immersed_rho_m Module

immersed boundary module, bsaed on flux surface label rho


Uses

  • module~~immersed_rho_m~~UsesGraph module~immersed_rho_m immersed_rho_m module~elementary_functions_m elementary_functions_m module~immersed_rho_m->module~elementary_functions_m module~equilibrium_m equilibrium_m module~immersed_rho_m->module~equilibrium_m module~error_handling_m error_handling_m module~immersed_rho_m->module~error_handling_m module~immersed_m immersed_m module~immersed_rho_m->module~immersed_m module~mesh_cart_m mesh_cart_m module~immersed_rho_m->module~mesh_cart_m module~precision_m precision_m module~immersed_rho_m->module~precision_m module~screen_io_m screen_io_m module~immersed_rho_m->module~screen_io_m module~status_codes_m status_codes_m module~immersed_rho_m->module~status_codes_m module~elementary_functions_m->module~precision_m module~equilibrium_m->module~precision_m module~error_handling_m->module~precision_m module~error_handling_m->module~screen_io_m module~error_handling_m->module~status_codes_m module~comm_handling_m comm_handling_m module~error_handling_m->module~comm_handling_m mpi mpi module~error_handling_m->mpi netcdf netcdf module~error_handling_m->netcdf module~immersed_m->module~equilibrium_m module~immersed_m->module~mesh_cart_m module~immersed_m->module~precision_m module~list_operations_m list_operations_m module~immersed_m->module~list_operations_m module~mesh_cart_m->module~equilibrium_m module~mesh_cart_m->module~error_handling_m module~mesh_cart_m->module~precision_m module~mesh_cart_m->module~status_codes_m iso_c_binding iso_c_binding module~mesh_cart_m->iso_c_binding module~mesh_cart_m->module~comm_handling_m module~descriptors_m descriptors_m module~mesh_cart_m->module~descriptors_m module~slab_equilibrium_m slab_equilibrium_m module~mesh_cart_m->module~slab_equilibrium_m module~mesh_cart_m->netcdf module~precision_m->iso_c_binding iso_fortran_env iso_fortran_env module~precision_m->iso_fortran_env module~precision_m->mpi module~precision_m->netcdf module~screen_io_m->module~precision_m module~screen_io_m->iso_fortran_env module~screen_io_m->netcdf module~comm_handling_m->mpi module~descriptors_m->module~screen_io_m module~list_operations_m->module~precision_m module~list_operations_m->module~screen_io_m module~slab_equilibrium_m->module~equilibrium_m module~slab_equilibrium_m->module~precision_m module~slab_equilibrium_m->module~screen_io_m module~slab_equilibrium_m->module~descriptors_m module~params_equi_slab_m params_equi_slab_m module~slab_equilibrium_m->module~params_equi_slab_m module~params_equi_slab_m->module~error_handling_m module~params_equi_slab_m->module~precision_m module~params_equi_slab_m->module~screen_io_m module~params_equi_slab_m->module~status_codes_m module~params_equi_slab_m->iso_fortran_env

Used by

  • module~~immersed_rho_m~~UsedByGraph module~immersed_rho_m immersed_rho_m module~immersed_factory_m immersed_factory_m module~immersed_factory_m->module~immersed_rho_m

Variables

Type Visibility Attributes Name Initial
real(kind=FP), protected :: immersed_rho_inner = -FP_LARGEST

rho value, until where boundary immersion is applied

real(kind=FP), protected :: immersed_width_inner = 0.0_FP

Transition width at inner rho boundary immersion

real(kind=FP), protected :: immersed_rho_outer = FP_LARGEST

rho value, from where boundary immersion is applied

real(kind=FP), protected :: immersed_width_outer = 0.0_FP

Transition width at outer rho boundary immersion

integer, protected :: immersed_step_order = 2

Hermite order of transition function


Derived Types

type, public, extends(immersed_t) ::  immersed_rho_t

Immersed boundary type based on rho

Components

Type Visibility Attributes Name Initial
real(kind=FP), public, allocatable, dimension(:) :: charfun

Characteristic function of immersed boundary, commonly referred chi

real(kind=FP), public, allocatable, dimension(:) :: dirindfun

Function indicating direction of magnetic field (towards/away from target), commonly referred xi

integer, public, allocatable, dimension(:) :: inds

Mesh indices which lie in immersed boundary region

integer, public :: n_inds

Size of inds

integer, public, allocatable, dimension(:) :: adj_inds

Mesh indices, which are adjacent to the immersed boundary region

integer, public :: n_adj_inds

Size of adj_inds

Finalizations Procedures

final :: destructor_immersed_rho_t

Type-Bound Procedures

procedure, public :: build_inds
procedure, public :: build_adj_inds
procedure, public :: write_netcdf => write_netcdf_immersed
procedure, public :: read_netcdf => read_netcdf_immersed
procedure, public :: init
procedure, public :: display

Subroutines

public subroutine init(self, equi, mesh, filename)

Arguments

Type IntentOptional Attributes Name
class(immersed_rho_t), intent(inout) :: self
class(equilibrium_t), intent(inout) :: equi
type(mesh_cart_t), intent(in) :: mesh
character(len=*), intent(in), optional :: filename

public subroutine read_params_immersed_rho(self, filename)

Reads parameters for rho based immersed boundary

Arguments

Type IntentOptional Attributes Name
class(immersed_rho_t), intent(inout) :: self

Instance of type

character(len=*), intent(in) :: filename

Filename, where to read parameters from

public subroutine display(self)

Arguments

Type IntentOptional Attributes Name
class(immersed_rho_t), intent(in) :: self

public subroutine destructor_immersed_rho_t(self)

Destructor for immersed_rho_t

Arguments

Type IntentOptional Attributes Name
type(immersed_rho_t), intent(inout) :: self