https://github.com/sakamotoyan/TiSPH_multiphase
Raw File
Tip revision: 06d2adb7822f4392b21185d38c52cad34aaebef6 authored by sakamotoyan on 20 March 2024, 13:09:09 UTC
Update representative image
Tip revision: 06d2adb
template_part.py
import taichi as ti
from ti_sph.basic_op import *
from ti_sph import *
import numpy as np

def part_template(part_obj, world, verbose=False):

    ''' Enssential arrays'''
    ''' encouraged to add for any particle system'''
    part_obj.add_array("pos", vecxf(part_obj.m_world.g_dim[None]).field())
    part_obj.add_array("vel", vecxf(part_obj.m_world.g_dim[None]).field())
    part_obj.add_array("vel_adv", vecxf(part_obj.m_world.g_dim[None]).field())
    part_obj.add_array("mass", ti.field(ti.f32))
    part_obj.add_array("size", ti.field(ti.f32))
    part_obj.add_array("volume", ti.field(ti.f32))
    part_obj.add_array("rest_density", ti.field(ti.f32))
    part_obj.add_array("pressure", ti.field(ti.f32))
    part_obj.add_array("k_vis", ti.field(ti.f32))
    part_obj.add_array("acc", vecxf(part_obj.m_world.g_dim[None]).field())
    part_obj.add_array("rgb", vecxf(3).field())
    
    part_obj.add_attr("statistics_linear_momentum", vecx_f(part_obj.m_world.g_dim[None]))
    part_obj.add_attr("statistics_angular_momentum", vecx_f(3))
    part_obj.add_attr("statistics_kinetic_energy", val_f(0))

    ''' Optional arrays'''
    # part_obj.add_array("volume_fraction", ti.field(ti.f32), bundle=2)
    ## example only, not used in this test
    # fluid_part.add_array("volume_fraction", [ti.field(ti.f32), ti.field(ti.f32)])

    # fluid_phase = ti.types.struct(
    # val_frac=ti.f32,
    # phase_vel=vecxf(part_obj.m_world.g_dim[None]),
    # phase_acc=vecxf(part_obj.m_world.g_dim[None]),
    # phase_force=vecxf(part_obj.m_world.g_dim[None]),
    # )

    sph = ti.types.struct(
        h=ti.f32,
        sig=ti.f32,
        sig_inv_h=ti.f32,
        density=ti.f32,
        compression_ratio=ti.f32,
        pressure=ti.f32,
        pressure_force=vecxf(part_obj.m_world.g_dim[None]),
        viscosity_force=vecxf(part_obj.m_world.g_dim[None]),
        gravity_force=vecxf(part_obj.m_world.g_dim[None]),
    )

    sph_df = ti.types.struct(
        alpha_1=vecxf(part_obj.m_world.g_dim[None]),
        alpha_2=ti.f32,
        alpha=ti.f32,
        kappa_incomp=ti.f32,
        kappa_div=ti.f32,
        delta_density=ti.f32,
        delta_compression_ratio=ti.f32,
        vel_adv=vecxf(part_obj.m_world.g_dim[None]),
    )
    sph_wc = ti.types.struct(
        B=ti.f32,
    )

    phase = ti.types.struct(
        val_frac=ti.f32,
        val_frac_in=ti.f32,
        val_frac_out=ti.f32,
        vel=vecxf(part_obj.m_world.g_dim[None]),
        drift_vel=vecxf(part_obj.m_world.g_dim[None]),
        acc=vecxf(part_obj.m_world.g_dim[None]),
    )
    mixture = ti.types.struct(
        lamb = ti.f32,
        flag_negative_val_frac = ti.i32,
        acc_pressure=vecxf(part_obj.m_world.g_dim[None]),
    )

    part_obj.add_struct("sph", sph)
    part_obj.add_struct("sph_df", sph_df)
    part_obj.add_struct("sph_wc", sph_wc)
    if hasattr(world, 'g_phase_num'):
        part_obj.add_struct("phase", phase, bundle=world.g_phase_num[None])
    part_obj.add_struct("mixture", mixture)

    if verbose:
        part_obj.verbose_attrs("fluid_part")
        part_obj.verbose_arrays("fluid_part")
        part_obj.verbose_structs("fluid_part")

    return part_obj
back to top