fix command

Syntax:

fix ID style args
  • ID = user-assigned name for the fix

  • style = one of a long list of possible style names (see below)

  • args = arguments used by a particular style

Examples:

fix 1 grid/check 100 warn
fix 1 ave/time all 100 5 1000 c_myTemp c_thermo_temp file temp.profile

Description:

Set a fix that will be applied to the system. In SPARTA, a “fix” is an operation that is applied to the system during timestepping. Examples include adding particles via inlet boundary conditions or computing diagnostics. Code for new fixes can be added to SPARTA; see Section 10 of the manual for details.

Fixes perform their operations at different stages of the timestep. If 2 or more fixes operate at the same stage of the timestep, they are invoked in the order they were specified in the input script.

The ID for a fix is used to identify the fix in other commands. Each fix ID must be unique; see an exception below. The ID can only contain alphanumeric characters and underscores. You can specify multiple fixes of the same style so long as they have different IDs. A fix can be deleted with the unfix command, after which its ID can be re-used.

Important

The unfix command is the only way to turn off a fix; simply specifying a new fix with the same style and a different ID will not turn off the first one.

If you specify a new fix with the same ID and style as an existing fix, the old fix is deleted and the new one is created (presumably with new settings). This is the same as if an “unfix” command were first performed on the old fix, except that the new fix is kept in the same order relative to the existing fixes as the old one originally was.

Some fixes store an internal “state” which is written to binary restart files via the restart or write_restart commands. This allows the fix to continue on with its calculations in a restarted simulation. See the read_restart command for info on how to re-specify a fix in an input script that reads a restart file. See the doc pages for individual fixes for info on which ones can be restarted.


Each fix style has its own doc page which describes its arguments and what it does, as listed below. Here is an alphabetic list of fix styles available in SPARTA:

  • adapt - on-the-fly grid adaptation

  • adapt/kk - Kokkos version of fix adapt

  • ambipolar - ambipolar approximation for ionized plasmas

  • ave/grid - compute per grid cell time-averaged quantities

  • ave/grid/kk - Kokkos version of fix ave/grid

  • ave/histo - compute/output time averaged histograms

  • ave/histo/weight - compute/output weighted histograms

  • ave/surf - compute per surface element time-averaged quantities

  • ave/time - compute/output global time-averaged quantities

  • balance - perform dynamic load-balancing

  • balance/kk - Kokkos version of fix balance

  • emit/face - emit particles at global boundaries

  • emit/face/kk - Kokkos version of fix emit/face

  • emit/face/file - emit particles at global boundaries using a distribution defined in a file

  • emit/surf - emit particles at surfaces

  • grid/check - check if particles are in the correct grid cell

  • grid/check/kk - Kokkos version of fix grid/check

  • move/surf - move surfaces dynamically during a simulation

  • move/surf/kk - Kokkos version of fix move/surf

  • print - print text and variables during a simulation

  • vibmode - discrete vibrational energy modes

There are also additional accelerated compute styles included in the SPARTA distribution for faster performance on specific hardware. The list of these with links to the individual styles are given in the pair section of this page.


In addition to the operation they perform, some fixes also produce one of four styles of quantities: global, per-particle, per-grid, or per-surf. These can be used by other commands or output as described below. A global quantity is one or more system-wide values, e.g. the temperature of the system. A per-particle quantity is one or more values per particle, e.g. the kinetic energy of each particle. A per-grid quantity is one or more values per grid cell. A per-surf quantity is one or more values per surface element.

Global, per-particle, per-grid, and per-surf quantities each come in two forms: a single scalar value or a vector of values. Additionaly, global quantities can also be a 2d array of values. The doc page for each fix describes the style and kind of values it produces, e.g. a per-particle vector. Some fixes can produce more than one form of a single style, e.g. a global scalar and a global vector.

When a fix quantity is accessed, as in many of the output commands discussed below, it can be referenced via the following bracket notation, where ID is the ID of the fix:

f_ID

entire scalar, vector, or array

f_ID[I]

one element of vector, one column of array

f_ID[I][J]

one element of array

In other words, using one bracket reduces the dimension of the quantity once (vector -> scalar, array -> vector). Using two brackets reduces the dimension twice (array -> scalar). Thus a command that uses scalar fix values as input can also process elements of a vector or array.

Note that commands and variables which use fix quantities typically do not allow for all kinds, e.g. a command may require a vector of values, not a scalar. This means there is no ambiguity about referring to a fix quantity as f_ID even if it produces, for example, both a scalar and vector. The doc pages for various commands explain the details.


Any values generated by a fix can be used in several ways:


Restrictions:

none

Default:

none