.. _program_listing_file_SPlisHSPlasH_NonPressureForceRegistration.cpp: Program Listing for File NonPressureForceRegistration.cpp ========================================================= |exhale_lsh| :ref:`Return to documentation for file ` (``SPlisHSPlasH/NonPressureForceRegistration.cpp``) .. |exhale_lsh| unicode:: U+021B0 .. UPWARDS ARROW WITH TIP LEFTWARDS .. code-block:: cpp #include "Simulation.h" #include "SPlisHSPlasH/Drag/DragForce_Macklin2014.h" #include "SPlisHSPlasH/Drag/DragForce_Gissler2017.h" #include "SPlisHSPlasH/Viscosity/Viscosity_Standard.h" #include "SPlisHSPlasH/Viscosity/Viscosity_Bender2017.h" #include "SPlisHSPlasH/Viscosity/Viscosity_Peer2015.h" #include "SPlisHSPlasH/Viscosity/Viscosity_Peer2016.h" #include "SPlisHSPlasH/Viscosity/Viscosity_Takahashi2015.h" #include "SPlisHSPlasH/Viscosity/Viscosity_Weiler2018.h" #include "SPlisHSPlasH/Vorticity/VorticityConfinement.h" #include "SPlisHSPlasH/Vorticity/MicropolarModel_Bender2017.h" #include "Elasticity/Elasticity_Becker2009.h" #include "Elasticity/Elasticity_Peer2018.h" #include "Elasticity/Elasticity_Kugelstadt2021.h" #include "SurfaceTension/SurfaceTension_Becker2007.h" #include "SurfaceTension/SurfaceTension_Akinci2013.h" #include "SurfaceTension/SurfaceTension_He2014.h" #include "SurfaceTension/SurfaceTension_Jeske2023.h" #ifdef USE_THIRD_PARTY_METHODS #include "SurfaceTension/SurfaceTension_ZorillaRitter2020.h" #endif using namespace SPH; void Simulation::registerNonpressureForces() { addDragMethod("None", [](FluidModel*) -> NonPressureForceBase* { return nullptr; }); addDragMethod("Macklin et al. 2014", DragForce_Macklin2014::creator); addDragMethod("Gissler et al. 2017", DragForce_Gissler2017::creator); addElasticityMethod("None", [](FluidModel*) -> NonPressureForceBase* { return nullptr; }); addElasticityMethod("Becker et al. 2009", Elasticity_Becker2009::creator); addElasticityMethod("Peer et al. 2018", Elasticity_Peer2018::creator); addElasticityMethod("Kugelstadt et al. 2021", Elasticity_Kugelstadt2021::creator); addSurfaceTensionMethod("None", [](FluidModel*) -> NonPressureForceBase* { return nullptr; }); addSurfaceTensionMethod("Becker & Teschner 2007", SurfaceTension_Becker2007::creator); addSurfaceTensionMethod("Akinci et al. 2013", SurfaceTension_Akinci2013::creator); addSurfaceTensionMethod("He et al. 2014", SurfaceTension_He2014::creator); addSurfaceTensionMethod("Jeske et al. 2023", SurfaceTension_Jeske2023::creator); #ifdef USE_THIRD_PARTY_METHODS addSurfaceTensionMethod("Zorilla, Ritter, et al. 2020", SurfaceTension_ZorillaRitter2020::creator); #endif addViscosityMethod("None", [](FluidModel*) -> NonPressureForceBase* { return nullptr; }); addViscosityMethod("Standard", Viscosity_Standard::creator); addViscosityMethod("Bender and Koschier 2017", Viscosity_Bender2017::creator); addViscosityMethod("Peer et al. 2015", Viscosity_Peer2015::creator); addViscosityMethod("Peer et al. 2016", Viscosity_Peer2016::creator); addViscosityMethod("Takahashi et al. 2015 (improved)", Viscosity_Takahashi2015::creator); addViscosityMethod("Weiler et al. 2018", Viscosity_Weiler2018::creator); addVorticityMethod("None", [](FluidModel*) -> NonPressureForceBase* { return nullptr; }); addVorticityMethod("Micropolar model", MicropolarModel_Bender2017::creator); addVorticityMethod("Vorticity confinement", VorticityConfinement::creator); }