Skip to content

PowerDistribution

Bases: MeshDistribution

Power path distribution class expression: fn(u) = u**power expression: fn(u) = u

For more information, see MeshDistribution.

Source code in pymesh/mesh/mesh_distributions.py
class PowerDistribution(MeshDistribution):
    """Power path distribution class
    expression: fn(u) = u**power
    expression: fn(u) = u

    For more information, see [MeshDistribution][pymesh.mesh.mesh_distributions.MeshDistribution].
    """

    power = AsNumber(return_type=float)

    def __init__(self, power: int | float = 1.0, flip_direction: bool = False):
        super().__init__(flip_direction=flip_direction)
        self.power = power

    def copy(self) -> Self:
        return PowerDistribution(self.power, self.flip_direction)

    def get_dist_fn(self):
        flip = True if self.flip_direction else False  # breaks ref to self

        def fn(u: int | float, flip_direction: bool = flip) -> float:
            u = self.validate_fn_input(u=u, flip_direction=flip_direction)
            exp = u**self.power
            return self.flip_exp(exp, flip_direction)

        return fn