{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ad72d99-3e05-4264-b7f2-56264832006e",
   "metadata": {
    "execution": {
     "execution_failed": "2025-09-18T06:16:48.251Z",
     "iopub.execute_input": "2025-09-18T06:16:34.589256Z",
     "iopub.status.busy": "2025-09-18T06:16:34.588953Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/hkhong/miniconda3/envs/mlip/lib/python3.12/site-packages/e3nn/o3/_wigner.py:10: UserWarning: Environment variable TORCH_FORCE_NO_WEIGHTS_ONLY_LOAD detected, since the`weights_only` argument was not explicitly passed to `torch.load`, forcing weights_only=False.\n",
      "  _Jd, _W3j_flat, _W3j_indices = torch.load(os.path.join(os.path.dirname(__file__), 'constants.pt'))\n",
      "WARNING:root:'model_path' argument is deprecated, please use 'model_paths' in the future.\n",
      "/home/hkhong/Research/MLIP/diffmace/mace/calculators/mace.py:166: UserWarning: Environment variable TORCH_FORCE_NO_WEIGHTS_ONLY_LOAD detected, since the`weights_only` argument was not explicitly passed to `torch.load`, forcing weights_only=False.\n",
      "  torch.load(f=model_path, map_location=device)\n",
      "/tmp/ipykernel_2799681/2072608596.py:19: FutureWarning: Please use atoms.calc = calc\n",
      "  atoms.set_calculator(calculator)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using head Default out of ['Default']\n",
      "No dtype selected, switching to float64 to match model dtype.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[298.4350,   0.0000,   0.0000],\n",
      "        [  0.0000, 298.4350,   0.0000],\n",
      "        [  0.0000,   0.0000, 298.4350]], device='cuda:0')\n",
      "tensor([[149.2175,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.2175,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.2175]], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 1/1000 [00:01<32:23,  1.95s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[298.9780,   0.0000,   0.0000],\n",
      "        [  0.0000, 298.9780,   0.0000],\n",
      "        [  0.0000,   0.0000, 298.9780]], device='cuda:0')\n",
      "tensor([[149.4890,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.4890,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.4890]], device='cuda:0')\n",
      "tensor([[299.5852,   0.0000,   0.0000],\n",
      "        [  0.0000, 299.5852,   0.0000],\n",
      "        [  0.0000,   0.0000, 299.5852]], device='cuda:0')\n",
      "tensor([[149.7926,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.7926,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.7926]], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 2/1000 [00:03<24:29,  1.47s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[300.0377,   0.0000,   0.0000],\n",
      "        [  0.0000, 300.0377,   0.0000],\n",
      "        [  0.0000,   0.0000, 300.0377]], device='cuda:0')\n",
      "tensor([[150.0188,   0.0000,   0.0000],\n",
      "        [  0.0000, 150.0188,   0.0000],\n",
      "        [  0.0000,   0.0000, 150.0188]], device='cuda:0')\n",
      "tensor([[300.1929,   0.0000,   0.0000],\n",
      "        [  0.0000, 300.1929,   0.0000],\n",
      "        [  0.0000,   0.0000, 300.1929]], device='cuda:0')\n",
      "tensor([[150.0965,   0.0000,   0.0000],\n",
      "        [  0.0000, 150.0965,   0.0000],\n",
      "        [  0.0000,   0.0000, 150.0965]], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|          | 6/1000 [00:04<08:03,  2.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[300.0152,   0.0000,   0.0000],\n",
      "        [  0.0000, 300.0152,   0.0000],\n",
      "        [  0.0000,   0.0000, 300.0152]], device='cuda:0')\n",
      "tensor([[150.0076,   0.0000,   0.0000],\n",
      "        [  0.0000, 150.0076,   0.0000],\n",
      "        [  0.0000,   0.0000, 150.0076]], device='cuda:0')\n",
      "tensor([[299.5799,   0.0000,   0.0000],\n",
      "        [  0.0000, 299.5799,   0.0000],\n",
      "        [  0.0000,   0.0000, 299.5799]], device='cuda:0')\n",
      "tensor([[149.7900,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.7900,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.7900]], device='cuda:0')\n",
      "tensor([[299.0590,   0.0000,   0.0000],\n",
      "        [  0.0000, 299.0590,   0.0000],\n",
      "        [  0.0000,   0.0000, 299.0590]], device='cuda:0')\n",
      "tensor([[149.5295,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.5295,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.5295]], device='cuda:0')\n",
      "tensor([[298.6762,   0.0000,   0.0000],\n",
      "        [  0.0000, 298.6762,   0.0000],\n",
      "        [  0.0000,   0.0000, 298.6762]], device='cuda:0')\n",
      "tensor([[149.3381,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.3381,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.3381]], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|          | 10/1000 [00:04<04:47,  3.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[298.6242,   0.0000,   0.0000],\n",
      "        [  0.0000, 298.6242,   0.0000],\n",
      "        [  0.0000,   0.0000, 298.6242]], device='cuda:0')\n",
      "tensor([[149.3121,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.3121,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.3121]], device='cuda:0')\n",
      "tensor([[298.9653,   0.0000,   0.0000],\n",
      "        [  0.0000, 298.9653,   0.0000],\n",
      "        [  0.0000,   0.0000, 298.9653]], device='cuda:0')\n",
      "tensor([[149.4826,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.4826,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.4826]], device='cuda:0')\n",
      "tensor([[299.5886,   0.0000,   0.0000],\n",
      "        [  0.0000, 299.5886,   0.0000],\n",
      "        [  0.0000,   0.0000, 299.5886]], device='cuda:0')\n",
      "tensor([[149.7943,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.7943,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.7943]], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|▏         | 14/1000 [00:05<02:42,  6.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[300.2641,   0.0000,   0.0000],\n",
      "        [  0.0000, 300.2641,   0.0000],\n",
      "        [  0.0000,   0.0000, 300.2641]], device='cuda:0')\n",
      "tensor([[150.1321,   0.0000,   0.0000],\n",
      "        [  0.0000, 150.1321,   0.0000],\n",
      "        [  0.0000,   0.0000, 150.1321]], device='cuda:0')\n",
      "tensor([[300.7460,   0.0000,   0.0000],\n",
      "        [  0.0000, 300.7460,   0.0000],\n",
      "        [  0.0000,   0.0000, 300.7460]], device='cuda:0')\n",
      "tensor([[150.3730,   0.0000,   0.0000],\n",
      "        [  0.0000, 150.3730,   0.0000],\n",
      "        [  0.0000,   0.0000, 150.3730]], device='cuda:0')\n",
      "tensor([[300.8575,   0.0000,   0.0000],\n",
      "        [  0.0000, 300.8575,   0.0000],\n",
      "        [  0.0000,   0.0000, 300.8575]], device='cuda:0')\n",
      "tensor([[150.4288,   0.0000,   0.0000],\n",
      "        [  0.0000, 150.4288,   0.0000],\n",
      "        [  0.0000,   0.0000, 150.4288]], device='cuda:0')\n",
      "tensor([[300.5353,   0.0000,   0.0000],\n",
      "        [  0.0000, 300.5353,   0.0000],\n",
      "        [  0.0000,   0.0000, 300.5353]], device='cuda:0')\n",
      "tensor([[150.2677,   0.0000,   0.0000],\n",
      "        [  0.0000, 150.2677,   0.0000],\n",
      "        [  0.0000,   0.0000, 150.2677]], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 18/1000 [00:05<01:49,  8.97it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[299.8446,   0.0000,   0.0000],\n",
      "        [  0.0000, 299.8446,   0.0000],\n",
      "        [  0.0000,   0.0000, 299.8446]], device='cuda:0')\n",
      "tensor([[149.9223,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.9223,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.9223]], device='cuda:0')\n",
      "tensor([[298.9703,   0.0000,   0.0000],\n",
      "        [  0.0000, 298.9703,   0.0000],\n",
      "        [  0.0000,   0.0000, 298.9703]], device='cuda:0')\n",
      "tensor([[149.4852,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.4852,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.4852]], device='cuda:0')\n",
      "tensor([[298.1756,   0.0000,   0.0000],\n",
      "        [  0.0000, 298.1756,   0.0000],\n",
      "        [  0.0000,   0.0000, 298.1756]], device='cuda:0')\n",
      "tensor([[149.0878,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.0878,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.0878]], device='cuda:0')\n",
      "tensor([[297.7140,   0.0000,   0.0000],\n",
      "        [  0.0000, 297.7140,   0.0000],\n",
      "        [  0.0000,   0.0000, 297.7140]], device='cuda:0')\n",
      "tensor([[148.8570,   0.0000,   0.0000],\n",
      "        [  0.0000, 148.8570,   0.0000],\n",
      "        [  0.0000,   0.0000, 148.8570]], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 22/1000 [00:05<01:24, 11.57it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[297.7172,   0.0000,   0.0000],\n",
      "        [  0.0000, 297.7172,   0.0000],\n",
      "        [  0.0000,   0.0000, 297.7172]], device='cuda:0')\n",
      "tensor([[148.8586,   0.0000,   0.0000],\n",
      "        [  0.0000, 148.8586,   0.0000],\n",
      "        [  0.0000,   0.0000, 148.8586]], device='cuda:0')\n",
      "tensor([[298.1339,   0.0000,   0.0000],\n",
      "        [  0.0000, 298.1339,   0.0000],\n",
      "        [  0.0000,   0.0000, 298.1339]], device='cuda:0')\n",
      "tensor([[149.0669,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.0669,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.0669]], device='cuda:0')\n",
      "tensor([[298.7727,   0.0000,   0.0000],\n",
      "        [  0.0000, 298.7727,   0.0000],\n",
      "        [  0.0000,   0.0000, 298.7727]], device='cuda:0')\n",
      "tensor([[149.3864,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.3864,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.3864]], device='cuda:0')\n",
      "tensor([[299.4074,   0.0000,   0.0000],\n",
      "        [  0.0000, 299.4074,   0.0000],\n",
      "        [  0.0000,   0.0000, 299.4074]], device='cuda:0')\n",
      "tensor([[149.7037,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.7037,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.7037]], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  3%|▎         | 26/1000 [00:06<01:13, 13.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[299.8656,   0.0000,   0.0000],\n",
      "        [  0.0000, 299.8656,   0.0000],\n",
      "        [  0.0000,   0.0000, 299.8656]], device='cuda:0')\n",
      "tensor([[149.9328,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.9328,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.9328]], device='cuda:0')\n",
      "tensor([[300.0734,   0.0000,   0.0000],\n",
      "        [  0.0000, 300.0734,   0.0000],\n",
      "        [  0.0000,   0.0000, 300.0734]], device='cuda:0')\n",
      "tensor([[150.0367,   0.0000,   0.0000],\n",
      "        [  0.0000, 150.0367,   0.0000],\n",
      "        [  0.0000,   0.0000, 150.0367]], device='cuda:0')\n",
      "tensor([[300.0681,   0.0000,   0.0000],\n",
      "        [  0.0000, 300.0681,   0.0000],\n",
      "        [  0.0000,   0.0000, 300.0681]], device='cuda:0')\n",
      "tensor([[150.0341,   0.0000,   0.0000],\n",
      "        [  0.0000, 150.0341,   0.0000],\n",
      "        [  0.0000,   0.0000, 150.0341]], device='cuda:0')\n",
      "tensor([[299.9880,   0.0000,   0.0000],\n",
      "        [  0.0000, 299.9880,   0.0000],\n",
      "        [  0.0000,   0.0000, 299.9880]], device='cuda:0')\n",
      "tensor([[149.9940,   0.0000,   0.0000],\n",
      "        [  0.0000, 149.9940,   0.0000],\n",
      "        [  0.0000,   0.0000, 149.9940]], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  3%|▎         | 30/1000 [00:06<01:10, 13.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[300.0376,   0.0000,   0.0000],\n",
      "        [  0.0000, 300.0376,   0.0000],\n",
      "        [  0.0000,   0.0000, 300.0376]], device='cuda:0')\n",
      "tensor([[150.0188,   0.0000,   0.0000],\n",
      "        [  0.0000, 150.0188,   0.0000],\n",
      "        [  0.0000,   0.0000, 150.0188]], device='cuda:0')\n",
      "tensor([[300.4137,   0.0000,   0.0000],\n",
      "        [  0.0000, 300.4137,   0.0000],\n",
      "        [  0.0000,   0.0000, 300.4137]], device='cuda:0')\n",
      "tensor([[150.2069,   0.0000,   0.0000],\n",
      "        [  0.0000, 150.2069,   0.0000],\n",
      "        [  0.0000,   0.0000, 150.2069]], device='cuda:0')\n",
      "tensor([[301.2031,   0.0000,   0.0000],\n",
      "        [  0.0000, 301.2031,   0.0000],\n",
      "        [  0.0000,   0.0000, 301.2031]], device='cuda:0')\n",
      "tensor([[150.6015,   0.0000,   0.0000],\n",
      "        [  0.0000, 150.6015,   0.0000],\n",
      "        [  0.0000,   0.0000, 150.6015]], device='cuda:0')\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from ase import Atoms\n",
    "from ase.io import read, Trajectory\n",
    "from ase.md.velocitydistribution import MaxwellBoltzmannDistribution\n",
    "from ase.md.verlet import VelocityVerlet\n",
    "from ase.calculators.lj import LennardJones\n",
    "from ase import units\n",
    "\n",
    "from mace.calculators import MACECalculator\n",
    "xyz_file_path = \"datasets/3BPA/test_600K.xyz\"\n",
    "molecules = read(xyz_file_path, format='extxyz', index=':')\n",
    "atoms = molecules[0]\n",
    "\n",
    "calculator = MACECalculator(model_path='./checkpoints/dmace_3BPA_config2_run-123_stagetwo.model', device='cuda')\n",
    "calculator.models[0].eval()\n",
    "\n",
    "# Set up calculator (using Lennard-Jones potential for simplicity)\n",
    "# calculator = LennardJones(epsilon=1.0, sigma=3.4)  # Example parameters\n",
    "atoms.set_calculator(calculator)\n",
    "\n",
    "# Set initial velocities (e.g., at 300 K)\n",
    "temperature = 300  # Kelvin\n",
    "MaxwellBoltzmannDistribution(atoms, temperature_K=temperature)\n",
    "\n",
    "# Set up NVE simulation\n",
    "from tqdm import tqdm\n",
    "from ase.md.langevin import Langevin\n",
    "dyn = VelocityVerlet(atoms, timestep=1.0 * units.fs)  # 1 fs timestep\n",
    "# dyn = Langevin(atoms, 0.5*units.fs, temperature_K=310, friction=5e-3)\n",
    "\n",
    "# Run simulation for 1000 steps\n",
    "n_steps = 10*100\n",
    "file = open('real_md/3bpa.csv', 'w+')\n",
    "for step in tqdm(range(n_steps)):\n",
    "    dyn.run(1)  # Run one step at a time\n",
    "    if step % 100 == 0:  # Print energy every 100 steps\n",
    "        potential_energy = atoms.get_potential_energy()\n",
    "        kinetic_energy = atoms.get_kinetic_energy()\n",
    "        total_energy = potential_energy + kinetic_energy\n",
    "        # print(f\"Step {step}: Total Energy = {total_energy:.4f} eV, \"\n",
    "        #       f\"Potential = {potential_energy:.4f} eV, \"\n",
    "        #       f\"Kinetic = {kinetic_energy:.4f} eV\")\n",
    "        file.write(f'{step}, {total_energy:.4f}, {potential_energy:.4f}, {kinetic_energy:.4f}\\n')\n",
    "file.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6b2afbdf-4f86-4d81-9856-f7e11c518976",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-08-07T07:27:59.473516Z",
     "iopub.status.busy": "2025-08-07T07:27:59.472861Z",
     "iopub.status.idle": "2025-08-07T07:29:32.137993Z",
     "shell.execute_reply": "2025-08-07T07:29:32.137388Z",
     "shell.execute_reply.started": "2025-08-07T07:27:59.473460Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2364784/1594612250.py:26: FutureWarning: Please use atoms.calc = calc\n",
      "  molecule.set_calculator(calculator)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MD simulation completed. Energies and temperature saved to 'md_energies.txt'.\n",
      "Trajectory saved to 'md_langevin.traj'.\n"
     ]
    }
   ],
   "source": [
    "from ase import Atoms\n",
    "from ase.md.langevin import Langevin\n",
    "from ase.calculators.emt import EMT\n",
    "from ase.units import fs, kB\n",
    "import numpy as np\n",
    "from ase.io import Trajectory\n",
    "\n",
    "# Example: Create a sample molecule (replace with your own Atoms object)\n",
    "\n",
    "file = '../../Data/chignolin_data/raw/chignolin.npz'\n",
    "data = np.load(file)\n",
    "positions = data['R'][:166]  # Coordinates in Ångström\n",
    "atomic_numbers = data['Z'][:166]  # Atomic numbers\n",
    "\n",
    "# Create ASE Atoms object\n",
    "molecule = Atoms(numbers=atomic_numbers, positions=positions)\n",
    "\n",
    "\n",
    "# molecule = Atoms('H2', positions=[(0, 0, 0), (0, 0, 0.74)])\n",
    "# molecule.center(vacuum=10.0)\n",
    "\n",
    "# Set up the calculator (replace EMT with your preferred calculator)\n",
    "molecule.calc = EMT()\n",
    "# from mace.calculators import MACECalculator\n",
    "# calculator = MACECalculator(model_path='./checkpoints/MACE_model_run-123.model', device='cuda:9')\n",
    "molecule.set_calculator(calculator)\n",
    "\n",
    "# Simulation parameters\n",
    "temperature = 300  # Temperature in Kelvin\n",
    "timestep = 1.0 * fs  # Timestep in femtoseconds\n",
    "friction = 0.01 / fs  # Friction coefficient in fs⁻¹\n",
    "total_steps = 10000  # 100 ps = 100,000 fs / 1.0 fs per step\n",
    "log_interval = 1000  # Log every 1000 steps (1 ps)\n",
    "\n",
    "# Initialize output file for energies and temperature\n",
    "output_file = 'real_MD/md_energies.txt'\n",
    "with open(output_file, 'w') as f:\n",
    "    f.write('# Step\\tTime(ps)\\tPotential_E(eV)\\tKinetic_E(eV)\\tTotal_E(eV)\\tTemperature(K)\\n')\n",
    "\n",
    "# Function to log energies and temperature\n",
    "def log_energies(atoms, step, time_ps):\n",
    "    pot_energy = atoms.get_potential_energy()\n",
    "    kin_energy = atoms.get_kinetic_energy()\n",
    "    total_energy = pot_energy + kin_energy\n",
    "    temp = kin_energy / (1.5 * kB * len(atoms))  # Temperature from kinetic energy\n",
    "    with open(output_file, 'a') as f:\n",
    "        f.write(f'{step}\\t{time_ps:.3f}\\t{pot_energy:.6f}\\t{kin_energy:.6f}\\t{total_energy:.6f}\\t{temp:.2f}\\n')\n",
    "\n",
    "# Initialize Langevin dynamics\n",
    "dyn = Langevin(\n",
    "    atoms=molecule,\n",
    "    timestep=timestep,\n",
    "    temperature_K=temperature,\n",
    "    friction=friction,\n",
    "    logfile='real_MD/md_langevin.log',\n",
    "    trajectory='real_MD/md_langevin.traj'\n",
    ")\n",
    "\n",
    "# Attach the logging function\n",
    "def print_energies():\n",
    "    step = dyn.get_number_of_steps()\n",
    "    time_ps = step * timestep / fs / 1000  # Convert to picoseconds\n",
    "    log_energies(molecule, step, time_ps)\n",
    "\n",
    "dyn.attach(print_energies, interval=log_interval)\n",
    "\n",
    "# Run the simulation\n",
    "dyn.run(total_steps)\n",
    "\n",
    "print(\"MD simulation completed. Energies and temperature saved to 'md_energies.txt'.\")\n",
    "print(\"Trajectory saved to 'md_langevin.traj'.\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.12.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
