Skip to content

Commit

Permalink
docs: Improve tutorials
Browse files Browse the repository at this point in the history
Apply feedback from summer school participants and tutors: LB units
conversion, LB Mach number, non-standard LB symbols, broken links to
the user guide, better plot axis labels, automatically update ZnDraw
visualizer. Also remove the summer school banner.
  • Loading branch information
jngrad committed Oct 11, 2024
1 parent 5fb1106 commit 6ba8718
Show file tree
Hide file tree
Showing 6 changed files with 55 additions and 43 deletions.
6 changes: 0 additions & 6 deletions Readme.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,3 @@
# Invitation to the ESPResSo Summer School 2024

[![CECAM Flagship School registration link](https://img.shields.io/badge/CECAM%20Flagship%20School-Register%20Now-blue?style=for-the-badge)](https://www.cecam.org/workshop-details/1324)

The summer school "Simulating soft matter across scales" will take place on October 7-11, 2024, in Stuttgart. Registration is now open on [CECAM](https://www.cecam.org/workshop-details/1324).

# ESPResSo

[![GitLab CI](https://gitlab.icp.uni-stuttgart.de/espressomd/espresso/badges/python/pipeline.svg)](https://gitlab.icp.uni-stuttgart.de/espressomd/espresso/-/commits/python)
Expand Down
6 changes: 3 additions & 3 deletions doc/bibliography.bib
Original file line number Diff line number Diff line change
Expand Up @@ -688,13 +688,13 @@ @Book{kruger17a
address = {Cham},
}

@Book{kundu01a,
@Book{kundu02a,
author = {Kundu, Pijush K. and Cohen, Ira M. and Hu, Howard},
title = {Fluid Mechanics},
year = {2001},
year = {2002},
edition = {2nd},
publisher = {Elsevier Science},
isbn = {9780080545585},
isbn = {978-0-12-178251-1},
doi = {10.1016/C2009-0-20716-1},
}

Expand Down
4 changes: 2 additions & 2 deletions doc/tutorials/electrokinetics/electrokinetics.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@
"id": "192c4793",
"metadata": {},
"source": [
"The first system that is simulated in this tutorial is the simple advection-diffusion of a drop of uncharged chemical species in a constant velocity field. To keep the computation time small, we restrict ourselves to a 2D problem, but the algorithm is also capable of solving the 3D advection-diffusion equation. Furthermore, we can also skip solving the electrostatic Poisson equation, since there are is no charged species present. The equations we solve thus reduce to\n",
"The first system that is simulated in this tutorial is the simple advection-diffusion of a drop of uncharged chemical species in a constant velocity field. To keep the computation time small, we restrict ourselves to a 2D problem, but the algorithm is also capable of solving the 3D advection-diffusion equation. Furthermore, we can also skip solving the electrostatic Poisson equation, since there are no charged species present. The equations we solve thus reduce to\n",
"\n",
"\\begin{equation}\n",
"\\partial_{t} n = D \\Delta n - \\vec{\\nabla} \\cdot (\\vec{v} n).\n",
Expand Down Expand Up @@ -187,7 +187,7 @@
"metadata": {},
"source": [
"# Exercise:\n",
"- Create an instance of the [`espressomd.electrokinetics.EKSpecies`]() and add it to the system with [`system.ekcontainer.add()`](https://espressomd.github.io/doc/espressomd.html#espressomd.electrokinetics.EKContainer.add). \n",
"- Create an instance of the [`espressomd.electrokinetics.EKSpecies`](https://espressomd.github.io/doc/espressomd.html#espressomd.electrokinetics.EKSpecies) and add it to the system with [`system.ekcontainer.add()`](https://espressomd.github.io/doc/espressomd.html#espressomd.electrokinetics.EKContainer.add). \n",
"\n",
"# Hint:\n",
"- Use the variables `DIFFUSION_COEFFICIENT`, `KT` and `TAU` defined above.\n",
Expand Down
55 changes: 33 additions & 22 deletions doc/tutorials/lattice_boltzmann/lattice_boltzmann_theory.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@
"The LBM essentially consists of solving a fully discretized version of the linearized\n",
"Boltzmann equation. The Boltzmann equation describes the time evolution of the one\n",
"particle distribution function $f \\left(\\vec{x}, \\vec{p}, t\\right)$, which is the probability of finding a molecule in\n",
"a phase space volume $d^3\\vec{x}\\,d^3\\vec{p}$ at time $t$.The function $f$ is normalized so that the integral\n",
"a phase space volume $d^3\\vec{x}\\,d^3\\vec{p}$ at time $t$. The function $f$ is normalized so that the integral\n",
"over the whole phase space is the total mass of the particles:\n",
"\n",
"$$\\int \\int f \\left(\\vec{x}, \\vec{p}, t\\right) \\,d^3\\vec{x}\\,d^3\\vec{p} = N,$$\n",
Expand Down Expand Up @@ -121,8 +121,8 @@
"cell in every LBM step.\n",
"\n",
"<figure>\n",
"<img src='figures/latticeboltzmann-grid.png', style=\"width: 300px;\"/>\n",
"<center>\n",
"<img src='figures/latticeboltzmann-grid.png', style=\"width: 300px;\"/>\n",
"<figcaption>The 19 velocity vectors $\\vec{c_i}$ for a D3Q19 lattice. From the central grid point, the velocity vectors point towards all 18 nearest neighbours marked by filled circles. The 19th velocity vector is the rest mode (zero velocity).</figcaption>\n",
"</center>\n",
"</figure>"
Expand All @@ -137,7 +137,7 @@
"The second step is the collision part, where the actual physics happens. For the LBM it is assumed that the collision process linearly relaxes the populations to the local equilibrium, thus that it is a linear (=matrix) operator \n",
"acting on the populations in each LB cell. It should conserve \n",
"the particle number and the momentum. At this point it is clear\n",
"why the mode space is helpful. A 19 dimensional matrix that\n",
"why the mode space is helpful. A 19-dimensional matrix that\n",
"conserves the first 4 modes (with the eigenvalue 1) is diagonal in the\n",
"first four rows and columns.\n",
"By symmetry consideration one finds that only four independent\n",
Expand All @@ -155,22 +155,22 @@
"and has the form\n",
"\n",
"\\begin{align*}\n",
" m^\\star_i &= \\gamma_i \\left( m_i - m_i^\\text{eq} \\right) + m_i ^\\text{eq}.\n",
" m^\\star_i &= \\omega_i \\left( m_i - m_i^\\text{eq} \\right) + m_i ^\\text{eq}.\n",
"\\end{align*}\n",
"\n",
"Here $m^\\star_i$ is the $i$th mode after the collision.\n",
"In other words: each mode is relaxed towards\n",
"its equilibrium value with a relaxation rate $\\gamma_i$.\n",
"its equilibrium value with a relaxation rate $\\omega_i$.\n",
"The conserved modes are not relaxed, i.e. their relaxation rate is 1.\n",
"We summarize them here:\n",
"\n",
"\\begin{align*}\n",
" m^\\star_i &= \\gamma_i m_i \\\\\n",
" \\gamma_1=\\dots=\\gamma_4&=1 \\\\\n",
" \\gamma_5&=\\gamma_\\text{b} \\\\\n",
" \\gamma_6=\\dots=\\gamma_{10}&=\\gamma_\\text{s} \\\\\n",
" \\gamma_{11}=\\dots=\\gamma_{16}&=\\gamma_\\text{odd} \\\\\n",
" \\gamma_{17}=\\dots = \\gamma_{19}&=\\gamma_\\text{even} \\\\\n",
" m^\\star_i &= \\omega_i m_i \\\\\n",
" \\omega_1=\\dots=\\omega_4&=1 \\\\\n",
" \\omega_5&=\\omega_\\text{b} \\\\\n",
" \\omega_6=\\dots=\\omega_{10}&=\\omega_\\text{s} \\\\\n",
" \\omega_{11}=\\dots=\\omega_{16}&=\\omega_\\text{odd} \\\\\n",
" \\omega_{17}=\\dots = \\omega_{19}&=\\omega_\\text{even} \\\\\n",
"\\end{align*}\n",
"\n",
"To include hydrodynamic fluctuations of the fluid, \n",
Expand Down Expand Up @@ -202,8 +202,8 @@
"to the fluctuation dissipation theorem. \n",
"\n",
"<figure>\n",
"<img src='figures/latticeboltzmann-momentumexchange.png', style=\"width: 300px;\"/>\n",
"<center>\n",
"<img src='figures/latticeboltzmann-momentumexchange.png', style=\"width: 300px;\"/>\n",
"<figcaption>The coupling scheme between fluid and particles is based on the interpolation of the fluid velocity $\\vec{u}$ from the grid nodes. This is done by trilinear interpolation. The difference between the particle velocity $\\vec{v}(t)$ and the interpolated velocity $\\vec{u}(\\vec{r},t)$ is used in the momentum exchange of the equation $\\vec{F}_H$ above.</figcaption>\n",
"</center>\n",
"</figure>"
Expand All @@ -221,33 +221,44 @@
"[<tt>LBFluidWalberlaGPU</tt>](https://espressomd.github.io/doc/espressomd.html#espressomd.lb.LBFluidWalberlaGPU) in the module\n",
"[<tt>espressomd.lb</tt>](https://espressomd.github.io/doc/espressomd.html#module-espressomd.lb).\n",
"\n",
"The LB lattice is a cubic lattice, with a lattice constant <tt>agrid</tt> that\n",
"The LB lattice is a cubic lattice, with a lattice constant <tt>agrid</tt> in MD units that\n",
"is the same in all spatial directions. The chosen box length must be an integer multiple\n",
"of <tt>agrid</tt>. The LB lattice is shifted by 0.5 <tt>agrid</tt> in all directions: the node\n",
"with integer coordinates $\\left(0,0,0\\right)$ is located at\n",
"$\\left(0.5a,0.5a,0.5a\\right)$.\n",
"The LB scheme and the MD scheme are not synchronized: in one\n",
"LB time step, several MD steps may be performed. This allows to speed\n",
"up the simulations and is adjusted with the parameter <tt>tau</tt>.\n",
"up the simulations and is adjusted with the parameter <tt>tau</tt> in MD units.\n",
"The LB parameter <tt>tau</tt> must be an integer multiple of the MD timestep.\n",
"\n",
"Even if MD features are not used, the System parameters <tt>cell_system.skin</tt> and <tt>time_step</tt> must be set. LB steps are performed \n",
"Even if MD features are not used, the system parameters <tt>cell_system.skin</tt> and <tt>time_step</tt> must be set. LB steps are performed \n",
"in regular intervals, such that the timestep $\\tau$ for LB is recovered.\n",
"\n",
"Important note: all commands of the LB interface use\n",
"MD units. This is convenient, as e.g. a particular \n",
"viscosity can be set and the LB time step can be changed without\n",
"altering the viscosity. On the other hand this is a source\n",
"Important note: all commands of the LB interface use MD units.\n",
"This is convenient, as e.g. a particular viscosity can be set\n",
"and the LB time step can be changed without altering the viscosity.\n",
"In LB units, both <tt>agrid</tt> and <tt>tau</tt> are unity.\n",
"On the other hand this is a source\n",
"of a plethora of mistakes: the LBM is only reliable in a certain \n",
"range of parameters (in LB units) and the unit conversion\n",
"may take some of them far out of this range. So remember to always\n",
"make sure you are not messing with that!\n",
"\n",
"One brief example: a certain velocity may be 10 in MD units.\n",
"If the LB time step is 0.1 in MD units, and the lattice constant\n",
"is 1, then it corresponds to a velocity of $1\\ \\frac{a}{\\tau}$ in LB units.\n",
"This is the maximum velocity of the discrete velocity set and therefore\n",
"causes numerical instabilities like negative populations."
"is 1.0 in MD units, then it corresponds to a velocity of 1 in LB units.\n",
"More specifically, given a velocity $v = 10\\ \\ell^\\star\\cdot t^{\\star-1}$ with\n",
"$\\ell^\\star$ the reduced MD length unit and $t^\\star$ the reduced MD time unit,\n",
"and LB parameters $a = 1\\ \\ell^\\star$ and $\\tau = 0.1\\ t^\\star$ in MD units,\n",
"then the corresponding velocity in LB units is given by\n",
"$u = v \\cdot \\tau / a = 10\\ \\ell^\\star\\cdot t^{\\star-1} \\cdot 0.1\\ t^\\star / 1\\ \\ell^{\\star} = 1$.\n",
"\n",
"In practice, you would like the fluid velocity to be much smaller than the fluid\n",
"speed of sound $c_s = \\frac{1}{\\sqrt{3}}\\frac{a}{\\tau}$ in MD units, aka Mach 1,\n",
"to avoid numerical instabilities due to the breakdown of the incompressibility assumption.\n",
"It is usually good practice to avoid exceeding Mach 0.2.\n",
"At Mach 0.35 the relative error in the calculated fluid density is ~6%,\n",
"which can ultimately lead to negative populations."
]
},
{
Expand Down
25 changes: 16 additions & 9 deletions doc/tutorials/lennard_jones/lennard_jones.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -615,7 +615,12 @@
"id": "10510b16-bc19-4c16-a881-a3b88cc298f6",
"metadata": {},
"source": [
"### System visualization "
"### System visualization\n",
"\n",
"We will use ZnDraw to visualize and interact with the simulation box.\n",
"On the server has started, a new frame will appear in the notebook with a menu bar and various buttons.\n",
"The bottom numbers represent the number of frames and the current position in the animation.\n",
"We will soon integrate the system and update the visualizer with the new system configurations."
]
},
{
Expand All @@ -630,7 +635,8 @@
"radii = {0: LJ_SIG/2.0} # Particle size by type\n",
"\n",
"# Initializing Visualizer\n",
"vis = espressomd.zn.Visualizer(system, colors=color, radii=radii)"
"vis = espressomd.zn.Visualizer(system, colors=color, radii=radii)\n",
"vis.update()"
]
},
{
Expand Down Expand Up @@ -672,7 +678,8 @@
"* Integrate the system and measure the total and kinetic energy. Take ``N_SAMPLES`` measurements every ``STEPS_PER_SAMPLE`` integration steps. Notice that the total simulated time in LJ units is given by the product <tt>N_SAMPLES</tt> $\\times$ <tt>STEPS_PER_SAMPLE</tt> $\\times$ <tt>TIME_STEP</tt>.\n",
"* Calculate the total and kinetic energies using the analysis method [<tt>system.analysis.energy()</tt>](https://espressomd.github.io/doc/espressomd.html#module-espressomd.analyze).\n",
"* Use the containers ``times``, ``e_total`` and ``e_kin`` from the cell above to store the time series.\n",
"* From the simulation results, calculate the kinetic temperature $T_{\\mathrm{inst}} = 2/3 \\times E_{\\mathrm{kin}}$ / <tt>N_PART</tt>."
"* From the simulation results, calculate the kinetic temperature $T_{\\mathrm{inst}} = 2/3 \\times E_{\\mathrm{kin}}$ / <tt>N_PART</tt>.\n",
"* Call `vis.update()` at the end of each loop to update the visualizer. Click inside the ZnDraw frame and press the space bar to animate the frames."
]
},
{
Expand Down Expand Up @@ -701,11 +708,11 @@
"outputs": [],
"source": [
"plt.figure(figsize=(10, 6))\n",
"plt.plot(times, T_inst, label='$T_{\\\\mathrm{inst}}$')\n",
"plt.plot(times, [TEMPERATURE] * len(times), label='$T$ set by thermostat')\n",
"plt.plot(times, T_inst, label=r\"$T_{\\mathrm{inst}}$\")\n",
"plt.plot(times, [TEMPERATURE] * len(times), label=r\"$T_{\\mathrm{thermostat}}$\")\n",
"plt.legend()\n",
"plt.xlabel('t')\n",
"plt.ylabel('T')\n",
"plt.xlabel(\"Simulation time\")\n",
"plt.ylabel(\"Temperature\")\n",
"plt.show()"
]
},
Expand Down Expand Up @@ -844,8 +851,8 @@
"plt.ylim(top=1.2, bottom=-0.15)\n",
"plt.legend()\n",
"plt.xscale('log')\n",
"plt.xlabel('t')\n",
"plt.ylabel('total energy autocorrelation')\n",
"plt.xlabel('Simulation time')\n",
"plt.ylabel('Total energy autocorrelation')\n",
"plt.show()"
]
},
Expand Down
2 changes: 1 addition & 1 deletion src/python/espressomd/lb.py
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ def mach_limit(self):
The relative error in the fluid density between a compressible fluid
and an incompressible fluid at Mach 0.30 is less than 5% (see
*constant density assumption* in :cite:`kundu01a` chapter 16, page
*constant density assumption* in :cite:`kundu02a` chapter 16, page
663). Since the speed of sound is :math:`c_s = 1 / \\sqrt{3}` in LB
velocity units in a D3Q19 lattice, the velocity limit at Mach 0.30
is :math:`v_{\\mathrm{max}} = 0.30 / \\sqrt{3} \\approx 0.17`.
Expand Down

0 comments on commit 6ba8718

Please sign in to comment.