User documentation

class hemtracer.EulerianFlowField(vtk_filename)

A class that represents a steady flow field in Eulerian coordinates with various field data. Unsteady flow fields are currently only supported in the form of MRF data. The mesh has to be unstructured and non-moving and the flow field has to be defined as node-centered velocity field (point data in VTK). The flow field is represented by a VTK file. It has to contain a velocity field. Additional field data, e.g., an Eulerian hemolysis solution, can be imported from other VTK files using the import_field_data method. The class provides functionality to interpolate field data to pathlines.

Initialize the EulerianField object with a VTK flow field name.

Parameters:

vtk_filename (str) – Name of the VTK file containing the flow field.

compute_distance_rotation(omega, x0=array([0., 0., 0.]))

Compute orthogonal distance from rotation axis. This is used for the transformation of the velocity field in a rotating frame of reference and for the tank-treading morphology model with rotation correction.

Parameters:
  • omega (Vector3) – The angular velocity vector of the rotating frame of reference.

  • x0 (Vector3) – Some point on the rotation axis. Defaults to (0,0,0).

Return type:

None

compute_gradients(node_centered=False)

Compute the velocity gradient tensor (if it has not been computed before). The velocity gradient tensor can be computed as cell-centered field or node-centered field. The node-centered field is more expensive to compute, but it can be interpolated to pathlines automatically. The cell-centered field is cheaper to compute, but it has to be interpolated manually to pathlines.

Parameters:

node_centered (bool) – If True, compute the gradient as node-centered field, else compute as cell-centered. Defaults to False.

Return type:

None

get_name_advection_velocity()

Get the name of the velocity field relevant for advection. In case of a rotating frame of reference, this is the MRF velocity field. Otherwise, this is the velocity field.

Returns:

The velocity field name.

Return type:

str

get_name_distance_center()

Get the name of the orthogonal distance from the rotation axis. If no rotating frame of reference has been defined, this is None.

Returns:

The orthogonal distance from the rotation axis.

Return type:

str

get_name_omega_frame()

Get the name of the angular velocity of the rotating frame of reference. If no rotating frame of reference has been defined, this is None.

Returns:

The angular velocity of the rotating frame of reference.

Return type:

str

get_name_velocity_gradient()

Get the name of the velocity gradient field. If no velocity gradient has been computed, this is None.

Returns:

The velocity gradient field name.

Return type:

str

get_vtk_flow_field()

Get the VTK flow field.

Returns:

The VTK flow field.

Return type:

vtkUnstructuredGrid

import_field_data(vtk_file_name, field_names_point=None, field_names_cell=None)

Import additional field data from a VTK file (to be interpolated to the streamlines). The field data has to be defined on the same mesh as the flow field.

Parameters:
  • vtk_file_name (str) – The name of the VTK file containing the additional field data.

  • field_names_point (List[str]) – A list of strings containing the names of the node-centered fields to import. If None, all fields are imported. If you do not want to import any node-centered fields, set field_names_point=[].

  • field_names_cell (List[str]) – A list of strings containing the names of the cell-centered fields to import. If None, all fields are imported. If you do not want to import any cell-centered fields, set field_names_cell=[].

Return type:

None

probe_field(x, field_names)

Extracts field information at specified points x, e.g., a pathline.

Parameters:
  • x (List[Vector3]) – Positions in field at which to extract information.

  • field_names (List[str]) – List of names of field in data to extract.

Returns:

A dictionary where keys are field names and values are the corresponding field information.

Return type:

Dict[str, NDArray]

reduce_to_relevant_fields(relevant_field_names)

Specify the names of the relevant fields in the VTK file. In particular, this could be velocity and all fields you want interpolated to the pathlines, e.g., some Eulerian solution for effective shear rate or local fluid shear. All other fields are removed. This can reduce memory requirements and speed up subsequent computations.

Parameters:

relevant_field_names (List[str]) – A list of strings containing the names of the relevant fields.

Return type:

None

set_velocity_gradient_name(velocity_gradient_name)

Specify the name of the velocity gradient field in the VTK file, if available. The velocity gradient field can be defined as node-centered field (point data in VTK) or cell-centered field (cell data in VTK).

Parameters:

velocity_gradient_name (str) – The name of the velocity gradient field in the VTK file.

Return type:

None

set_velocity_name(vtk_velocity_name)

Specify the name of the velocity field in the VTK file (velocity transformed to absolute frame for MRF fields). The velocity field has to be defined as node-centered field (point data in VTK)

Parameters:

vtk_velocity_name (str) – The name of the velocity field in the VTK file.

Return type:

None

smooth_node_data(attribute_name)

Smooth certain node-centered data in the VTK file.

Parameters:

attribute_name (str) – The name of the node-centered attribute to smooth.

Return type:

None

transform_mrf_data(rf_name, rf_rot, omega, x0=array([0., 0., 0.]))

Transform the velocity field of a rotating frame of reference.

Parameters:
  • rf_name (str) – The name of the cell-centered (!) attribute in the vtk file that specifies the reference frame ID.

  • rf_rot (int) – The reference frame ID of the rotating frame of reference.

  • omega (Vector3) – The angular velocity vector of the rotating frame of reference.

  • x0 (Vector3) – Some point on the rotation axis. Defaults to (0,0,0).

Return type:

None

class hemtracer.HemolysisSolver(pathlines)

Class for computing hemolysis along pathlines. Takes an existing pathline collection and handles the various pathlines contained within, interfacing to the hemolysis models.

Associate pathlines with hemolysis solver and get names of relevant quantities.

Parameters:

pathlines (PathlineCollection) – Pathlines to analyze.

average_hemolysis(model, end_criterion_attribute=None, end_criterion_value=0.0)

Average hemolysis index over the end points of all pathlines.

Parameters:
  • model (PowerLawModel) – Power law model to use.

  • end_criterion_name – Criterion for selecting end points. Can be a string representing an attribute name. If given, uses the first time point where the attribute is greater than end_criterion_value as end point. Discards all pathlines where the criterion is not met. Defaults to None.

  • end_criterion_value (float) – Value to use as end criterion. Defaults to 0.0.

  • end_criterion_attribute (str | None) –

Returns:

Average hemolysis index.

Return type:

float

compute_hemolysis(powerlaw_model, visc=0.0035)

Computes index of hemolysis along pathlines in percent.

Parameters:
  • powerlaw_model (PowerLawModel) – Power law model to use for computing index of hemolysis.

  • visc (float | str) – Blood viscosity. Defaults to 0.0035 Pa s. If a string is given, it is assumed to be the name of an attribute containing the (local) dynamic viscosity.

Return type:

None

compute_representativeShear(model, store_solution=False)

Obtain representative scalar shear rate (effective shear) from stress-based or strain-based cell model.

Parameters:
  • model (RBCModel) – Cell model to use.

  • store_solution (bool) – Store solution in pathlines. Defaults to False.

Return type:

None

get_output(model)

Obtain hemolysis solutions along pathlines after they have been computed. Returns a list of dictionaries, each one representing a pathline and containing the keys ‘t’ and ‘y’ for time and output variable.

Parameters:

model (str) – Model to consider.

Returns:

List of dictionaries, each one representing a pathline and containing the keys ‘t’ and ‘y’ for time and output variable.

Return type:

List[Dict[str, NDArray]]

class hemtracer.Pathline(t, x, reason_for_termination='misc')

Class representing a single pathline as a collection of PathlineAttribute objects. Every pathline has an attribute ‘Position’, which is stored by default as definition of the pathline. Additional attributes can be added using the add_attribute function.

Constructing an object creates its ‘Position’ attribute and stores it in attributes list.

Parameters:
  • t (List[float]) – The integration times along the pathline.

  • x (List[Vector3]) – The positions along the pathline.

  • reason_for_termination (str) – The reason for termination of the pathline integration, defaults to ‘misc’.

add_attribute(t, val, name, interpolation_scheme='linear')

Adds an attribute to the pathline.

Parameters:
  • t (ArrayLike) – The integration times along the pathline. If not in the range [t0, tend], the integration times are clipped.

  • val (ArrayLike) – The values of the attribute along the pathline (first axis must correspond to integration times). If the attribute is vector-valued, the second axis must correspond to the components of the vector.

  • name (str) – The name of the attribute.

  • interpolation_scheme (str) – The interpolation scheme to use along the pathline. Defaults to ‘linear’.

Return type:

None

get_attribute(name)

Returns the attribute with the specified name. Returns None if no attribute with the specified name exists.

Parameters:

name (str) – The name of the attribute.

Returns:

The attribute with the specified name or None.

Return type:

PathlineAttribute

get_attribute_interpolator(attribute_name)

Returns interpolator for attribute on pathline, or None if it does not exist.

Parameters:

attribute_name (str|None) – string indicating name of attribute

Returns:

interpolator for attribute on pathline, or None if it does not exist

Return type:

interp1d|None

get_attribute_names()

Returns a list of all attributes stored in pathline.

Returns:

A list of attribute names.

Return type:

List[str]

get_position_attribute()

Returns the ‘Position’ attribute of the pathline. Has to exist by definition.

Raises:

AttributeError – If no position attribute exists on pathline.

Returns:

The ‘Position’ attribute.

Return type:

PathlineAttribute

get_reason_for_termination()

Returns the reason for termination of the pathline integration.

Returns:

The reason for termination.

Return type:

str

get_t0()

Returns the initial integration time of the pathline.

Returns:

The initial integration time.

Return type:

float

get_tend()

Returns the final integration time of the pathline.

Returns:

The final integration time.

Return type:

float

unify_attributes(attribute_names, ref_attribute_name='Position')

Interpolates all attributes to the same time points of some reference attribute (if not specified, use the ‘Position’ attribute) and return them as an array. The first column of each array contains the time points used.

Parameters:
  • attribute_names (List[str] | None) – A list of attribute names to unify. If None, all attributes are unified.

  • ref_attribute_name (str) – The name of the attribute to use as reference, defaults to ‘Position’.

Returns:

A tuple containing the array of interpolated values and a list of attribute names. The first column of the array contains the time points used.

Return type:

Tuple[NDArray, List[str]]

class hemtracer.PathlineAttribute(t, val, name, interpolation_scheme='linear')

Class for storing a quantity of interest along a pathline. The data is stored as a function of the integration time. All class attributes are meant to be publicly accessible.

Parameters:
  • t (ArrayLike) – The integration times along the pathline.

  • val (ArrayLike) – The values of the attribute along the pathline.

  • name (str) – The name of the attribute.

  • interpolation_scheme (str) – The scheme to use for interpolation, defaults to ‘linear’. Refer to scipy.interpolate.interp1d for other options.

get_number_of_components()

Returns the number of components of the attribute.

Returns:

The number of components.

Return type:

int

interpolator

A function that interpolates the values along the pathline.

name

The name of the quantity of interest.

t

The integration times along the pathline at which the values are stored.

val

The values of the quantity of interest along the pathline.

class hemtracer.PathlineCollection

Class for storing a collection of pathlines.

get_attribute(attribute_name)

Returns a list of dictionaries, each one representing a pathline and containing the keys ‘t’ and ‘y’ for time and attribute, respectively.

Parameters:

attribute_name (str) – The name of the attribute to return.

Returns:

A list of dictionaries.

Return type:

List[Dict[str, NDArray]]

get_name_distance_center()

Returns the name of the attribute that describes the orthogonal distance to the center of rotation. None if not available.

Returns:

The name of the attribute.

Return type:

str | None

get_name_omega_frame()

Returns the name of the attribute that describes the angular velocity vector of the frame of reference. None if not available.

Returns:

The name of the attribute.

Return type:

str | None

get_name_velocity()

Returns the name of the velocity field used for pathline integration.

Returns:

The name of the velocity field.

Return type:

str

get_name_velocity_gradient()

Returns the name of the attribute that contains the velocity gradient. None if not available.

Returns:

The name of the attribute.

Return type:

str | None

get_pathlines()

Returns the current list of pathlines.

Returns:

A list of pathlines.

Return type:

List[Pathline]

to_file(filename, attribute_names=None)

Write pathlines to file. If attribute names are specified, only those attributes are written to file. Otherwise, all attributes are written to file.

Interpolates all attributes to the same time points (those of the ‘Position’ attribute) before writing to file.

Supports writing to CSV, npz, and VTK files. In case of CSV and VTK, it is assumed that all pathlines contain the same attributes, as this is required by the file format (every point must have the same number of attributes). If you want to write pathlines with different attributes to file, there are two options: (1) Write to npz file, which does not require all pathlines to have the same attributes. (2) Instantiate multiple PathlineTracker objects, each with a different set of attributes, and write each one to a separate file. In case of npz, the attribute names and values on each pathline are stored as separate arrays in the file, pattern: arr_0 = attribute_values_pl1, arr_1 = attribute_names_pl1, arr_2 = attribute_values_pl2, arr_3 = attribute_names_pl2, ….

Parameters:
  • filename (str) – The name of the file to write to, including path and extension. Supported extensions are .csv, .npz, and .vtk.

  • attribute_names (List[str], optional) – A list of attribute names to write to file. If None, all attributes are written to file (default).

Return type:

None

class hemtracer.PathlineReader(filename, id_name, t_name, posX_name, posY_name, posZ_name, velX_name=None, velY_name=None, velZ_name=None, dvX_dx_name=None, dvX_dy_name=None, dvX_dz_name=None, dvY_dx_name=None, dvY_dy_name=None, dvY_dz_name=None, dvZ_dx_name=None, dvZ_dy_name=None, dvZ_dz_name=None, omegaX_name=None, omegaY_name=None, omegaZ_name=None, distance_center_name=None, idx=None, gradient_interp='previous')

Class for reading pathlines from file. Currently only supports reading from csv files.

Parameters:
  • filename (str) – The name of the file to read from.

  • id_name (str) – The name of the attribute containing the pathline IDs.

  • t_name (str) – The name of the attribute containing the integration times.

  • posX_name (str) – The name of the attribute containing the x-coordinates of the pathlines.

  • posY_name (str) – The name of the attribute containing the y-coordinates of the pathlines.

  • posZ_name (str) – The name of the attribute containing the z-coordinates of the pathlines.

  • velX_name (str | None) – The name of the attribute containing the x-component of the velocity field. Defaults to None.

  • velY_name (str | None) – The name of the attribute containing the y-component of the velocity field. Defaults to None.

  • velZ_name (str | None) – The name of the attribute containing the z-component of the velocity field. Defaults to None.

  • dvX_dx_name (str | None) – The name of the attribute containing the derivative of v_x w.r.t. x. Defaults to None.

  • dvX_dy_name (str | None) – The name of the attribute containing the derivative of v_x w.r.t. y. Defaults to None.

  • dvX_dz_name (str | None) – The name of the attribute containing the derivative of v_x w.r.t. z. Defaults to None.

  • dvY_dx_name (str | None) – The name of the attribute containing the derivative of v_y w.r.t. x. Defaults to None.

  • dvY_dy_name (str | None) – The name of the attribute containing the derivative of v_y w.r.t. y. Defaults to None.

  • dvY_dz_name (str | None) – The name of the attribute containing the derivative of v_y w.r.t. z. Defaults to None.

  • dvZ_dx_name (str | None) – The name of the attribute containing the derivative of v_z w.r.t. x. Defaults to None.

  • dvZ_dy_name (str | None) – The name of the attribute containing the derivative of v_z w.r.t. y. Defaults to None.

  • dvZ_dz_name (str | None) – The name of the attribute containing the derivative of v_z w.r.t. z. Defaults to None.

  • omegaX_name (str | None) – The name of the attribute containing the x-component of the angular velocity vector of the frame of reference. Defaults to None.

  • omegaY_name (str | None) – The name of the attribute containing the y-component of the angular velocity vector of the frame of reference. Defaults to None.

  • omegaZ_name (str | None) – The name of the attribute containing the z-component of the angular velocity vector of the frame of reference. Defaults to None.

  • distance_center_name (str | None) – The name of the attribute containing the orthogonal distance to the center of rotation. Defaults to None.

  • idx (List[int] | None) – A list of indices indicating which pathlines to read from file. If None, all pathlines are read. Defaults to None.

  • gradient_interp (str) – The interpolation scheme to use for the velocity gradient field. Defaults to ‘previous’.

get_attribute(attribute_name)

Returns a list of dictionaries, each one representing a pathline and containing the keys ‘t’ and ‘y’ for time and attribute, respectively.

Parameters:

attribute_name (str) – The name of the attribute to return.

Returns:

A list of dictionaries.

Return type:

List[Dict[str, NDArray]]

get_name_distance_center()

Returns the name of the attribute that describes the orthogonal distance to the center of rotation. None if not available.

Returns:

The name of the attribute.

Return type:

str | None

get_name_omega_frame()

Returns the name of the attribute that describes the angular velocity vector of the frame of reference. None if not available.

Returns:

The name of the attribute.

Return type:

str | None

get_name_velocity()

Returns the name of the velocity field used for pathline integration.

Returns:

The name of the velocity field.

Return type:

str

get_name_velocity_gradient()

Returns the name of the attribute that contains the velocity gradient. None if not available.

Returns:

The name of the attribute.

Return type:

str | None

get_pathlines()

Returns the current list of pathlines.

Returns:

A list of pathlines.

Return type:

List[Pathline]

to_file(filename, attribute_names=None)

Write pathlines to file. If attribute names are specified, only those attributes are written to file. Otherwise, all attributes are written to file.

Interpolates all attributes to the same time points (those of the ‘Position’ attribute) before writing to file.

Supports writing to CSV, npz, and VTK files. In case of CSV and VTK, it is assumed that all pathlines contain the same attributes, as this is required by the file format (every point must have the same number of attributes). If you want to write pathlines with different attributes to file, there are two options: (1) Write to npz file, which does not require all pathlines to have the same attributes. (2) Instantiate multiple PathlineTracker objects, each with a different set of attributes, and write each one to a separate file. In case of npz, the attribute names and values on each pathline are stored as separate arrays in the file, pattern: arr_0 = attribute_values_pl1, arr_1 = attribute_names_pl1, arr_2 = attribute_values_pl2, arr_3 = attribute_names_pl2, ….

Parameters:
  • filename (str) – The name of the file to write to, including path and extension. Supported extensions are .csv, .npz, and .vtk.

  • attribute_names (List[str], optional) – A list of attribute names to write to file. If None, all attributes are written to file (default).

Return type:

None

class hemtracer.PathlineTracker(flow_field)

Class for generating pathlines from a given flow field. Uses VTK’s vtkStreamTracer to compute pathlines. Stores pathlines as Pathline objects. All point-centered data available in the Eulerian field is interpolated to the pathlines. Cell-centered data is not interpolated. Data can be interpolated to the pathlines afterwards using the interpolate_to_pathlines() function.

Associate Eulerian flow field data and find appropriate velocity field.

Parameters:

flow_field (EulerianFlowField) – The flow field in which to track pathlines.

compute_pathlines(x0, initial_step=0.001, min_step=0.001, max_step=0.002, max_err=0.001, max_length=5.0, n_steps=100000, terminal_velocity=1e-10, integrator='RK45', direction='forward')

Compute pathlines starting from a list of initial points. Stores pathlines in internal list. All point-centered data available in the Eulerian field is interpolated to the pathlines. Cell-centered data is not interpolated. Data can be interpolated to the pathlines afterwards using the interpolate_to_pathlines function.

Parameters:
  • x0 (List[Vector3]) – A list of seed points.

  • initial_step (float) – The initial step size for the pathline integration. Defaults to 0.001.

  • min_step (float) – The minimum step size for the pathline integration. Defaults to 0.001.

  • max_step (float) – The maximum step size for the pathline integration. Defaults to 0.002.

  • max_err (float) – The maximum error for the pathline integration. Defaults to 1e-3.

  • max_length (float) – The maximum length of the pathline. Defaults to 5.0.

  • n_steps (float) – The maximum number of steps to take. Defaults to 100000.

  • terminal_velocity (float) – The velocity at which to stop integration. Defaults to 1e-10.

  • integrator (str) – The integrator to use. Options are “RK2”, “RK4” and “RK45”. Defaults to “RK45”.

  • direction (str) – The direction of integration. Options are “forward”, “backward” and “both”. Defaults to “forward”.

Return type:

None

get_attribute(attribute_name)

Returns a list of dictionaries, each one representing a pathline and containing the keys ‘t’ and ‘y’ for time and attribute, respectively.

Parameters:

attribute_name (str) – The name of the attribute to return.

Returns:

A list of dictionaries.

Return type:

List[Dict[str, NDArray]]

get_flow_field()

Returns the flow field associated with the pathline tracker.

Returns:

The flow field.

Return type:

EulerianFlowField

get_name_distance_center()

Returns the name of the attribute that describes the orthogonal distance to the center of rotation. Implemented by asking the flow field.

Returns:

The name of the attribute.

Return type:

str

get_name_omega_frame()

Returns the name of the attribute that describes the angular velocity vector of the frame of reference. Implemented by asking the flow field.

Returns:

The name of the attribute.

Return type:

str

get_name_velocity()

Returns the name of the velocity field used for pathline integration.

Returns:

The name of the velocity field.

Return type:

str

get_name_velocity_gradient()

Returns the name of the attribute that contains the velocity gradient. Implemented by asking the flow field.

Returns:

The name of the attribute.

Return type:

str

get_pathlines()

Returns the current list of pathlines.

Returns:

A list of pathlines.

Return type:

List[Pathline]

interpolate_dv_to_pathlines(sampling_rate=0.001, interpolation_scheme='previous')

Special case of interpolate_to_pathlines: interpolate velocity gradient data to pathlines. If velocity gradient has not been computed yet, it is computed as part of this function.

Parameters:
  • sampling_rate (float) – The sampling rate for interpolation. Positive values are interpreted as the (fixed) time interval between subsequent samples on the pathline. Zero means to use the same time points as the pathline integration. Negative values are not allowed. Defaults to 0.001.

  • interpolation_scheme (str) – The interpolation scheme to use along the pathline. For all possible values, refer to scipy.interpolate.interp1d. Defaults to ‘previous’.

Return type:

None

interpolate_to_pathlines(field_names, sampling_rate=0.0, interpolation_scheme='linear')

Interpolate field data (cell-centered or point-centered) to pathlines. If fields of same names already exist on pathlines, they are overwritten.

Parameters:
  • field_names (List[str]) – A list of field names to interpolate.

  • sampling_rate (float) – The sampling rate for interpolation. Positive values are interpreted as the (fixed) time interval between subsequent samples on the pathline. Zero means to use the same time points as the pathline integration. Defaults to 0.0.

  • interpolation_scheme (str) – The interpolation scheme to use along the pathline. For all possible values, refer to scipy.interpolate.interp1d. Defaults to ‘linear’.

Return type:

None

to_file(filename, attribute_names=None)

Write pathlines to file. If attribute names are specified, only those attributes are written to file. Otherwise, all attributes are written to file.

Interpolates all attributes to the same time points (those of the ‘Position’ attribute) before writing to file.

Supports writing to CSV, npz, and VTK files. In case of CSV and VTK, it is assumed that all pathlines contain the same attributes, as this is required by the file format (every point must have the same number of attributes). If you want to write pathlines with different attributes to file, there are two options: (1) Write to npz file, which does not require all pathlines to have the same attributes. (2) Instantiate multiple PathlineTracker objects, each with a different set of attributes, and write each one to a separate file. In case of npz, the attribute names and values on each pathline are stored as separate arrays in the file, pattern: arr_0 = attribute_values_pl1, arr_1 = attribute_names_pl1, arr_2 = attribute_values_pl2, arr_3 = attribute_names_pl2, ….

Parameters:
  • filename (str) – The name of the file to write to, including path and extension. Supported extensions are .csv, .npz, and .vtk.

  • attribute_names (List[str], optional) – A list of attribute names to write to file. If None, all attributes are written to file (default).

Return type:

None

RBC models

class hemtracer.rbc_model.strain_based.AroraFullEig

Represents the eigenvalue-eigenvector formulation of the full Eulerian formulation of the Arora model (see Full Arora model)

Arora coefficients (Arora et al. 2004) are used by default.

configure_ODE_solver(method='RK45', atol=1e-06, rtol=1e-05, first_step=0.0001, max_step=0.1)

Configure ODE solver for strain-based model. For details on the parameters, see scipy.integrate.solve_ivp

Parameters:
  • method (str) – Method for ODE solver. Defaults to ‘RK45’.

  • atol (float) – Absolute tolerance for ODE solver. Defaults to 1e-6.

  • rtol (float) – Relative tolerance for ODE solver. Defaults to 1e-5.

  • first_step (float) – Initial step size for ODE solver. Defaults to 0.0001.

  • max_step (float) – Maximum step size for ODE solver. Defaults to 0.1.

Return type:

None

get_attribute_name()

Get name of resulting scalar shear rate attribute on pathlines.

Returns:

Name of scalar shear rate attribute.

Return type:

str

get_name()

Get name of blood damage model.

Returns:

Name of the blood damage model.

Return type:

str

set_coefficients(coeffs)

Set coefficients to use for morphology model. If not called, the Arora coefficients (Arora et al. 2004) are used by default.

Parameters:

coeffs (MorphologyModelCoefficients) – Coefficients for morphology model, has to be a member of the Enum class MorphologyModelCoefficients, e.g., hemtracer.rbc_model.strain_based.MorphologyModelCoefficients.ARORA.

Return type:

None

set_initial_condition(type='undeformed', value=None)

Set initial condition for strain-based model.

Parameters:
  • type (str) – Type of initial condition, i.e., shape of cells at the start of the pathline. Currently supported: undeformed, steadyShear, specificShear, solutionVector. ‘undeformed’ represents an undeformed, i.e., spherical cell. ‘steadyShear’ represents the steady state for a simple shear flow. The shear rate is computed using the second invariant of the strain tensor at the initial position. ‘specificShear’ requires another input in value that can be either a string specifying attribute to take the shear rate from, e.g., ‘Geff’, or a scalar floating point value that specifies the shear rate. It then deforms the cell to correspond to that particular scalar shear rate at the beginning. ‘solutionVector’ allows the user to specify an initial condition directly for the solution variables of the ODE. Defaults to ‘undeformed’.

  • val (str|float|NDArray|None) – Value for initial condition, if applicable. Defaults to None.

  • value (str | float | ndarray[Any, dtype[_ScalarType_co]] | None) –

Return type:

None

class hemtracer.rbc_model.strain_based.AroraSimplified

Represents the simplified Eulerian morphology model (see Simplified Arora model)

Arora coefficients (Arora et al. 2004) are used by default.

configure_ODE_solver(method='RK45', atol=1e-06, rtol=1e-05, first_step=0.0001, max_step=0.1)

Configure ODE solver for strain-based model. For details on the parameters, see scipy.integrate.solve_ivp

Parameters:
  • method (str) – Method for ODE solver. Defaults to ‘RK45’.

  • atol (float) – Absolute tolerance for ODE solver. Defaults to 1e-6.

  • rtol (float) – Relative tolerance for ODE solver. Defaults to 1e-5.

  • first_step (float) – Initial step size for ODE solver. Defaults to 0.0001.

  • max_step (float) – Maximum step size for ODE solver. Defaults to 0.1.

Return type:

None

get_attribute_name()

Get name of resulting scalar shear rate attribute on pathlines.

Returns:

Name of scalar shear rate attribute.

Return type:

str

get_name()

Get name of blood damage model.

Returns:

Name of the blood damage model.

Return type:

str

set_coefficients(coeffs)

Set coefficients to use for morphology model. If not called, the Arora coefficients (Arora et al. 2004) are used by default.

Parameters:

coeffs (MorphologyModelCoefficients) – Coefficients for morphology model, has to be a member of the Enum class MorphologyModelCoefficients, e.g., hemtracer.rbc_model.strain_based.MorphologyModelCoefficients.ARORA.

Return type:

None

set_initial_condition(type='undeformed', value=None)

Set initial condition for strain-based model.

Parameters:
  • type (str) – Type of initial condition, i.e., shape of cells at the start of the pathline. Currently supported: undeformed, steadyShear, specificShear, solutionVector. ‘undeformed’ represents an undeformed, i.e., spherical cell. ‘steadyShear’ represents the steady state for a simple shear flow. The shear rate is computed using the second invariant of the strain tensor at the initial position. ‘specificShear’ requires another input in value that can be either a string specifying attribute to take the shear rate from, e.g., ‘Geff’, or a scalar floating point value that specifies the shear rate. It then deforms the cell to correspond to that particular scalar shear rate at the beginning. ‘solutionVector’ allows the user to specify an initial condition directly for the solution variables of the ODE. Defaults to ‘undeformed’.

  • val (str|float|NDArray|None) – Value for initial condition, if applicable. Defaults to None.

  • value (str | float | ndarray[Any, dtype[_ScalarType_co]] | None) –

Return type:

None

class hemtracer.rbc_model.strain_based.TankTreading

Represents the tank-treading cell deformation model (see Tank-treading model),

Arora coefficients (Arora et al. 2004) are used by default.

configure_ODE_solver(method='RK45', atol=1e-06, rtol=1e-05, first_step=0.0001, max_step=0.1)

Configure ODE solver for strain-based model. For details on the parameters, see scipy.integrate.solve_ivp

Parameters:
  • method (str) – Method for ODE solver. Defaults to ‘RK45’.

  • atol (float) – Absolute tolerance for ODE solver. Defaults to 1e-6.

  • rtol (float) – Relative tolerance for ODE solver. Defaults to 1e-5.

  • first_step (float) – Initial step size for ODE solver. Defaults to 0.0001.

  • max_step (float) – Maximum step size for ODE solver. Defaults to 0.1.

Return type:

None

configure_steadyOrientation_solver(tol=1e-05, maxIt=100)

Set parameters for steady state orientation computation.

Parameters:
  • tol (float) – Tolerance for convergence. Defaults to 1e-5.

  • maxIt (int) – Maximum number of iterations. Defaults to 100.

Return type:

None

get_attribute_name()

Get name of resulting scalar shear rate attribute on pathlines.

Returns:

Name of scalar shear rate attribute.

Return type:

str

get_name()

Get name of blood damage model.

Returns:

Name of the blood damage model.

Return type:

str

set_coefficients(coeffs)

Set coefficients to use for morphology model. If not called, the Arora coefficients (Arora et al. 2004) are used by default.

Parameters:

coeffs (MorphologyModelCoefficients) – Coefficients for morphology model, has to be a member of the Enum class MorphologyModelCoefficients, e.g., hemtracer.rbc_model.strain_based.MorphologyModelCoefficients.ARORA.

Return type:

None

set_initial_condition(type='undeformed', value=None)

Set initial condition for strain-based model.

Parameters:
  • type (str) – Type of initial condition, i.e., shape of cells at the start of the pathline. Currently supported: undeformed, steadyShear, specificShear, solutionVector. ‘undeformed’ represents an undeformed, i.e., spherical cell. ‘steadyShear’ represents the steady state for a simple shear flow. The shear rate is computed using the second invariant of the strain tensor at the initial position. ‘specificShear’ requires another input in value that can be either a string specifying attribute to take the shear rate from, e.g., ‘Geff’, or a scalar floating point value that specifies the shear rate. It then deforms the cell to correspond to that particular scalar shear rate at the beginning. ‘solutionVector’ allows the user to specify an initial condition directly for the solution variables of the ODE. Defaults to ‘undeformed’.

  • val (str|float|NDArray|None) – Value for initial condition, if applicable. Defaults to None.

  • value (str | float | ndarray[Any, dtype[_ScalarType_co]] | None) –

Return type:

None

class hemtracer.rbc_model.strain_based.TankTreadingRotationCorrection

Represents the tank-treading model (Dirkes et al. 2023) with a correction term for cell rotation along the pathline. This model is still experimental and not yet published.

Arora coefficients (Arora et al. 2004) are used by default.

configure_ODE_solver(method='RK45', atol=1e-06, rtol=1e-05, first_step=0.0001, max_step=0.1)

Configure ODE solver for strain-based model. For details on the parameters, see scipy.integrate.solve_ivp

Parameters:
  • method (str) – Method for ODE solver. Defaults to ‘RK45’.

  • atol (float) – Absolute tolerance for ODE solver. Defaults to 1e-6.

  • rtol (float) – Relative tolerance for ODE solver. Defaults to 1e-5.

  • first_step (float) – Initial step size for ODE solver. Defaults to 0.0001.

  • max_step (float) – Maximum step size for ODE solver. Defaults to 0.1.

Return type:

None

configure_steadyOrientation_solver(tol=1e-05, maxIt=100)

Set parameters for steady state orientation computation.

Parameters:
  • tol (float) – Tolerance for convergence. Defaults to 1e-5.

  • maxIt (int) – Maximum number of iterations. Defaults to 100.

Return type:

None

get_attribute_name()

Get name of resulting scalar shear rate attribute on pathlines.

Returns:

Name of scalar shear rate attribute.

Return type:

str

get_name()

Get name of blood damage model.

Returns:

Name of the blood damage model.

Return type:

str

set_coefficients(coeffs)

Set coefficients to use for morphology model. If not called, the Arora coefficients (Arora et al. 2004) are used by default.

Parameters:

coeffs (MorphologyModelCoefficients) – Coefficients for morphology model, has to be a member of the Enum class MorphologyModelCoefficients, e.g., hemtracer.rbc_model.strain_based.MorphologyModelCoefficients.ARORA.

Return type:

None

set_initial_condition(type='undeformed', value=None)

Set initial condition for strain-based model.

Parameters:
  • type (str) – Type of initial condition, i.e., shape of cells at the start of the pathline. Currently supported: undeformed, steadyShear, specificShear, solutionVector. ‘undeformed’ represents an undeformed, i.e., spherical cell. ‘steadyShear’ represents the steady state for a simple shear flow. The shear rate is computed using the second invariant of the strain tensor at the initial position. ‘specificShear’ requires another input in value that can be either a string specifying attribute to take the shear rate from, e.g., ‘Geff’, or a scalar floating point value that specifies the shear rate. It then deforms the cell to correspond to that particular scalar shear rate at the beginning. ‘solutionVector’ allows the user to specify an initial condition directly for the solution variables of the ODE. Defaults to ‘undeformed’.

  • val (str|float|NDArray|None) – Value for initial condition, if applicable. Defaults to None.

  • value (str | float | ndarray[Any, dtype[_ScalarType_co]] | None) –

Return type:

None

set_time_dependent_quantitites(t0, tend, time_points=None, dv=None, omega=None, x=None, v=None, init=None)

Set time-dependent quantities for the cell model. Overrides superclass method to include position measure x and velocity v.

Parameters:
  • t0 (float) – Start time.

  • tend (float) – End time.

  • dv (Callable[[float], Vector9]) – Time-dependent velocity gradient dv/dt.

  • omega (Callable[[float], Vector3]) – Time-dependent angular velocity.

  • x (Callable[[float], Vector3]) – Time-dependent position measure, e.g., absolute coordinates or distance from rotational center.

  • v (Callable[[float], Vector3]) – Time-dependent velocity.

  • init (Dict[str, float]) – Dict with initial values for attributes on pathline, only required for specific shear initial condition.

  • time_points (ndarray[Any, dtype[_ScalarType_co]] | None) –

Raises:

ValueError – If position measure x or velocity v is not provided.

Return type:

None

class hemtracer.rbc_model.strain_based.MorphologyModelCoefficients(value, names=<not given>, *values, module=None, qualname=None, type=None, start=1, boundary=None)

Structure that contains morphology model coefficients \((f_1, f_2, f_3, \tilde{f}_2, \tilde{f}_3)\). The coefficients are defined as follows:

\(f_1\) : Recovery coefficient.

\(f_2\) : Strain coefficient.

\(f_3\) : Vorticity coefficient.

\(\tilde{f}_2\): Coefficient for rotational part of strain tensor (only relevant for AroraFullEig).

\(\tilde{f}_3\): Coefficient for rotational part of vorticity tensor (only relevant for AroraFullEig).

ARORA = (5.0, 0.00042298, 0.00042298, 1.0, 1.0)

Arora et al. (2004)

class hemtracer.rbc_model.stress_based.Bludszuweit

Represents the stress-based Bludszuweit model.

Initialize stress-based model. By default, use same time points as pathline, i.e., do not sample.

get_attribute_name()

Get name of resulting scalar shear rate attribute on pathlines.

Returns:

Name of scalar shear rate attribute.

Return type:

str

get_name()

Get name of blood damage model.

Returns:

Name of the blood damage model.

Return type:

str

set_sampling_rate(sampling_rate)

Set sampling rate of velocity gradients along pathline for stress-based model. If sampling rate is positive, it is interpreted as the time interval between two consecutive samples. If sampling rate is negative, it is interpreted as the number of samples per time interval.

Parameters:

sampling_rate (float) – Sampling rate.

Return type:

None

class hemtracer.rbc_model.stress_based.FaghihSharp

Represents the stress-based Faghih and Sharp model that weighs extensional and shear stresses differently.

Initialize stress-based model. By default, use same time points as pathline, i.e., do not sample.

get_attribute_name()

Get name of resulting scalar shear rate attribute on pathlines.

Returns:

Name of scalar shear rate attribute.

Return type:

str

get_name()

Get name of blood damage model.

Returns:

Name of the blood damage model.

Return type:

str

set_sampling_rate(sampling_rate)

Set sampling rate of velocity gradients along pathline for stress-based model. If sampling rate is positive, it is interpreted as the time interval between two consecutive samples. If sampling rate is negative, it is interpreted as the number of samples per time interval.

Parameters:

sampling_rate (float) – Sampling rate.

Return type:

None

class hemtracer.rbc_model.stress_based.Frobenius

Computes a representative scalar from instantaneous fluid strain using the Frobenius norm.

Initialize stress-based model. By default, use same time points as pathline, i.e., do not sample.

get_attribute_name()

Get name of resulting scalar shear rate attribute on pathlines.

Returns:

Name of scalar shear rate attribute.

Return type:

str

get_name()

Get name of blood damage model.

Returns:

Name of the blood damage model.

Return type:

str

set_sampling_rate(sampling_rate)

Set sampling rate of velocity gradients along pathline for stress-based model. If sampling rate is positive, it is interpreted as the time interval between two consecutive samples. If sampling rate is negative, it is interpreted as the number of samples per time interval.

Parameters:

sampling_rate (float) – Sampling rate.

Return type:

None

class hemtracer.rbc_model.stress_based.SecondInvariant

Computes a representative scalar from instantaneous fluid strain using the Second strain invariant.

Initialize stress-based model. By default, use same time points as pathline, i.e., do not sample.

get_attribute_name()

Get name of resulting scalar shear rate attribute on pathlines.

Returns:

Name of scalar shear rate attribute.

Return type:

str

get_name()

Get name of blood damage model.

Returns:

Name of the blood damage model.

Return type:

str

set_sampling_rate(sampling_rate)

Set sampling rate of velocity gradients along pathline for stress-based model. If sampling rate is positive, it is interpreted as the time interval between two consecutive samples. If sampling rate is negative, it is interpreted as the number of samples per time interval.

Parameters:

sampling_rate (float) – Sampling rate.

Return type:

None

Hemolysis models

class hemtracer.hemolysis_model.PowerLawModel(scalar_shear, hemolysis_correlation=IHCorrelation.GIERSIEPEN, mu=0.0035, integration_scheme='basic')

A power law hemolysis model is a model that, given a scalar measure for fluid stress (in our case a representative shear rate), predicts the hemolysis index along a pathline. This is done by integrating an experimental correlation for the hemolysis index along the pathline. For details, see Hemolysis models.

Initialization defines all parameters to use. They cannot be changed afterwards.

Parameters:
  • scalar_shear (RBCModel | str) – Model to compute scalar shear rate, or name of attribute containing representative shear rate, e.g., ‘Geff’ if available from an Eulerian simulation.

  • hemolysis_correlation (HemolysisCorrelation) – Hemolysis correlation to use.

  • mu (float | str) – Dynamic viscosity of blood. Defaults to 3.5e-3. If a string is given, it is assumed to be the name of an attribute containing the (local) dynamic viscosity.

  • integration_scheme (str) – Integration scheme for hemolysis correlation. Integration schemes defined according to Taskin et al. [12]. Valid options are ‘basic’ (HI1), ‘timeDiff’ (HI2), ‘linearized’ (HI3), ‘mechDose’ (HI4), ‘effTime’ (HI5). Defaults to ‘basic’.

class hemtracer.hemolysis_model.IHCorrelation(value, names=<not given>, *values, module=None, qualname=None, type=None, start=1, boundary=None)

Represents sets of empirical parameters \((A_\mathrm{Hb}, \alpha_\mathrm{Hb}, \beta_\mathrm{Hb})\) for the correlation \(IH = A_\mathrm{Hb} \sigma^{\alpha_\mathrm{Hb}} t^{\beta_\mathrm{Hb}}\). Magnitude of \(A_{Hb}\) is chosen such that \(IH\) is in percent.

DING_BOVINE = (9.772e-05, 1.4445, 0.2076)

Ding et al. [3]

DING_HUMAN = (3.458e-06, 2.0639, 0.2777)

Ding et al. [3]

DING_PORCINE = (0.0006701, 1.0981, 0.2778)

Ding et al. [3]

GESENHUES_OPTIMIZED = (0.00023212, 1.4949, 0.33)

Gesenhues et al. [6]

GIERSIEPEN = (3.62e-05, 2.416, 0.785)

Giersiepen et al. [7]

SONG = (1.8e-06, 1.991, 0.765)

Song et al. [11]

ZHANG = (1.228e-05, 1.9918, 0.6606)

Zhang et al. [13]