{"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","1\n","2\n","3\n","4\n","5\n","6\n","7\n","8\n","9\n","10\n","11\n","12\n","13\n","14\n","15\n","16\n","17\n","18\n","19\n","20\n","21\n","22\n","23\n","24\n","25\n","26\n","27\n","28\n","29\n","30\n","31\n","32\n","33\n","34\n","35\n","36\n","37\n","38\n","39\n","40\n","41\n","42\n","43\n","44\n","45\n","46\n","47\n","48\n","49\n","50\n","51\n","52\n","53\n","54\n","55\n","56\n","57\n","58\n","59\n","60\n","61\n","62\n","63\n","64\n","65\n","66\n","67\n","68\n","69\n","70\n","71\n","72\n","73\n","74\n","75\n","76\n","77\n","78\n","79\n","80\n","81\n","82\n","83\n","84\n","85\n","86\n","87\n","88\n","89\n","90\n","91\n","92\n","93\n","94\n","95\n","96\n","97\n","98\n","99\n","100\n","101\n","102\n","103\n","104\n","105\n","106\n","107\n","108\n","109\n","110\n","111\n","112\n","113\n","114\n","115\n","116\n","117\n","118\n","119\n","120\n","121\n","122\n","123\n","124\n","125\n","126\n","127\n","128\n","129\n","130\n","131\n","132\n","133\n","134\n","135\n","136\n","137\n","138\n","139\n","140\n","141\n","142\n","143\n","144\n","145\n","146\n","147\n","148\n","149\n","150\n","151\n","152\n","153\n","154\n","155\n","156\n","157\n","158\n","159\n","160\n","161\n","162\n","163\n","164\n","165\n","166\n","167\n","168\n","169\n","170\n","171\n","172\n","173\n","174\n","175\n","176\n","177\n","178\n","179\n","180\n","181\n","182\n","183\n","184\n","185\n","186\n","187\n","188\n","189\n","190\n","191\n","192\n","193\n","194\n","195\n","196\n","197\n","198\n","199\n"]}],"source":["threads=23\n","\n","num_steps = 512\n","replica_num = 100\n","save_every = 1\n","dt = 0.001\n","temp_count = 200\n","kT = np.linspace(0.5, 1.5, num=temp_count)\n","mass = 1\n","\n","full_traj = np.zeros((num_steps//save_every, temp_count, replica_num*threads, 4), dtype=np.float16)\n","for i in range(temp_count):\n","    x0 = np.random.uniform(-2, 2, size=(replica_num, 2))\n","    #short equilibration\n","    x0 = simulate_brownian_motion(100000, replica_num, dt=dt, kT=kT[i], mass=mass, x0=x0, save_every=save_every)\n","    x0 = x0[-1, :, 0:2]\n","    positions = simulate_brownian_motion_pool(num_steps, replica_num, dt=dt, kT=kT[i], mass=mass, x0=x0, save_every=save_every, threads=threads)\n","    full_traj[:, i, ::, ::] = 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, 2)), full_traj.min(axis=(0, 1, 2))])\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}
