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.