{"cells":[{"cell_type":"code","execution_count":1,"metadata":{"executionInfo":{"elapsed":1713,"status":"ok","timestamp":1673957507997,"user":{"displayName":"M Petersen","userId":"13637530209006951077"},"user_tz":-60},"id":"URSGo6tJnbsE"},"outputs":[],"source":["import numpy as np\n","import matplotlib.pyplot as plt\n","import matplotlib\n","from sklearn.preprocessing import MinMaxScaler\n","from numba import jit\n","import pickle\n","import multiprocessing as mp\n","from functools import partial"]},{"cell_type":"markdown","metadata":{"id":"Qi6YFs2fHZK0"},"source":["# Verify Data"]},{"cell_type":"code","execution_count":2,"metadata":{"executionInfo":{"elapsed":421,"status":"ok","timestamp":1673957509672,"user":{"displayName":"M Petersen","userId":"13637530209006951077"},"user_tz":-60},"id":"bhRgTPrOni_y"},"outputs":[],"source":["@jit(fastmath=True, nopython=True)\n","def simulate_brownian_motion(num_steps, replica_num, dt=0.001, kT=60, mass=1, x0=np.array([-1.5, 1.5], dtype=np.float64), save_every=10):\n","    sigma = np.sqrt(2 * kT * dt / mass)\n","    x = x0.copy()\n","    positions = np.zeros((num_steps//save_every, replica_num, 4), dtype=np.float64)\n","    forces_mean = np.zeros((2, replica_num), dtype=np.float64)\n","    for i in range(num_steps):\n","        forces_x = -(18*x[:, 0]*(x[:, 0]**2-1)+3*x[:, 0]**2)\n","        forces_y = -(6*x[:, 1])\n","        forces_mean[0] += forces_x\n","        forces_mean[1] += forces_y\n","        if i%save_every==0:\n","            positions[i//save_every, ::, 0:2] = x\n","            positions[i//save_every, ::, 2:4] = forces_mean.T/save_every\n","            forces_mean = np.zeros((2, replica_num), dtype=np.float64)\n","        x += sigma*np.random.randn(replica_num, 2) # Euler-Maruyama integration scheme\n","        x[:, 0] += forces_x*dt\n","        x[:, 1] += forces_y*dt\n","    return positions"]},{"cell_type":"code","execution_count":3,"metadata":{},"outputs":[],"source":["def simulate_brownian_motion_pool(num_steps, replica_num, dt=0.001, kT=60, mass=1, x0=np.array([-1.5, 1.5], dtype=np.float64), save_every=10, threads=23):\n","    with mp.Pool(threads) as p:\n","        func = partial(simulate_brownian_motion, replica_num=replica_num, x0=x0, dt=dt, kT=kT, mass=mass, save_every=save_every)\n","        trajs = p.map(func, [num_steps]*threads)\n","        trajs = np.concatenate(trajs, axis=1)\n","    return trajs"]},{"cell_type":"code","execution_count":4,"metadata":{},"outputs":[{"name":"stdout","output_type":"stream","text":["0\n"]}],"source":["threads=23\n","\n","num_steps = 1000\n","replica_num = 600\n","save_every = 1\n","iterations = 1\n","dt = 0.001\n","kT = 1\n","mass = 1\n","\n","full_traj = np.zeros((num_steps//save_every, replica_num*iterations*threads, 4), dtype=np.float16)\n","for i in range(iterations):\n","    x0 = np.random.uniform(-2, 2, size=(replica_num, 2))\n","    x0 = simulate_brownian_motion(100000, replica_num, dt=dt, kT=kT, mass=mass, x0=x0, save_every=1)\n","    x0 = x0[-1, :, 0:2]\n","    positions = simulate_brownian_motion_pool(num_steps, replica_num, dt=dt, kT=kT, mass=mass, x0=x0, save_every=save_every, threads=threads)\n","    full_traj[:, i*replica_num*threads:(i+1)*replica_num*threads, ::] = positions\n","    print(i)"]},{"cell_type":"code","execution_count":5,"metadata":{"executionInfo":{"elapsed":51854,"status":"ok","timestamp":1673958056372,"user":{"displayName":"M Petersen","userId":"13637530209006951077"},"user_tz":-60},"id":"27qlTNgegIeI"},"outputs":[],"source":["max_min_array = np.array([full_traj.max(axis=(0, 1)), full_traj.min(axis=(0, 1))])\n","full_traj = (full_traj - max_min_array[1])/(max_min_array[0] - max_min_array[1])\n","full_traj = full_traj*2 - 1\n","\n","pickle.dump(max_min_array, open(\"Data/dw_scaler.pkl\", \"wb\"))\n","pickle.dump(full_traj, open(\"Data/traj_dw.pkl\", \"wb\"))"]},{"cell_type":"code","execution_count":null,"metadata":{},"outputs":[],"source":[]}],"metadata":{"accelerator":"GPU","colab":{"authorship_tag":"ABX9TyPatKxVo2fatyJ9+cQWXXRX","machine_shape":"hm","mount_file_id":"1Sp-blo5ysvJ9QQ9i12pYy7K5XHo9XMdL","provenance":[]},"gpuClass":"standard","kernelspec":{"display_name":"base","language":"python","name":"python3"},"language_info":{"codemirror_mode":{"name":"ipython","version":3},"file_extension":".py","mimetype":"text/x-python","name":"python","nbconvert_exporter":"python","pygments_lexer":"ipython3","version":"3.9.13"},"vscode":{"interpreter":{"hash":"639d8a7c3e620b1d142eea4deabde5aac9ed3b21a6e651e4622d69fbdac2ed0a"}}},"nbformat":4,"nbformat_minor":0}
