# PARTICLE_SEED

Specifies the initial conditions for a set of particles.

## Type

AcuTrace Command

## Syntax

PARTICLE_SEED ("name") {parameters...}

## Qualifier

User-given name.

## Parameters

- marker (integer) [=0]
- A marker value assigned to all particles in this set.
- seed_ids_type or id_type (enumerated) [=user]
- Type of seed position specification.
- user
- Use the seed ids provided by you if available, otherwise, use global seed ids.
- global
- Use global seed ids.
- local
- Use local seed ids.

- coordinates_type or crd_type (enumerated) [=per_seed]
- Type of seed position specification.
- per_seed or seeds
- Use a list of seed ids and positions (id, x, y, z).
- volume_random or vol_random
- Seeds randomly distributed in an element set.
- volume_uniform or vol_uniform
- Seeds uniformly distributed in an element set.
- surface_random or surf_random
- Seeds randomly distributed on a surface.
- surface_uniform or surf_uniform
- Seeds uniformly distributed on a surface.
- surface_flux_weighted or surf_flux_weighted
- Seeds randomly distributed on a surface in a flux weighted manner.
- region_random or reg_random
- Seeds randomly distributed in a rectangular region.
- region_uniform or reg_uniform
- Seeds uniformly distributed in a rectangular region.

- seed_coordinates or coord (array) [no default]
- List of seed ids and positions. Each row contains an integer seed id followed by the three real values, x,y,z, of the seed position. Used only if coordinates_type is per_seed.
- number_of_seeds or num_seeds (integer) [=1]
- Number of seeds. Ignored if coordinates_type is per_seed.
- region_bounding_box or region (array) [={0,0,0;1,1,1}]
- Lower and upper corners of the region. Used only if coordinates_type is region_random or region_uniform.
- particle_surface or surface (string) [no default]
- Name of the particle surface. Used only if coordinates_type is surface_random, surface_uniform, or surface_flux_weighted.

- particle_surface_offset or surface_offset (real) [=0]
- Offset of seed position from the particle surface as a fraction of the element length. Used only if coordinates_type is surface_random, surface_uniform, or surface_flux_weighted.
- element_set or elem_set (string) [no default]
- Name of the element set. Used only if coordinates_type is volume_random or volume_uniform.
- density_type (enumerated) [=constant]
- Type of seed density specification.
- constant
- All seeds assigned the same density.
- per_seed
- Use a list of densities, one density per seed.
- random
- Seed densities are randomly assigned.

- seed_densities or densities (array) [no default]
- List of seed densities, one per seed. Used only if density_type is per_seed.
- constant_density (real) >0.0 [=1.0]
- Density assigned to all seeds. Used only if density_type is constant.
- density_random_bounds or density_rand_bounds (array) [no default]
- Upper and lower bounds used to assign the random density initial conditions. Used only if density_type is random.
- radius_type (enumerated) [=constant]
- Type of seed radius specification.
- constant
- All seeds assigned the same radius.
- per_seed
- Use a list of radii, one density per seed.
- random
- Seed radii are randomly assigned.

- seed_radii or radii (array) (no default)
- List of seed radii, one per seed. Used only if radius_type is per_seed.
- constant_radius real >0.0 (=1.0)
- Radius assigned to all seeds. Used only if radius_type is constant.
- radius_random_bounds or radius_rand_bounds (array) (no default)
- Upper and lower bounds used to assign the random density initial conditions. Used only if density_type is random.
- velocity_type (enumerated) [=use_flow_velocity]
- Type of seed velocity specification.
- use_flow_velocity or use_flow
- Use the flow velocity at the seed location.
- constant
- All seeds assigned the same velocity.
- zero
- All seeds assigned a zero velocity.
- per_seed
- Use a list of velocities, one velocity per seed.
- random
- Seed velocities are randomly assigned.

- particle_velocity_multiplier (real) >=0.0, <=1.0 [=1.0]
- When velocity_type equals use_flow_velocity, the particle velocity is set to the flow velocity at the seed location multiplied by particle_velocity_multiplier. Used only if velocity_type is use_flow_velocity.
- seed_velocity or seed_vel (array) [no default]
- List of seed velocities, one per seed. Used only if velocity_type is per_seed.
- constant_velocity or vel (array) [={0,0,0}]
- Velocity assigned to all seeds. Used only if velocity_type is constant.
- velocity_random_bounds or vel_rand_bounds (array) [no default]
- Upper and lower bounds used to assign the random velocity initial conditions. Used only if velocity_type is random.
- time_type (enumerated) [=zero]
- Type of seed time specification.
- zero
- All seeds assigned a time of 0.
- constant
- All seeds assigned an identical time.
- per_seed
- Use a list of times, one time per seed.
- emission_times
- Use a list of times. A copy of all the seeds are emitted at each time.

- seed_time or time (real) [=0]
- Time assigned to all seeds. Used only if time_type is constant.
- seed_times or times (array) [no default]
- List of seed times, one per seed. Used only if time_type is per_seed.
- emission_time_type (enumerated) [=series]
- Type of emission seed time specification. The number of particles in the simulation will be
the number of seeds times the number of emission times.
- time_series or series
- Use a list of emission times.
- time_interval or interval
- Specify times by start and stop times and a time interval.

- emission_times (array) [no default]
- List of emission times. Used only if emission_time_type is time_series.
- emission_start_time or etime_start (real) [=0]
- First emission time. Used only if emission_time_type is interval.
- emission_stop_time or etime_stop (real) [=0]
- Last emission time. Used only if emission_time_type is interval.
- emission_time_interval or etime_interval (real) [=0]
- Time interval between successive emission times. Used only if emission_time_type is interval. When emission_time_type is interval, the emission times always include emission_start_time and emission_stop_time regardless of the value of emission_time_interval.
- stretch_type (enumerated) [=constant]
- Type of seed stretch specification.
- constant
- All seeds assigned the same stretch vector.
- random
- Stretch vectors are randomly assigned.
- per_seed
- Use a list of stretch vectors.

- constant_stretch (array) [={1,0,0}]
- Stretch vector assigned to all seeds. Used only if stretch_type is constant.
- seed_stretch (array) [no default}
- List of stretch vectors, one per seed. Used only if stretch_type is per_seed.
- random_stretch_length (real) [=1]
- Value of random stretch length. Used only if stretch_type is random.
- component_type (enumerated) [=none]
- Type of seed component specification.
- none
- No components are assigned.
- constant
- All seeds assigned the same component vector.
- random
- Component vectors are randomly assigned.
- per_seed
- Use a list of stretch vectors.
- distributed
- All components of each seed have value 0 excepting a randomly selected one with a value of 1.

- constant_components (array) [no default]
- If component_type is constant, the component vector assigned to all seeds. If component_type is distributed, the array is used to construct bins, one for each component. Using these bins, seeds are randomly assigned one component with a value of 1.
- seed_components or seed_comp (array) [no default]
- List of components vectors, one per seed. Used only if component_type is per_seed.
- component_random_bounds or comp_rand_bounds (array) [no default]
- Upper and lower bounds used to assign the random component initial conditions. The array should have two rows, one for each bound. The number of columns in each row equal must the number of particle components. Use only if component_type is random.
- turbulence_random_seed_type (enumerated) [=constant]
- Type of turbulence random seed specification.
- constant
- All particle seeds assigned the same random seed.
- per_seed
- Used a list of random seeds.

- constant_turbulence_random_seed or turb_seed (integer) [=1]
- Turbulence random seed assigned to all particle seeds. The random seed actually used for each particle is this value plus the internal seed id. Used only if turbulence_random_seed_type is constant.

- turbulence_random_seeds (array) [no default]
- List of turbulence random seeds, one per seed. The random seed actually used for the particles are these values added to the internal seed ids. Used only if turbulence_random_seed_type is per_seed.

## Description

The PARTICLE_SEED command defines a set of particles and initial conditions for those particles. The initial conditions that can be set by the PARTICLE_SEED command are

- particle ids
- particle set marker
- position (coordinates)
- radius
- density
- velocity
- time
- stretch vector
- turbulence random seed

User equation initial conditions for a set of particles are defined by the USER_EQUATION_INITIAL_CONDITION command.

```
PARTICLE_SEED( "seed_group_1" ) {
coordinates_type = per_seed
seed_coordinates = { 11, -0.05, 0.1, 0.0;
12, -0.05, 0.2, 0.0
}
}
PARTICLE_SEED( "seed_group_2" ) {
coordinates_type = per_seed
seed_coordinates = { 21, -0.05, 0.1, 0.0;
22, -0.05, 0.2, 0.0
}
}
```

Particle coordinates are assigned explicitly only if coordinates_type equals per_seed, in which case the number of seeds in the particle set equals the number of particle id and positions provided by the seed_coordinates parameter. In the example above, there are two particles in each particle set. If the coordinates of a seed fall outside the AcuSolve flow domain, the seed is ignored and does not participate in the particle trace. Particle ids are assigned explicitly only if coordinates_type equals per_seed and seed_ids_type equals user.

- If coordinates_type equals per_seed but seed_ids_type does not equal user, the seed id values in the seed_coordinates parameter are ignored, and the particle ids are automatically assigned based on the value of seed_ids_type.
- If coordinates_type does not equal per_seed and seed_ids_type does equal user, seed_ids_type is reset to global.
- If seed_ids_type equals global, the particles are assigned a unique id between 1 and the total number of seeds in all the particle seed sets.
- If seed_ids_type equals local, the particles are assigned an id between 1 and the number of seeds specified in the current PARTICLE_SEED command.

In the example above, the four seeds are assigned seed ids of 11, 12, 21, and 22. If the parameter seed_ids_type is set to local in both particle seed commands, the four seeds will have ids of 1, 2, 1, and 2. If the parameter seed_ids_type is set to global in both particle seed commands, the four seeds will have ids of 1, 2, 3, and 4. The parameter seed_ids_type does not need to have the same value in all the seed groups. For example, if seed_ids_type is set to user in the first seed group and global in the second, the four seeds will have ids of 11, 12, 3, and 4.

- If fluid_elements is the name of an AcuSolve element set, for example, the
command
`ELEMENT_SET( "fluid_elements" ) { ... }`

```
PARTICLE_SEED( "seeds" ) {
...
coordinates_type = volume_random
element_set = "fluid_elements"
number_of_seeds = 20
...
}
```

- If inflow is the name of an AcuSolve particle
surface, for example, if either the
command
`PARTICLE_SURFACE( "inflow" ) { ... }`

```
SIMPLE_BOUNDARY_CONDITION( "inflow" ) {
...
}
```

```
PARTICLE_SEED( "seeds" ) {
...
coordinates_type = surface_random
particle_surface = "inflow"
number_of_seeds = 20
...
}
```

```
PARTICLE_SEED( "seeds" ) {
...
coordinates_type = surface_flux_weighted
particle_surface = "inflow"
number_of_seeds = 20
...
}
```

- A set of particles with positions randomly distributed in a rectangular region is initialized by
the
command
`PARTICLE_SEED( "seeds" ) { ... coordinates_type = region_random region_bounding_box = {0,1,2;3,4,5} number_of_seeds = 20 ... }`

When coordinates_type equals region_random, particle positions that fall outside the flow domain are discarded. If this happens, the number of particles initialized is less than the value of number_of_seeds.

- Values of coordinates_type equal to volume_uniform, surface_uniform, and region_uniform currently result in the same seeding as volume_random, surface_uniform, and region_random, respectively.

For coordinates_type of surface_uniform, surface_random, and surface_flux_weighted, the parameter particle_surface_offset defines an offset for the initial particle positions from the surface as a fraction of the representative element length. In other words, when particle_surface_offset is 0, the positions are directly on the surface whereas for a non-zero value they are moved into the element adjacent to the surface. This is particularly useful if the surface is a no-slip wall. In this case, if the particle_surface_offset is 0, the particles will never move since the velocity at the wall is 0 for all time. For a non-zero value, the particles do move because they are put into the fluid next to the wall.

Particle masses are not input directly. Instead, particle densities and radii are specified. The particle masses are then initialized to the particle density times the particle volume. The particle radius and density inputs affect the particle trace only if the finite mass particle equation is used. If the massless particle equation is used, the particle densities and radii are still assigned to the particles but have no effect on the particle trace.

- as a constant over the seed set, for
example,
`PARTICLE_SEED( "seeds" ) { ... density_type = constant constant_density = 1.0 ... }`

- per seed, for
example,
`PARTICLE_SEED( "seeds" ) { ... density_type = per_seed seed_densities = { 0.9, 0.7, 1.2, 1.3, 1.05 } ... }`

- randomly, for
example,
`PARTICLE_SEED( "seeds" ) { ... desnity_type = random density_random_bounds = {0.5, 1.5 } ... }`

When density_type equals random, the density of each seed is randomly assigned a value between the values of density_random_bounds, here, between 0.5 and 1.5.

- as constant over the seed set, for
example,
`PARTICLE_SEED( "seeds" ) { ... radius_type = constant constant_radius = 0.0001 ... }`

- per seed, for
example,
`PARTICLE_SEED( "seeds" ) { ... radius_type = per_seed seed_radii = { 1.1e-4, 9.0e-5, 1.2e-4, 0.85e-4, 1.01e-4 } ... }`

- randomly, for
example,
`PARTICLE_SEED( "seeds" ) { ... density_type = random desity_random_bounds = { 9.0e-5, 1.1e-4 } ... }`

When radius_type equals random, the radius of each seed is randomly assigned a value between the values of radius_random_bounds, here, between 9.0e-5 and 1.1e-4.

Particle velocity initialization is relevant only when the finite mass particle equation is used. If the massless particle equation is used, particle velocity inputs are ignored because the particle velocity always equals the flow velocity.

- to zero for all seeds in the seed set, for
example,
`PARTICLE_SEED( "seeds" ) { ... velocity_type = zero ... }`

- to the flow velocity at the seed location, for
example,
`PARTICLE_SEED( "seeds" ) { ... velocity_type = use_flow_velocity particle_velocity_multiplier = 1.0 ... }`

- to a constant times the flow velocity, for
example,
`PARTICLE_SEED( "seeds" ) { ... velocity_type = use_flow_velocity particle_velocity_multiplier = 0.9 ... }`

- as a constant over the seed set, for
example,
`PARTICLE_SEED( "seeds" ) { ... velocity_type = constant constant_velocity = { 0.7, 0.9, 1.1 } ... }`

- per seed, for
example,
`PARTICLE_SEED( "seeds" ) { ... velocity_type = per_seed seed_velocity = { 1.0, 1.1, 0.8 ; 0.85, 0.95, 1.3 ; 1.35, 1.1, 0.65 ; 0.7, 0.8, 1.4 } ... }`

- randomly, for
example,
`PARTICLE_SEED( "seeds" ) { ... velocity_type = random velocity_random_bounds = { 0.65, 0.75, 0.6 ; 1.4, 1.2, 1.5 } ... }`

When velocity_type equals random, each component of the velocity of a seed is randomly assigned a value between the values of velocity_random_bounds. In the example above, the x-component is randomly assigned a value between 0.65 and 1.4, the y-component between .75 and 1.2, and the z-component between .6 and 1.5.

- An initial time of 0 is assigned to all the particles in a particle set if time_type is zero.
- To assign the same non-zero constant time to all the particles, use, for
example,
`PARTICLE_SEED( "seeds" ) { ... time_type = constant time = 20.0 ... }`

- To assign a unique time for each particle, use, for
example:
`PARTICLE_SEED( "seeds" ) { ... time_type = per_seed times = Read( "seed_times" ) ... }`

The number of values specified by the times must equal the number of seeds in the set.

- To assign a series of emission times to all the particles in the current set, use, for
example,
`PARTICLE_SEED( "seeds" ) { ... time_type = emission_times emission_time_type = time_series emission_times = { 0.0 ; 1.0; 2.0; 3.0 } ... }`

```
PARTICLE_SEED( "seeds" ) {
coordinates_type = per_seed
seed_coordinates = {
1, -0.05, 0.1, 0.0;
2, -0.05, 0.2, 0.0
}
...
time_type = emission_times
emission_time_type = time_interval
emission_start_time = 0.0
emission_stop_time = 3.0
emission_time_interval = 1.0
...
}
```

there are eight particles in all. There are four particles at (-0.05, 0.1, 0.0) with initial times of 0.0, 1.0, 2.0, and 3.0, and four particles at (-0.05, 0.2, 0.0) with the same four initial times.

- a constant over the seed set, for
example,
`PARTICLE_SEED( "seeds" ) { ... stretch_type = constant constant_stretch = { 1.0, 0.0, 1.0 } ... }`

- per seed, for
example,
`PARTICLE_SEED( "seeds" ) { ... stretch_type = per_seed seed_stretch = { 1, 0, 0; 0, 1, 0; 1, 1, 1; 0, 0, 1 } ... }`

- randomly, for
example,
`PARTICLE_SEED( "seeds" ) { ... stretch_type = random random_stretch_length = 1.0 ... }`

When stretch_type equals per_seed, the number of stretch vectors (four in the example shown) must equal the number of seeds in the seed set. When stretch_type equals random, each component of each stretch vector is randomly assigned a value between 0 and the value of random_stretch_length.

The initial values of the particle component vectors can be assigned in one of four ways. In the following example, it is assumed that number_particle_components is set to five in the EQUATION command.

- a constant over the seed set, for
example,
`PARTICLE_SEED( "seeds" ) { ... component_type = constant constant_components = { 0.0, 0.0, 1.0, 1.0, 0.0 } ... }`

- per seed, for
example,
`PARTICLE_SEED( "seeds" ) { ... component_type = per_seed seed_components = { 1, 0, 0, 0, 0; 0, 1, 0, 0, 0; 0, 0, 1, 0, 0 } ... }`

- randomly, for
example,
`PARTICLE_SEED( "seeds" ) { ... component_type = random component_random_bounds = {0.0, 2.0, 4.0, 3.0, 4.0 ; 1.0, 3.0, 5.0, 4.0, 5.0 } ... }`

- randomly distributed over the seeds, for
example,
`PARTICLE_SEED( "seeds" ) { ... component_type = distributed constant_components = { 1.0, 2.0, 1.0, 0.5, 1.5 } ... }`

When component_type equals constant, all seeds in the seed set are assigned the same component vector, (0.0, 0.0, 1.0, 1.0, 0.0) in the example shown. When component_type equals per_seed, the number of initial component vectors, three in the example shown, must equal the number of seeds in the seed set. When component_type equals random, each component of each seed is randomly assigned a value between the corresponding values of component_random_bounds. Here, the first components all lie between 0.0 and 1.0, the second between 2.0 and 3.0, and so on.

When component_type equals distributed, the values of constant_components represent bin widths. For the example shown, five bins are constructed: 0.0 to 1.0; 1.0 to 3.0; 3.0 to 4.0; 4.0 to 4.5; 4.5 to 6. For each seed, a random number is drawn between the lower bound of the lowest bin and the upper bound of the highest bin. That number is then used to determine a bin number. The component for that bin is set to 1; the components for the other bins are set to 0. For the example show, random numbers are drawn between zero and six. If the random draw for the first seed is 4.1, the first seed is assigned a component vector of (0.0, 0.0, 0.0, 1.0, 0.0) because 4.1 falls in the fourth bin, that is, it is between 4.0 and 4.5. If the draw for the second seed is 2.7, the second seed is assigned a component vector of (0.0, 1.0, 0.0, 0.0, 0.0) because 2.7 falls in the second bin, that is, it is between 1.0 and 3.0. This process is repeated for all the seeds in the seed group.

- a constant over the seed set, for
example,
`PARTICLE_SEED( "seeds" ) { ... turbulence_random_seed_type = constant turbulence_random_seed = 1.0 ... }`

- per seed, for
example,
`PARTICLE_SEED( "seeds" ) { ... turbulence_random_seed_type = per_seed turbulence_random_seeds = { 1; 3; 99; -3; 17 } ... }`

When turbulence_random_seed_type equals per_seed, the number of turbulent seeds, five in the example shown, must equal the number of seeds in the seed set.