Skip to content

Commit

Permalink
Docs: New Kin Energy APIs
Browse files Browse the repository at this point in the history
  • Loading branch information
ax3l committed Oct 20, 2023
1 parent d4e8126 commit 10015d0
Show file tree
Hide file tree
Showing 2 changed files with 90 additions and 72 deletions.
146 changes: 82 additions & 64 deletions docs/source/usage/parameters.rst
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,9 @@ Overall simulation parameters
Setting up the field mesh
-------------------------

ImpactX uses an AMReX grid of boxes to organize and parallelize the simulation domain.
These boxes also contain a field mesh, if space charge calculations are enabled.

* ``amr.n_cell`` (3 integers) optional (default: 1 `blocking_factor <https://amrex-codes.github.io/amrex/docs_html/GridCreation.html>`__ per MPI process)
The number of grid points along each direction (on the **coarsest level**)

Expand Down Expand Up @@ -114,104 +117,119 @@ Domain Boundary Conditions
Initial Beam Distributions
--------------------------

* ``<distribution>.type`` (``string``)
* ``beam.npart`` (``integer``)
number of weighted simulation particles

* ``beam.units`` (``string``)
currently, only ``static`` is supported.

* ``beam.kin_energy`` (``float``, in MeV)
beam kinetic energy

* ``beam.charge`` (``float``, in C)
bunch charge

* ``beam.particle`` (``string``)
particle type: currently either ``electron``, ``positron`` or ``proton``

* ``beam.distribution`` (``string``)
Indicates the initial distribution type.
This should be one of:

* ``waterbag`` for initial Waterbag distribution.
With additional parameters:

* ``<distribution>.sigmaX`` (``float``, in meters) rms X
* ``<distribution>.sigmaY`` (``float``, in meters) rms Y
* ``<distribution>.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``<distribution>.sigmaPx`` (``float``, in momentum) rms Px
* ``<distribution>.sigmaPy`` (``float``, in momentum) rms Py
* ``<distribution>.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``<distribution>.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``<distribution>.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``<distribution>.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt
* ``beam.sigmaX`` (``float``, in meters) rms X
* ``beam.sigmaY`` (``float``, in meters) rms Y
* ``beam.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``beam.sigmaPx`` (``float``, in momentum) rms Px
* ``beam.sigmaPy`` (``float``, in momentum) rms Py
* ``beam.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``beam.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``beam.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``beam.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt

* ``kurth6d`` for initial 6D Kurth distribution.
With additional parameters:

* ``<distribution>.sigmaX`` (``float``, in meters) rms X
* ``<distribution>.sigmaY`` (``float``, in meters) rms Y
* ``<distribution>.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``<distribution>.sigmaPx`` (``float``, in momentum) rms Px
* ``<distribution>.sigmaPy`` (``float``, in momentum) rms Py
* ``<distribution>.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``<distribution>.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``<distribution>.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``<distribution>.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt
* ``beam.sigmaX`` (``float``, in meters) rms X
* ``beam.sigmaY`` (``float``, in meters) rms Y
* ``beam.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``beam.sigmaPx`` (``float``, in momentum) rms Px
* ``beam.sigmaPy`` (``float``, in momentum) rms Py
* ``beam.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``beam.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``beam.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``beam.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt

* ``gaussian`` for initial 6D Gaussian (normal) distribution.
With additional parameters:

* ``<distribution>.sigmaX`` (``float``, in meters) rms X
* ``<distribution>.sigmaY`` (``float``, in meters) rms Y
* ``<distribution>.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``<distribution>.sigmaPx`` (``float``, in momentum) rms Px
* ``<distribution>.sigmaPy`` (``float``, in momentum) rms Py
* ``<distribution>.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``<distribution>.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``<distribution>.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``<distribution>.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt
* ``beam.sigmaX`` (``float``, in meters) rms X
* ``beam.sigmaY`` (``float``, in meters) rms Y
* ``beam.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``beam.sigmaPx`` (``float``, in momentum) rms Px
* ``beam.sigmaPy`` (``float``, in momentum) rms Py
* ``beam.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``beam.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``beam.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``beam.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt

* ``kvdist`` for initial K-V distribution in the transverse plane.
The distribution is uniform in t and Gaussian in pt.
With additional parameters:

* ``<distribution>.sigmaX`` (``float``, in meters) rms X
* ``<distribution>.sigmaY`` (``float``, in meters) rms Y
* ``<distribution>.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``<distribution>.sigmaPx`` (``float``, in momentum) rms Px
* ``<distribution>.sigmaPy`` (``float``, in momentum) rms Py
* ``<distribution>.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``<distribution>.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``<distribution>.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``<distribution>.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt
* ``beam.sigmaX`` (``float``, in meters) rms X
* ``beam.sigmaY`` (``float``, in meters) rms Y
* ``beam.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``beam.sigmaPx`` (``float``, in momentum) rms Px
* ``beam.sigmaPy`` (``float``, in momentum) rms Py
* ``beam.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``beam.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``beam.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``beam.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt

* ``kurth4d`` for initial 4D Kurth distribution in the transverse plane.
The distribution is uniform in t and Gaussian in pt.
With additional parameters:

* ``<distribution>.sigmaX`` (``float``, in meters) rms X
* ``<distribution>.sigmaY`` (``float``, in meters) rms Y
* ``<distribution>.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``<distribution>.sigmaPx`` (``float``, in momentum) rms Px
* ``<distribution>.sigmaPy`` (``float``, in momentum) rms Py
* ``<distribution>.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``<distribution>.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``<distribution>.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``<distribution>.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt
* ``beam.sigmaX`` (``float``, in meters) rms X
* ``beam.sigmaY`` (``float``, in meters) rms Y
* ``beam.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``beam.sigmaPx`` (``float``, in momentum) rms Px
* ``beam.sigmaPy`` (``float``, in momentum) rms Py
* ``beam.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``beam.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``beam.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``beam.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt

* ``semigaussian`` for initial Semi-Gaussian distribution. The distribution is uniform within a cylinder in (x,y,z) and Gaussian in momenta (px,py,pt).
With additional parameters:

* ``<distribution>.sigmaX`` (``float``, in meters) rms X
* ``<distribution>.sigmaY`` (``float``, in meters) rms Y
* ``<distribution>.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``<distribution>.sigmaPx`` (``float``, in momentum) rms Px
* ``<distribution>.sigmaPy`` (``float``, in momentum) rms Py
* ``<distribution>.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``<distribution>.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``<distribution>.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``<distribution>.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt
* ``beam.sigmaX`` (``float``, in meters) rms X
* ``beam.sigmaY`` (``float``, in meters) rms Y
* ``beam.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``beam.sigmaPx`` (``float``, in momentum) rms Px
* ``beam.sigmaPy`` (``float``, in momentum) rms Py
* ``beam.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``beam.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``beam.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``beam.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt

* ``triangle`` a triangle distribution for laser-plasma acceleration related applications.
A ramped, triangular current profile with a Gaussian energy spread (possibly correlated).
The transverse distribution is a 4D waterbag.
With additional parameters:

* ``<distribution>.sigmaX`` (``float``, in meters) rms X
* ``<distribution>.sigmaY`` (``float``, in meters) rms Y
* ``<distribution>.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``<distribution>.sigmaPx`` (``float``, in momentum) rms Px
* ``<distribution>.sigmaPy`` (``float``, in momentum) rms Py
* ``<distribution>.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``<distribution>.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``<distribution>.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``<distribution>.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt
* ``beam.sigmaX`` (``float``, in meters) rms X
* ``beam.sigmaY`` (``float``, in meters) rms Y
* ``beam.sigmaT`` (``float``, in radian) rms normalized time difference T
* ``beam.sigmaPx`` (``float``, in momentum) rms Px
* ``beam.sigmaPy`` (``float``, in momentum) rms Py
* ``beam.sigmaPt`` (``float``, in energy deviation) rms Pt
* ``beam.muxpx`` (``float``, dimensionless, default: ``0``) correlation X-Px
* ``beam.muypy`` (``float``, dimensionless, default: ``0``) correlation Y-Py
* ``beam.mutpt`` (``float``, dimensionless, default: ``0``) correlation T-Pt

.. _running-cpp-parameters-lattice:

Expand Down
16 changes: 8 additions & 8 deletions docs/source/usage/python.rst
Original file line number Diff line number Diff line change
Expand Up @@ -304,27 +304,27 @@ Particles

.. py:property:: px
momentum in x, normalized to proper velocity
momentum in x, normalized to mass*c :math:`p_x = \gamma \beta_x`

.. py:property:: py
momentum in y, normalized to proper velocity
momentum in y, normalized to mass*c :math:`p_x = \gamma \beta_x`

.. py:property:: pz
momentum in z, normalized to proper velocity
momentum in z, normalized to mass*c :math:`p_x = \gamma \beta_x`

.. py:property:: pt
energy deviation, normalized by rest energy
energy, normalized by rest energy :math:`p_t = -\gamma`

.. py:property:: gamma
Read-only: Get reference particle relativistic gamma.
Read-only: Get reference particle relativistic gamma :math:`\gamma = 1/\sqrt{1-\beta^2}`

.. py:property:: beta
Read-only: Get reference particle relativistic beta.
Read-only: Get reference particle relativistic beta :math:`\beta = v/c`

.. py:property:: beta_gamma
Expand All @@ -342,9 +342,9 @@ Particles
Write-only: Set reference particle rest mass (MeV/c^2).

.. py:method:: set_energy_MeV(energy_MeV)
.. py:method:: set_kin_energy_MeV(kin_energy_MeV)
Write-only: Set reference particle kinetic energy.
Write-only: Set reference particle kinetic energy (MeV)

.. py:method:: load_file(madx_file)
Expand Down

0 comments on commit 10015d0

Please sign in to comment.