Lattice3D
- class Lattice3D.Lattice3D(x_min: float, x_max: float, y_min: float, y_max: float, z_min: float, z_max: float, num_points_x: int, num_points_y: int, num_points_z: int, n_sigma_x: float | None = None, n_sigma_y: float | None = None, n_sigma_z: float | None = None)[source]
Represents a 3D lattice with evenly spaced points.
- Parameters:
- x_minfloat
The minimum value along the x-axis.
- x_maxfloat
The maximum value along the x-axis.
- y_minfloat
The minimum value along the y-axis.
- y_maxfloat
The maximum value along the y-axis.
- z_minfloat
The minimum value along the z-axis.
- z_maxfloat
The maximum value along the z-axis.
- num_points_xint
The number of points along the x-axis.
- num_points_yint
The number of points along the y-axis.
- num_points_zint
The number of points along the z-axis.
- n_sigma_xfloat
Number of sigmas to consider in smearing in x direction. Default is 3.
- n_sigma_yfloat
Number of sigmas to consider in smearing in y direction. Default is 3.
- n_sigma_zfloat
Number of sigmas to consider in smearing in z direction. Default is 3.
- Attributes:
- x_min_float
The minimum value along the x-axis.
- x_max_float
The maximum value along the x-axis.
- y_min_float
The minimum value along the y-axis.
- y_max_float
The maximum value along the y-axis.
- z_min_float
The minimum value along the z-axis.
- z_max_float
The maximum value along the z-axis.
- num_points_x_int
The number of points along the x-axis.
- num_points_y_int
The number of points along the y-axis.
- num_points_z_int
The number of points along the z-axis.
- spacing_x_float
The spacing between points along the x-axis.
- spacing_y_float
The spacing between points along the y-axis.
- spacing_z_float
The spacing between points along the z-axis.
- density_x_float
The density of points along the x-axis.
- density_y_float
The density of points along the y-axis.
- density_z_float
The density of points along the z-axis.
- cell_volume_float
The volume of each cell in the lattice.
- x_values_numpy.ndarray
The array of x-axis values.
- y_values_numpy.ndarray
The array of y-axis values.
- z_values_numpy.ndarray
The array of z-axis values.
- grid_numpy.ndarray
The 3D grid containing the values at each lattice point.
Methods
set_value_by_index:
Set the value at the specified indices in the grid.
get_value_by_index:
Get the value at the specified indices in the grid.
set_value:
Set the value at the specified coordinates in the lattice.
set_value_nearest_neighbor:
Set the value at the nearest neighbor of the specified coordinates within the lattice.
get_value:
Get the value at the specified coordinates in the lattice.
get_value_nearest_neighbor:
Get the value of the nearest neighbor at the specified coordinates within the lattice.
get_coordinates:
Get the coordinates corresponding to the given indices.
find_closest_indices:
Find the closest indices in the lattice for the given coordinates.
interpolate_value:
Interpolate the value at the specified position using trilinear interpolation.
average:
Compute the element-wise average of multiple Lattice3D objects.
rescale:
Rescale the values of the lattice by a specified factor.
save_to_csv:
Save the lattice data, including metadata, to a CSV file.
load_from_csv:
Load lattice data, including metadata, from a CSV file.
visualize:
Visualize the lattice data in a 3D plot.
extract_slice:
Extract a 2D slice from the lattice along the specified axis at the given index.
save_slice_to_csv:
Save a 2D slice from the lattice along the specified axis and index to a CSV file.
interpolate_to_lattice:
Interpolate the current lattice data to a new lattice with the specified number of points along each axis.
interpolate_to_lattice_new_extent:
Interpolate the current lattice data to a new lattice with the specified number of points and extent.
reset:
Reset the values of all grid points in the lattice to zero.
add_same_spaced_grid:
Add the values from another grid with the same spacing.
add_particle_data:
Add particle data to the lattice.
- Lattice3D.set_value_by_index(i: int, j: int, k: int, value: int | float) None [source]
Set the value at the specified indices (i, j, k) in the grid.
- Parameters:
- iint
The index along the x-axis.
- jint
The index along the y-axis.
- kint
The index along the z-axis.
- valueint or float
The value to set at the specified indices.
- Returns:
- None
- Lattice3D.get_value_by_index(i: int, j: int, k: int) int | float | None [source]
Get the value at the specified indices (i, j, k) in the grid.
- Parameters:
- iint
The index along the x-axis.
- jint
The index along the y-axis.
- kint
The index along the z-axis.
- Returns:
- int or float or None
The value at the specified indices if the indices are valid, otherwise None.
- Lattice3D.set_value(x: int | float, y: int | float, z: int | float, value: int | float) None [source]
Set the value at the specified coordinates within the lattice.
- Parameters:
- xint or float
The x-coordinate where the value is to be set.
- yint or float
The y-coordinate where the value is to be set.
- zint or float
The z-coordinate where the value is to be set.
- valueint or float
The value to be set.
- Raises:
- ValueError
If any of the coordinates are outside their specified ranges.
- Lattice3D.set_value_nearest_neighbor(x: int | float, y: int | float, z: int | float, value: int | float) None [source]
Set the value at the nearest neighbor of the specified coordinates within the lattice.
- Parameters:
- xint or float
The x-coordinate where the value is to be set.
- yint or float
The y-coordinate where the value is to be set.
- zint or float
The z-coordinate where the value is to be set.
- valueint or float
The value to be set.
- Raises:
- ValueError
If any of the coordinates are outside their specified ranges.
- Lattice3D.get_value(x: int | float, y: int | float, z: int | float) int | float | None [source]
Get the value at the specified coordinates within the lattice.
- Parameters:
- xint or float
The x-coordinate where the value is to be retrieved.
- yint or float
The y-coordinate where the value is to be retrieved.
- zint or float
The z-coordinate where the value is to be retrieved.
- Returns:
- int or float or None
The value at the specified coordinates.
- Raises:
- ValueError
If any of the coordinates are outside their specified ranges.
- Lattice3D.get_value_nearest_neighbor(x: int | float, y: int | float, z: int | float) int | float | None [source]
Get the value of the nearest neighbor at the specified coordinates within the lattice.
- Parameters:
- xint or float
The x-coordinate where the value is to be retrieved.
- yint or float
The y-coordinate where the value is to be retrieved.
- zint or float
The z-coordinate where the value is to be retrieved.
- Returns:
- int or float or None
The value at the specified coordinates.
- Raises:
- ValueError
If any of the coordinates are outside their specified ranges.
- Lattice3D.get_coordinates(i: int, j: int, k: int) Tuple[float, float, float] [source]
Retrieve the coordinates associated with the given indices.
- Parameters:
- iint
The index along the x-axis.
- jint
The index along the y-axis.
- kint
The index along the z-axis.
- Returns:
- tuple
A tuple containing the x, y, and z coordinates corresponding to the given indices.
- Raises:
- ValueError
If any of the indices are outside the specified range.
- Lattice3D.find_closest_indices(x: float, y: float, z: float) Tuple[int, int, int] [source]
Find the closest indices in the lattice corresponding to the given coordinates.
- Parameters:
- xfloat
The x-coordinate.
- yfloat
The y-coordinate.
- zfloat
The z-coordinate.
- Returns:
- tuple
A tuple of three integers representing the closest indices in the lattice for the given coordinates (x, y, z).
- Lattice3D.interpolate_value(x: float, y: float, z: float, method: str = 'nearest') float [source]
Interpolate the value at the specified position using (up to) trilinear interpolation.
- Parameters:
- xfloat
The x-coordinate.
- yfloat
The y-coordinate.
- zfloat
The z-coordinate.
- methodstr
Scipy option for interpolation method. Default is ‘nearest’.
- Returns:
- float or None
The interpolated value at the specified position. If the provided position is outside the lattice range, None is returned.
- Lattice3D.average(*lattices: Lattice3D) Lattice3D [source]
Compute the average of multiple Lattice3D objects element-wise.
- Parameters:
- *latticesLattice3D
Multiple Lattice3D objects to compute the average.
- Returns:
- Lattice3D
A new Lattice3D object containing the element-wise average.
- Raises:
- TypeError
If any of the operands are not of type ‘Lattice3D’.
- ValueError
If the lattices do not have the same shape.
Examples
If you want to average over 3 lattices, you can do the following:
1>>> lattice1 = Lattice3D(x_min=0, x_max=1, y_min=0, y_max=1, z_min=0, 2>>> z_max=1, num_points_x=10, num_points_y=10, num_points_z=10) 3>>> 4>>> lattice2 = Lattice3D(x_min=0, x_max=1, y_min=0, y_max=1, z_min=0, 5>>> z_max=1, num_points_x=10, num_points_y=10, num_points_z=10) 6>>> 7>>> lattice3 = Lattice3D(x_min=0, x_max=1, y_min=0, y_max=1, z_min=0, 8>>> z_max=1, num_points_x=10, num_points_y=10, num_points_z=10) 9>>> 10>>> lattice1=lattice1.average(lattice2, lattice3)
- Lattice3D.rescale(factor: float) None [source]
Rescale the values of the lattice by a specified factor.
- Parameters:
- factornumeric
The rescaling factor.
- Returns:
- None
- Lattice3D.save_to_csv(filename: str) None [source]
Save the lattice data, including metadata, to a CSV file.
- Parameters:
- filenamestr
The filename of the CSV file to save.
- Returns:
- None
- classmethod Lattice3D.load_from_csv(filename: str) Lattice3D [source]
Load lattice data, including metadata, from a CSV file.
- Parameters:
- filenamestr
The filename of the CSV file to load.
- Returns:
- latticeLattice3D
The loaded Lattice3D object containing the data and metadata.
- Lattice3D.visualize() None [source]
Visualize the lattice data in a 3D plot.
The lattice values are represented as a scatter plot in a 3D space.
- Lattice3D.extract_slice(axis: str, index: int) Tuple[ndarray, Tuple[ndarray, ndarray], str] [source]
Extract a 2D slice from the lattice along the specified axis at the given index.
- Parameters:
- axisstr
The axis along which to extract the slice. Must be ‘x’, ‘y’, or ‘z’.
- indexint
The index of the slice along the specified axis.
- Returns:
- A tuple containing the following:
- slice_datandarray
The 2D slice data extracted from the lattice.
- slice_valuestuple of 2 ndarrays
A tuple of coordinate lists containing the 2D coordinates of the slice.
- slice_labelstr
The label describing the slice plane.
- Raises:
- ValueError
If the axis parameter is invalid or the index is out of range.
- Lattice3D.save_slice_to_csv(axis: str, index: int, filename: str) None [source]
Save a 2D slice from the lattice along the specified axis and index to a CSV file.
- Parameters:
- axisstr
The axis along which to extract the slice. Must be ‘x’, ‘y’, or ‘z’.
- indexint
The index of the slice along the specified axis.
- filenamestr
The name of the CSV file to save the slice data.
- Raises:
- ValueError
If the axis parameter is invalid or the index is out of range.
- Lattice3D.interpolate_to_lattice(num_points_x: int, num_points_y: int, num_points_z: int) Lattice3D [source]
Interpolate the current lattice data to a new lattice with the specified number of points along each axis.
- Parameters:
- num_points_xint
The number of points along the X-axis of the new lattice.
- num_points_yint
The number of points along the Y-axis of the new lattice.
- num_points_zint
The number of points along the Z-axis of the new lattice.
- Returns:
- Lattice3D
A new Lattice3D object containing the interpolated data.
Notes
This method performs spline interpolation to generate the values for each grid point of the new lattice. The interpolation is based on the current lattice data and the desired number of points along each axis.
- Lattice3D.interpolate_to_lattice_new_extent(num_points_x: int, num_points_y: int, num_points_z: int, x_min: float, x_max: float, y_min: float, y_max: float, z_min: float, z_max: float) Lattice3D [source]
Interpolate the current lattice data to a new lattice with the specified number of points and extent.
- Parameters:
- num_points_xint
The number of points along the X-axis of the new lattice.
- num_points_yint
The number of points along the Y-axis of the new lattice.
- num_points_zint
The number of points along the Z-axis of the new lattice.
- x_minfloat
The minimum value of the X-axis for the new lattice extent.
- x_maxfloat
The maximum value of the X-axis for the new lattice extent.
- y_minfloat
The minimum value of the Y-axis for the new lattice extent.
- y_maxfloat
The maximum value of the Y-axis for the new lattice extent.
- z_minfloat
The minimum value of the Z-axis for the new lattice extent.
- z_maxfloat
The maximum value of the Z-axis for the new lattice extent.
- Returns:
- Lattice3D
A new Lattice3D object containing the interpolated data.
Notes
This method performs spline interpolation to generate the values for each grid point of the new lattice. The interpolation is based on the current lattice data and the desired number of points and extent along each axis.
- Lattice3D.reset() None [source]
Reset the values of all grid points in the lattice to zero.
Notes
This method iterates over all grid points in the lattice and sets their values to zero.
- Lattice3D.add_same_spaced_grid(other: Lattice3D, center_x: float, center_y: float, center_z: float) None [source]
Add the values of grid points of another lattice with same spacing.
- Parameters:
- otherLattice3D
The other Lattice3D object to add, which is expected to have the same spacing.
- center_xfloat
x-position in this grid at which the center of the other grid should be placed.
- center_yfloat
y-position in this grid at which the center of the other grid should be placed.
- center_zfloat
z-position in this grid at which the center of the other grid should be placed.
- Raises:
- TypeError
If the operand other is not of type Lattice3D.
- ValueError
If other is of wrong spacing.
- Lattice3D.add_particle_data(particle_data: List[Particle], sigma: float, quantity: str, kernel: str = 'gaussian', add: bool = False) None [source]
Add particle data to the lattice.
- Parameters:
- particle_datalist
A list of Particle objects containing the particle data.
- sigmafloat
The standard deviation of the Gaussian kernel used for smearing the particle data.
- quantitystr
The quantity of the particle data to be added. Supported values are ‘energy_density’, ‘number_density’, ‘charge_density’, ‘baryon_density’, and ‘strangeness_density’.
- kernelstr
The type of kernel to use for smearing the particle data. Supported values are ‘gaussian’ and ‘covariant’. The default is ‘gaussian’.
- addbool, optional
Specifies whether to add the particle data to the existing lattice values or replace them. If True, the particle data will be added to the existing lattice values. If False (default), the lattice values will be reset before adding the particle data.
- Raises:
- ValueError
If an unknown quantity is specified or if the particle data contains NaN values.
Notes
This method calculates the smearing of the particle data using a Gaussian kernel centered at each particle’s coordinates. The smeared values are added to the corresponding grid points in the lattice.
The Gaussian kernel is defined by the provided standard deviation sigma. The larger the sigma value, the smoother the smearing effect.
The supported quantities for particle data are as follows:
‘energy_density’: Uses the particle’s energy (E) as the value to be added to the lattice.
‘number_density’: Adds a value of 1.0 to the grid for each particle.
‘charge_density’: Uses the particle’s charge as the value to be added to the lattice.
‘baryon_density’: Uses the particle’s baryon number as the value to be added to the lattice.
‘strangeness_density’: Uses the particle’s strangeness as the value to be added to the lattice.