Neko 0.9.1
A portable framework for high-order spectral element flow simulations
Loading...
Searching...
No Matches
cg_device::cg_device_t Type Referenceabstract

Device based preconditioned conjugate gradient method. More...

Inheritance diagram for cg_device::cg_device_t:
Collaboration diagram for cg_device::cg_device_t:

Public Member Functions

procedure, pass(thisinit (this, n, max_iter, m, rel_tol, abs_tol, monitor)
 Initialise a device based PCG solver.
 
procedure, pass(thisfree (this)
 Deallocate a device based PCG solver.
 
procedure, pass(thissolve (this, ax, x, f, n, coef, blst, gs_h, niter)
 Standard PCG solve.
 
procedure, pass(thissolve_coupled (this, ax, x, y, z, fx, fy, fz, n, coef, blstx, blsty, blstz, gs_h, niter)
 Standard PCG coupled solve.
 
procedure, pass(thisksp_init (this, max_iter, rel_tol, abs_tol, m, monitor)
 Base type constructor.
 
procedure, pass(thisksp_free (this)
 Base type destructor.
 
procedure, pass(thisset_pc (this, m)
 Set preconditioner.
 
procedure(ksp_method), deferred, pass solve (this, ax, x, f, n, coef, blst, gs_h, niter)
 Solve the system.
 
procedure(ksp_method_coupled), deferred, pass solve_coupled (this, ax, x, y, z, fx, fy, fz, n, coef, blstx, blsty, blstz, gs_h, niter)
 Solve the system (coupled version).
 
procedure, pass(thismonitor_start (this, name)
 Monitor start.
 
procedure, pass(thismonitor_stop (this)
 Monitor stop.
 
procedure, pass(thismonitor_iter (this, iter, rnorm)
 Monitor iteration.
 
procedure(ksp_t_free), deferred, pass free (this)
 Destructor.
 

Public Attributes

real(kind=rp), dimension(:), allocatable w
 
real(kind=rp), dimension(:), allocatable r
 
real(kind=rp), dimension(:), allocatable p
 
real(kind=rp), dimension(:), allocatable z
 
type(c_ptr) w_d = C_NULL_PTR
 
type(c_ptr) r_d = C_NULL_PTR
 
type(c_ptr) p_d = C_NULL_PTR
 
type(c_ptr) z_d = C_NULL_PTR
 
type(c_ptr) gs_event = C_NULL_PTR
 
class(pc_t), pointer m => null()
 Preconditioner.
 
real(kind=rp) rel_tol
 Relative tolerance.
 
real(kind=rp) abs_tol
 Absolute tolerance.
 
integer max_iter
 Maximum number of iterations.
 
class(pc_t), allocatable m_ident
 Internal preconditioner (Identity)
 
logical monitor
 Turn on/off monitoring.
 

Detailed Description

Definition at line 50 of file cg_device.f90.

Member Function/Subroutine Documentation

◆ free() [1/2]

procedure, pass(this) cg_device::cg_device_t::free ( class(cg_device_t), intent(inout this)

Definition at line 62 of file cg_device.f90.

◆ free() [2/2]

procedure(ksp_t_free), deferred, pass krylov::ksp_t::free ( class(ksp_t), intent(inout this)
pure virtualinherited

Definition at line 91 of file krylov.f90.

◆ init()

procedure, pass(this) cg_device::cg_device_t::init ( class(cg_device_t), intent(inout this,
integer, intent(in n,
integer, intent(in max_iter,
class(pc_t), intent(inout), optional, target  m,
real(kind=rp), intent(inout), optional  rel_tol,
real(kind=rp), intent(inout), optional  abs_tol,
logical, intent(in), optional  monitor 
)

Definition at line 61 of file cg_device.f90.

◆ ksp_free()

procedure, pass(this) krylov::ksp_t::ksp_free ( class(ksp_t), intent(inout this)
inherited

Definition at line 77 of file krylov.f90.

◆ ksp_init()

procedure, pass(this) krylov::ksp_t::ksp_init ( class(ksp_t), intent(inout), target  this,
integer, intent(in max_iter,
real(kind=rp), intent(in), optional  rel_tol,
real(kind=rp), intent(in), optional  abs_tol,
class(pc_t), intent(in), optional, target  m,
logical, intent(in), optional  monitor 
)
inherited
Parameters
objectThe object to be allocated.
nSize of the vectors the solver operates on.
type_nameThe name of the solver type.
max_iterThe maximum number of iterations
abstolThe absolute tolerance, optional.
MThe preconditioner, optional.
monitorEnable/disable monitoring, optional. Destroy an iterative Krylov type_name Constructor for the base type.
max_iterMaximum number of iterations.
rel_tolRelative tolarance for converence.
rel_tolAbsolute tolarance for converence.
MThe preconditioner.

Definition at line 75 of file krylov.f90.

◆ monitor_iter()

procedure, pass(this) krylov::ksp_t::monitor_iter ( class(ksp_t), intent(in this,
integer, intent(in iter,
real(kind=rp), intent(in rnorm 
)
inherited

Definition at line 89 of file krylov.f90.

◆ monitor_start()

procedure, pass(this) krylov::ksp_t::monitor_start ( class(ksp_t), intent(in this,
character(len=*)  name 
)
inherited

Definition at line 85 of file krylov.f90.

◆ monitor_stop()

procedure, pass(this) krylov::ksp_t::monitor_stop ( class(ksp_t), intent(in this)
inherited

Definition at line 87 of file krylov.f90.

◆ set_pc()

procedure, pass(this) krylov::ksp_t::set_pc ( class(ksp_t), intent(inout this,
class(pc_t), intent(in), target  m 
)
inherited
Parameters
MThe preconditioner.

Definition at line 79 of file krylov.f90.

◆ solve() [1/2]

procedure, pass(this) cg_device::cg_device_t::solve ( class(cg_device_t), intent(inout this,
class(ax_t), intent(inout ax,
type(field_t), intent(inout x,
real(kind=rp), dimension(n), intent(inout f,
integer, intent(in n,
type(coef_t), intent(inout coef,
type(bc_list_t), intent(inout blst,
type(gs_t), intent(inout gs_h,
integer, intent(in), optional  niter 
)

Definition at line 63 of file cg_device.f90.

◆ solve() [2/2]

procedure(ksp_method), deferred, pass krylov::ksp_t::solve ( class(ksp_t), intent(inout this,
class(ax_t), intent(inout ax,
type(field_t), intent(inout x,
real(kind=rp), dimension(n), intent(inout f,
integer, intent(in n,
type(coef_t), intent(inout coef,
type(bc_list_t), intent(inout blst,
type(gs_t), intent(inout gs_h,
integer, intent(in), optional  niter 
)
pure virtualinherited

Definition at line 81 of file krylov.f90.

◆ solve_coupled() [1/2]

procedure, pass(this) cg_device::cg_device_t::solve_coupled ( class(cg_device_t), intent(inout this,
class(ax_t), intent(inout ax,
type(field_t), intent(inout x,
type(field_t), intent(inout y,
type(field_t), intent(inout z,
real(kind=rp), dimension(n), intent(inout fx,
real(kind=rp), dimension(n), intent(inout fy,
real(kind=rp), dimension(n), intent(inout fz,
integer, intent(in n,
type(coef_t), intent(inout coef,
type(bc_list_t), intent(inout blstx,
type(bc_list_t), intent(inout blsty,
type(bc_list_t), intent(inout blstz,
type(gs_t), intent(inout gs_h,
integer, intent(in), optional  niter 
)

Definition at line 64 of file cg_device.f90.

◆ solve_coupled() [2/2]

procedure(ksp_method_coupled), deferred, pass krylov::ksp_t::solve_coupled ( class(ksp_t), intent(inout this,
class(ax_t), intent(inout ax,
type(field_t), intent(inout x,
type(field_t), intent(inout y,
type(field_t), intent(inout z,
real(kind=rp), dimension(n), intent(inout fx,
real(kind=rp), dimension(n), intent(inout fy,
real(kind=rp), dimension(n), intent(inout fz,
integer, intent(in n,
type(coef_t), intent(inout coef,
type(bc_list_t), intent(inout blstx,
type(bc_list_t), intent(inout blsty,
type(bc_list_t), intent(inout blstz,
type(gs_t), intent(inout gs_h,
integer, intent(in), optional  niter 
)
pure virtualinherited

Definition at line 83 of file krylov.f90.

Member Data Documentation

◆ abs_tol

real(kind=rp) krylov::ksp_t::abs_tol
inherited

Definition at line 69 of file krylov.f90.

◆ gs_event

type(c_ptr) cg_device::cg_device_t::gs_event = C_NULL_PTR

Definition at line 59 of file cg_device.f90.

◆ m

class(pc_t), pointer krylov::ksp_t::m => null()
inherited

Definition at line 67 of file krylov.f90.

◆ m_ident

class(pc_t), allocatable krylov::ksp_t::m_ident
inherited

Definition at line 71 of file krylov.f90.

◆ max_iter

integer krylov::ksp_t::max_iter
inherited

Definition at line 70 of file krylov.f90.

◆ monitor

logical krylov::ksp_t::monitor
inherited

Definition at line 72 of file krylov.f90.

◆ p

real(kind=rp), dimension(:), allocatable cg_device::cg_device_t::p

Definition at line 53 of file cg_device.f90.

◆ p_d

type(c_ptr) cg_device::cg_device_t::p_d = C_NULL_PTR

Definition at line 57 of file cg_device.f90.

◆ r

real(kind=rp), dimension(:), allocatable cg_device::cg_device_t::r

Definition at line 52 of file cg_device.f90.

◆ r_d

type(c_ptr) cg_device::cg_device_t::r_d = C_NULL_PTR

Definition at line 56 of file cg_device.f90.

◆ rel_tol

real(kind=rp) krylov::ksp_t::rel_tol
inherited

Definition at line 68 of file krylov.f90.

◆ w

real(kind=rp), dimension(:), allocatable cg_device::cg_device_t::w

Definition at line 51 of file cg_device.f90.

◆ w_d

type(c_ptr) cg_device::cg_device_t::w_d = C_NULL_PTR

Definition at line 55 of file cg_device.f90.

◆ z

real(kind=rp), dimension(:), allocatable cg_device::cg_device_t::z

Definition at line 54 of file cg_device.f90.

◆ z_d

type(c_ptr) cg_device::cg_device_t::z_d = C_NULL_PTR

Definition at line 58 of file cg_device.f90.


The documentation for this type was generated from the following file: