Report Typos and Errors    
Semi-Lagrangian Library
Modular library for kinetic and gyrokinetic simulations of plasmas in fusion energy devices.
Derived types and interfaces | Functions/Subroutines
sll_m_advection_1d_csl_periodic Module Reference

Description

conservative semi-lagrangian 1d advection using periodic interpolation

Derived types and interfaces

type  csl_periodic_1d_advector
 

Functions/Subroutines

type(csl_periodic_1d_advector) function, pointer, public sll_f_new_csl_periodic_1d_advector (interp, charac, Npts, eta_min, eta_max, eta_coords, csl_degree)
 
subroutine initialize_csl_periodic_1d_advector (adv, interp, charac, Npts, eta_min, eta_max, eta_coords, csl_degree)
 
subroutine csl_periodic_advect_1d (adv, A, dt, input, output)
 
subroutine csl_periodic_advect_1d_constant (adv, A, dt, input, output)
 
subroutine delete_csl_periodic_1d_adv (adv)
 
subroutine check_charac_feet (origin, feet, Npts, epsilon)
 
real(kind=f64) function compute_gap_min (input, Npts)
 
real(kind=f64) function compute_gap_max (input, Npts)
 
subroutine compute_csl_hermite_mat (d, N, output)
 
subroutine compute_inverse_csl_hermite_mat (N, mat)
 
subroutine mult_circulant_mat (N, mat, f, fft_buf)
 
subroutine compute_csl_integral (Npts, interp, origin, feet, output)
 
real(kind=f64) function compute_simpson_contribution_csl_periodic (interp, a, b, eta_min, eta_max)
 
subroutine compute_csl_mat (interp, eta_min, eta_max, Npts, output)
 
real(kind=f64) function compute_quadrature (interp, a, b, w)
 
subroutine check_solve_csl_mat (csl_mat, csl_mat_init, N, fft_buf)
 
subroutine circ_mat_mul_direct (a, input, output, N)
 
subroutine compute_node_derivative_order3 (interp, deriv, N, eta_min, eta_max)
 
subroutine update_solution_csl_periodic (interp, input, deriv, charac, Npts, eta_min, eta_max, output, csl_degree)
 
real(kind=f64) function evaluate_hermite_1d (x, dof)
 
real(kind=f64) function contribution_simpson_hermite (a, b, dof)
 
subroutine compute_csl_ww (ww, r, s)
 
real(kind=f64) function contribution_gauss_lagrange (a, b, xval, fval, r, s, xw, ng)
 

Function/Subroutine Documentation

◆ check_charac_feet()

subroutine sll_m_advection_1d_csl_periodic::check_charac_feet ( real(kind=f64), dimension(:), intent(in)  origin,
real(kind=f64), dimension(:), intent(inout)  feet,
integer(kind=i32), intent(in)  Npts,
real(kind=f64), intent(in), optional  epsilon 
)
private

Definition at line 387 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ check_solve_csl_mat()

subroutine sll_m_advection_1d_csl_periodic::check_solve_csl_mat ( real(kind=f64), dimension(:), intent(in)  csl_mat,
real(kind=f64), dimension(:), intent(in)  csl_mat_init,
integer(kind=i32), intent(in)  N,
real(kind=f64), dimension(:), intent(in)  fft_buf 
)
private

Definition at line 794 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the call graph for this function:

◆ circ_mat_mul_direct()

subroutine sll_m_advection_1d_csl_periodic::circ_mat_mul_direct ( real(kind=f64), dimension(:), intent(in)  a,
real(kind=f64), dimension(:), intent(in)  input,
real(kind=f64), dimension(:), intent(out)  output,
integer(kind=i32), intent(in)  N 
)
private

Definition at line 842 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the caller graph for this function:

◆ compute_csl_hermite_mat()

subroutine sll_m_advection_1d_csl_periodic::compute_csl_hermite_mat ( integer(kind=i32), intent(in)  d,
integer(kind=i32), intent(in)  N,
real(kind=f64), dimension(:), intent(out)  output 
)
private

Definition at line 480 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the call graph for this function:

◆ compute_csl_integral()

subroutine sll_m_advection_1d_csl_periodic::compute_csl_integral ( integer(kind=i32), intent(in)  Npts,
class(sll_c_interpolator_1d), pointer  interp,
real(kind=f64), dimension(:), intent(in)  origin,
real(kind=f64), dimension(:), intent(in)  feet,
real(kind=f64), dimension(:), intent(out)  output 
)
private

Definition at line 604 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the call graph for this function:

◆ compute_csl_mat()

subroutine sll_m_advection_1d_csl_periodic::compute_csl_mat ( class(sll_c_interpolator_1d), pointer  interp,
real(kind=f64), intent(in)  eta_min,
real(kind=f64), intent(in)  eta_max,
integer(kind=i32), intent(in)  Npts,
real(kind=f64), dimension(:), intent(out)  output 
)
private

Definition at line 710 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the call graph for this function:

◆ compute_csl_ww()

subroutine sll_m_advection_1d_csl_periodic::compute_csl_ww ( real(kind=f64), dimension(r:s - 1), intent(out)  ww,
integer(kind=i32), intent(in)  r,
integer(kind=i32), intent(in)  s 
)
private

Definition at line 1574 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the caller graph for this function:

◆ compute_gap_max()

real(kind=f64) function sll_m_advection_1d_csl_periodic::compute_gap_max ( real(kind=f64), dimension(:), intent(in)  input,
integer(kind=i32), intent(in)  Npts 
)
private

Definition at line 460 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the caller graph for this function:

◆ compute_gap_min()

real(kind=f64) function sll_m_advection_1d_csl_periodic::compute_gap_min ( real(kind=f64), dimension(:), intent(in)  input,
integer(kind=i32), intent(in)  Npts 
)
private

Definition at line 440 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the caller graph for this function:

◆ compute_inverse_csl_hermite_mat()

subroutine sll_m_advection_1d_csl_periodic::compute_inverse_csl_hermite_mat ( integer(kind=i32), intent(in)  N,
real(kind=f64), dimension(:), intent(inout)  mat 
)
private

Definition at line 536 of file sll_m_advection_1d_CSL_periodic.F90.

◆ compute_node_derivative_order3()

subroutine sll_m_advection_1d_csl_periodic::compute_node_derivative_order3 ( class(sll_c_interpolator_1d), pointer  interp,
real(kind=f64), dimension(:, :), intent(out)  deriv,
integer(kind=i32), intent(in)  N,
real(kind=f64), intent(in)  eta_min,
real(kind=f64), intent(in)  eta_max 
)
private

Definition at line 864 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ compute_quadrature()

real(kind=f64) function sll_m_advection_1d_csl_periodic::compute_quadrature ( class(sll_c_interpolator_1d), pointer  interp,
real(kind=f64), intent(in)  a,
real(kind=f64), intent(in)  b,
real(kind=f64), dimension(4), intent(in)  w 
)
private

Definition at line 777 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the caller graph for this function:

◆ compute_simpson_contribution_csl_periodic()

real(kind=f64) function sll_m_advection_1d_csl_periodic::compute_simpson_contribution_csl_periodic ( class(sll_c_interpolator_1d), pointer  interp,
real(kind=f64), intent(in)  a,
real(kind=f64), intent(in)  b,
real(kind=f64), intent(in)  eta_min,
real(kind=f64), intent(in)  eta_max 
)
private

Definition at line 678 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ contribution_gauss_lagrange()

real(kind=f64) function sll_m_advection_1d_csl_periodic::contribution_gauss_lagrange ( real(kind=f64), intent(in)  a,
real(kind=f64), intent(in)  b,
real(kind=f64), dimension(r:s), intent(in)  xval,
real(kind=f64), dimension(r:s), intent(in)  fval,
integer(kind=i32), intent(in)  r,
integer(kind=i32), intent(in)  s,
real(kind=f64), dimension(:, :), intent(in)  xw,
integer(kind=i32), intent(in)  ng 
)
private

Definition at line 1657 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ contribution_simpson_hermite()

real(kind=f64) function sll_m_advection_1d_csl_periodic::contribution_simpson_hermite ( real(kind=f64), intent(in)  a,
real(kind=f64), intent(in)  b,
real(kind=f64), dimension(:), intent(in)  dof 
)
private

Definition at line 1550 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ csl_periodic_advect_1d()

subroutine sll_m_advection_1d_csl_periodic::csl_periodic_advect_1d ( class(csl_periodic_1d_advector adv,
real(kind=f64), dimension(:), intent(in)  A,
real(kind=f64), intent(in)  dt,
real(kind=f64), dimension(:), intent(in)  input,
real(kind=f64), dimension(:), intent(out)  output 
)
private

Definition at line 241 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the call graph for this function:

◆ csl_periodic_advect_1d_constant()

subroutine sll_m_advection_1d_csl_periodic::csl_periodic_advect_1d_constant ( class(csl_periodic_1d_advector adv,
real(kind=f64), intent(in)  A,
real(kind=f64), intent(in)  dt,
real(kind=f64), dimension(:), intent(in)  input,
real(kind=f64), dimension(:), intent(out)  output 
)
private

Definition at line 337 of file sll_m_advection_1d_CSL_periodic.F90.

◆ delete_csl_periodic_1d_adv()

subroutine sll_m_advection_1d_csl_periodic::delete_csl_periodic_1d_adv ( class(csl_periodic_1d_advector), intent(inout)  adv)
private

Definition at line 380 of file sll_m_advection_1d_CSL_periodic.F90.

◆ evaluate_hermite_1d()

real(kind=f64) function sll_m_advection_1d_csl_periodic::evaluate_hermite_1d ( real(kind=f64), intent(in)  x,
real(kind=f64), dimension(:), intent(in)  dof 
)
private

Definition at line 1536 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the caller graph for this function:

◆ initialize_csl_periodic_1d_advector()

subroutine sll_m_advection_1d_csl_periodic::initialize_csl_periodic_1d_advector ( class(csl_periodic_1d_advector), intent(inout)  adv,
class(sll_c_interpolator_1d), pointer  interp,
class(sll_c_characteristics_1d_base), pointer  charac,
integer(kind=i32), intent(in)  Npts,
real(kind=f64), intent(in), optional  eta_min,
real(kind=f64), intent(in), optional  eta_max,
real(kind=f64), dimension(:), optional, pointer  eta_coords,
integer(kind=i32), optional  csl_degree 
)
private

Definition at line 117 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the caller graph for this function:

◆ mult_circulant_mat()

subroutine sll_m_advection_1d_csl_periodic::mult_circulant_mat ( integer(kind=i32), intent(in)  N,
real(kind=f64), dimension(:), intent(in)  mat,
real(kind=f64), dimension(:), intent(inout)  f,
real(kind=f64), dimension(:), intent(in)  fft_buf 
)
private

Definition at line 578 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the caller graph for this function:

◆ sll_f_new_csl_periodic_1d_advector()

type(csl_periodic_1d_advector) function, pointer, public sll_m_advection_1d_csl_periodic::sll_f_new_csl_periodic_1d_advector ( class(sll_c_interpolator_1d), pointer  interp,
class(sll_c_characteristics_1d_base), pointer  charac,
integer(kind=i32), intent(in)  Npts,
real(kind=f64), intent(in), optional  eta_min,
real(kind=f64), intent(in), optional  eta_max,
real(kind=f64), dimension(:), optional, pointer  eta_coords,
integer(kind=i32), intent(in), optional  csl_degree 
)

Definition at line 84 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the call graph for this function:

◆ update_solution_csl_periodic()

subroutine sll_m_advection_1d_csl_periodic::update_solution_csl_periodic ( class(sll_c_interpolator_1d), pointer  interp,
real(kind=f64), dimension(:), intent(in)  input,
real(kind=f64), dimension(:, :), intent(inout)  deriv,
real(kind=f64), dimension(:), intent(in)  charac,
integer(kind=i32), intent(in)  Npts,
real(kind=f64), intent(in)  eta_min,
real(kind=f64), intent(in)  eta_max,
real(kind=f64), dimension(:), intent(out)  output,
integer(kind=i32), intent(in), optional  csl_degree 
)
private

Definition at line 907 of file sll_m_advection_1d_CSL_periodic.F90.

Here is the call graph for this function:
Here is the caller graph for this function:
    Report Typos and Errors