!!matvec with matmul
!#define __MATVEC_N(y,Mat,Vec) y=MATMUL(Mat,Vec)
!#define __MATVEC_T(y,Mat,Vec) y=MATMUL(Vec,Mat)
!#define __PMATVEC_N(fy,y,Mat,Vec) y=fyy+MATMUL(Mat,Vec)
!#define __PMATVEC_T(fy,y,Mat,Vec) y=fy y+MATMUL(Vec,Mat)
!#define __AMATVEC_N(y,fMat,Mat,Vec) y=fMatMATMUL(Mat,Vec)
!#define __AMATVEC_T(y,fMat,Mat,Vec) y=fMat MATMUL(Vec,Mat)
!#define __PAMATVEC_N(fy,y,fMat,Mat,Vec) y=fyy+fMat MATMUL(Mat,Vec)
!#define __PAMATVEC_T(fy,y,fMat,Mat,Vec) y=fyy+fMat MATMUL(Vec,Mat)
!!#define __GENERICMATVEC(NT,fy,y,fMat,Mat,Vec) CALL DGEMV(NT,SIZE(Mat,1),SIZE(Mat,2),fMat,Mat,SIZE(Mat,1),Vec,1,fy,y,1)
!!matmat with matmul
!#define __MATMAT_NN(Y,A,B) Y=MATMUL(A,B)
!#define __MATMAT_TN(Y,A,B) Y=MATMUL(TRANSPOSE(A),B)
!#define __MATMAT_NT(Y,A,B) Y=MATMUL(A,TRANSPOSE(B))
!#define __MATMAT_TT(Y,A,B) Y=TRANSPOSE(MATMUL(B,A))
!#define __PMATMAT_NN(fy,Y,A,B) Y=fyY+MATMUL(A,B)
!#define __PMATMAT_TN(fy,Y,A,B) Y=fy Y+MATMUL(TRANSPOSE(A),B)
!#define __PMATMAT_NT(fy,Y,A,B) Y=fyY+MATMUL(A,TRANSPOSE(B))
!#define __PMATMAT_TT(fy,Y,A,B) Y=fy Y+TRANSPOSE(MATMUL(B,A))
!#define __AMATMAT_NN(Y,fa,A,B) Y=faMATMUL(A,B)
!#define __AMATMAT_TN(Y,fa,A,B) Y=fa MATMUL(TRANSPOSE(A),B)
!#define __AMATMAT_NT(Y,fa,A,B) Y=faMATMUL(A,TRANSPOSE(B))
!#define __AMATMAT_TT(Y,fa,A,B) Y=fa TRANSPOSE(MATMUL(B,A))
!#define __PAMATMAT_NN(fy,Y,fa,A,B) Y=fyY+fa MATMUL(A,B)
!#define __PAMATMAT_TN(fy,Y,fa,A,B) Y=fyY+fa MATMUL(TRANSPOSE(A),B)
!#define __PAMATMAT_NT(fy,Y,fa,A,B) Y=fyY+fa MATMUL(A,TRANSPOSE(B))
!#define __PAMATMAT_TT(fy,Y,fa,A,B) Y=fyY+fa TRANSPOSE(MATMUL(B,A))
! GEMM does in general Y = fa A^?B^? + fy Y
! with structure: (m x n) = (m x k) (k x n)
! Y=A B : DGEMM('N','N',m,n,k,fa,Amat ,m, Bmat,k, fy,Y,m)
! Y=A^TB : DGEMM('T','N',m,n,k,fa,Amat ,k, Bmat,k, fy,Y,m)
! Y=A B^T : DGEMM('N','T',m,n,k,fa,Amat ,m, Bmat,n, fy,Y,m)
! Y=A^T*B^T : DGEMM('T','T',m,n,k,fa,Amat ,k, Bmat,n, fy,Y,m)
!#define __GENERICMATMAT_NN(fy,Y,fa,A,B) CALL DGEMM('N','N',SIZE(A,1),SIZE(B,2),SIZE(B,1),fa,A,SIZE(A,1),B,SIZE(B,1),fy,Y,SIZE(A,1))
!#define __GENERICMATMAT_TN(fy,Y,fa,A,B) CALL DGEMM('T','N',SIZE(A,2),SIZE(B,2),SIZE(B,1),fa,A,SIZE(B,1),B,SIZE(B,1),fy,Y,SIZE(A,2))
!#define __GENERICMATMAT_NT(fy,Y,fa,A,B) CALL DGEMM('N','T',SIZE(A,1),SIZE(B,1),SIZE(B,2),fa,A,SIZE(A,1),B,SIZE(B,1),fy,Y,SIZE(A,1))
!#define __GENERICMATMAT_TT(fy,Y,fa,A,B) CALL DGEMM('T','T',SIZE(A,2),SIZE(B,1),SIZE(B,2),fa,A,SIZE(B,2),B,SIZE(B,1),fy,Y,SIZE(A,2))
! SIMPLE INTERFACE FOR DGEMM, specifying nrows/ncols of mat A and nrows/ncols of mat B (for any transpose!)
! GEMM does in general Y = fa A^?B^? + fy Y
! with structure: (m x n) = (m x k) (k x n)
! Y=A B : DGEMM('N','N',m,n,k,fa,Amat ,m, Bmat,k, fy,Y,m)
! Y=A^TB : DGEMM('T','N',m,n,k,fa,Amat ,k, Bmat,k, fy,Y,m)
! Y=A B^T : DGEMM('N','T',m,n,k,fa,Amat ,m, Bmat,n, fy,Y,m)
! Y=A^T*B^T : DGEMM('T','T',m,n,k,fa,Amat ,k, Bmat,n, fy,Y,m)
sourcefile~~readstate_vars.f90~~EfferentGraph
sourcefile~readstate_vars.f90
readstate_vars.F90
sourcefile~base.f90
base.F90
sourcefile~readstate_vars.f90->sourcefile~base.f90
sourcefile~globals.f90
globals.F90
sourcefile~readstate_vars.f90->sourcefile~globals.f90
sourcefile~hmap.f90
hmap.F90
sourcefile~readstate_vars.f90->sourcefile~hmap.f90
sourcefile~sbase.f90
sbase.F90
sourcefile~readstate_vars.f90->sourcefile~sbase.f90
sourcefile~sgrid.f90
sgrid.F90
sourcefile~readstate_vars.f90->sourcefile~sgrid.f90
sourcefile~base.f90->sourcefile~globals.f90
sourcefile~base.f90->sourcefile~sbase.f90
sourcefile~base.f90->sourcefile~sgrid.f90
sourcefile~fbase.f90
fbase.F90
sourcefile~base.f90->sourcefile~fbase.f90
sourcefile~hmap.f90->sourcefile~globals.f90
sourcefile~c_hmap.f90
c_hmap.F90
sourcefile~hmap.f90->sourcefile~c_hmap.f90
sourcefile~hmap_axisnb.f90
hmap_axisNB.F90
sourcefile~hmap.f90->sourcefile~hmap_axisnb.f90
sourcefile~hmap_cyl.f90
hmap_cyl.F90
sourcefile~hmap.f90->sourcefile~hmap_cyl.f90
sourcefile~hmap_frenet.f90
hmap_frenet.F90
sourcefile~hmap.f90->sourcefile~hmap_frenet.f90
sourcefile~hmap_knot.f90
hmap_knot.F90
sourcefile~hmap.f90->sourcefile~hmap_knot.f90
sourcefile~hmap_rz.f90
hmap_RZ.F90
sourcefile~hmap.f90->sourcefile~hmap_rz.f90
sourcefile~sbase.f90->sourcefile~globals.f90
sourcefile~sbase.f90->sourcefile~sgrid.f90
sourcefile~basis1d.f90
basis1d.F90
sourcefile~sbase.f90->sourcefile~basis1d.f90
sourcefile~linalg.f90
linalg.F90
sourcefile~sbase.f90->sourcefile~linalg.f90
sourcefile~sll_m_boundary_condition_descriptors.f90
sll_m_boundary_condition_descriptors.F90
sourcefile~sbase.f90->sourcefile~sll_m_boundary_condition_descriptors.f90
sourcefile~sll_m_bsplines.f90
sll_m_bsplines.F90
sourcefile~sbase.f90->sourcefile~sll_m_bsplines.f90
sourcefile~sll_m_spline_interpolator_1d.f90
sll_m_spline_interpolator_1d.F90
sourcefile~sbase.f90->sourcefile~sll_m_spline_interpolator_1d.f90
sourcefile~sll_m_spline_matrix.f90
sll_m_spline_matrix.F90
sourcefile~sbase.f90->sourcefile~sll_m_spline_matrix.f90
sourcefile~sgrid.f90->sourcefile~globals.f90
sourcefile~basis1d.f90->sourcefile~globals.f90
sourcefile~basis1d.f90->sourcefile~linalg.f90
sourcefile~c_hmap.f90->sourcefile~globals.f90
sourcefile~fbase.f90->sourcefile~globals.f90
sourcefile~hmap_axisnb.f90->sourcefile~globals.f90
sourcefile~hmap_axisnb.f90->sourcefile~c_hmap.f90
sourcefile~hmap_axisnb.f90->sourcefile~fbase.f90
sourcefile~analyze_vars.f90
analyze_vars.F90
sourcefile~hmap_axisnb.f90->sourcefile~analyze_vars.f90
sourcefile~io_netcdf.f90
io_netcdf.F90
sourcefile~hmap_axisnb.f90->sourcefile~io_netcdf.f90
sourcefile~mod_mpi.f90
mod_mpi.F90
sourcefile~hmap_axisnb.f90->sourcefile~mod_mpi.f90
sourcefile~output_csv.f90
output_csv.F90
sourcefile~hmap_axisnb.f90->sourcefile~output_csv.f90
sourcefile~output_netcdf.f90
output_netcdf.F90
sourcefile~hmap_axisnb.f90->sourcefile~output_netcdf.f90
sourcefile~output_vtk.f90
output_vtk.F90
sourcefile~hmap_axisnb.f90->sourcefile~output_vtk.f90
sourcefile~readintools.f90
readintools.F90
sourcefile~hmap_axisnb.f90->sourcefile~readintools.f90
sourcefile~hmap_cyl.f90->sourcefile~globals.f90
sourcefile~hmap_cyl.f90->sourcefile~c_hmap.f90
sourcefile~hmap_cyl.f90->sourcefile~readintools.f90
sourcefile~hmap_frenet.f90->sourcefile~globals.f90
sourcefile~hmap_frenet.f90->sourcefile~c_hmap.f90
sourcefile~hmap_frenet.f90->sourcefile~analyze_vars.f90
sourcefile~hmap_frenet.f90->sourcefile~output_csv.f90
sourcefile~hmap_frenet.f90->sourcefile~output_netcdf.f90
sourcefile~hmap_frenet.f90->sourcefile~output_vtk.f90
sourcefile~hmap_frenet.f90->sourcefile~readintools.f90
sourcefile~hmap_knot.f90->sourcefile~globals.f90
sourcefile~hmap_knot.f90->sourcefile~c_hmap.f90
sourcefile~hmap_knot.f90->sourcefile~readintools.f90
sourcefile~hmap_rz.f90->sourcefile~globals.f90
sourcefile~hmap_rz.f90->sourcefile~c_hmap.f90
sourcefile~linalg.f90->sourcefile~globals.f90
sourcefile~sll_m_working_precision.f90
sll_m_working_precision.F90
sourcefile~sll_m_boundary_condition_descriptors.f90->sourcefile~sll_m_working_precision.f90
sourcefile~sll_m_assert.f90
sll_m_assert.F90
sourcefile~sll_m_bsplines.f90->sourcefile~sll_m_assert.f90
sourcefile~sll_m_bsplines_base.f90
sll_m_bsplines_base.F90
sourcefile~sll_m_bsplines.f90->sourcefile~sll_m_bsplines_base.f90
sourcefile~sll_m_bsplines_non_uniform.f90
sll_m_bsplines_non_uniform.F90
sourcefile~sll_m_bsplines.f90->sourcefile~sll_m_bsplines_non_uniform.f90
sourcefile~sll_m_bsplines_uniform.f90
sll_m_bsplines_uniform.F90
sourcefile~sll_m_bsplines.f90->sourcefile~sll_m_bsplines_uniform.f90
sourcefile~sll_m_errors.f90
sll_m_errors.F90
sourcefile~sll_m_bsplines.f90->sourcefile~sll_m_errors.f90
sourcefile~sll_m_bsplines.f90->sourcefile~sll_m_working_precision.f90
sourcefile~sll_m_spline_interpolator_1d.f90->sourcefile~sll_m_boundary_condition_descriptors.f90
sourcefile~sll_m_spline_interpolator_1d.f90->sourcefile~sll_m_spline_matrix.f90
sourcefile~sll_m_spline_interpolator_1d.f90->sourcefile~sll_m_assert.f90
sourcefile~sll_m_spline_interpolator_1d.f90->sourcefile~sll_m_bsplines_base.f90
sourcefile~sll_m_spline_interpolator_1d.f90->sourcefile~sll_m_errors.f90
sourcefile~sll_m_spline_1d.f90
sll_m_spline_1d.F90
sourcefile~sll_m_spline_interpolator_1d.f90->sourcefile~sll_m_spline_1d.f90
sourcefile~sll_m_spline_interpolator_1d.f90->sourcefile~sll_m_working_precision.f90
sourcefile~sll_m_spline_matrix.f90->sourcefile~sll_m_errors.f90
sourcefile~sll_m_spline_matrix_banded.f90
sll_m_spline_matrix_banded.F90
sourcefile~sll_m_spline_matrix.f90->sourcefile~sll_m_spline_matrix_banded.f90
sourcefile~sll_m_spline_matrix_base.f90
sll_m_spline_matrix_base.F90
sourcefile~sll_m_spline_matrix.f90->sourcefile~sll_m_spline_matrix_base.f90
sourcefile~sll_m_spline_matrix_dense.f90
sll_m_spline_matrix_dense.F90
sourcefile~sll_m_spline_matrix.f90->sourcefile~sll_m_spline_matrix_dense.f90
sourcefile~sll_m_spline_matrix.f90->sourcefile~sll_m_working_precision.f90
sourcefile~analyze_vars.f90->sourcefile~globals.f90
sourcefile~io_netcdf.f90->sourcefile~globals.f90
sourcefile~mod_mpi.f90->sourcefile~globals.f90
sourcefile~output_csv.f90->sourcefile~globals.f90
sourcefile~output_netcdf.f90->sourcefile~globals.f90
sourcefile~output_netcdf.f90->sourcefile~io_netcdf.f90
sourcefile~output_vtk.f90->sourcefile~globals.f90
sourcefile~readintools.f90->sourcefile~globals.f90
sourcefile~readintools.f90->sourcefile~mod_mpi.f90
sourcefile~sll_m_assert.f90->sourcefile~globals.f90
sourcefile~sll_m_bsplines_base.f90->sourcefile~sll_m_assert.f90
sourcefile~sll_m_bsplines_base.f90->sourcefile~sll_m_working_precision.f90
sourcefile~sll_m_bsplines_non_uniform.f90->sourcefile~sll_m_assert.f90
sourcefile~sll_m_bsplines_non_uniform.f90->sourcefile~sll_m_bsplines_base.f90
sourcefile~sll_m_bsplines_non_uniform.f90->sourcefile~sll_m_working_precision.f90
sourcefile~sll_m_bsplines_uniform.f90->sourcefile~sll_m_assert.f90
sourcefile~sll_m_bsplines_uniform.f90->sourcefile~sll_m_bsplines_base.f90
sourcefile~sll_m_bsplines_uniform.f90->sourcefile~sll_m_errors.f90
sourcefile~sll_m_bsplines_uniform.f90->sourcefile~sll_m_working_precision.f90
sourcefile~sll_m_spline_1d.f90->sourcefile~sll_m_assert.f90
sourcefile~sll_m_spline_1d.f90->sourcefile~sll_m_bsplines_base.f90
sourcefile~sll_m_spline_1d.f90->sourcefile~sll_m_working_precision.f90
sourcefile~sll_m_spline_matrix_banded.f90->sourcefile~sll_m_assert.f90
sourcefile~sll_m_spline_matrix_banded.f90->sourcefile~sll_m_errors.f90
sourcefile~sll_m_spline_matrix_banded.f90->sourcefile~sll_m_spline_matrix_base.f90
sourcefile~sll_m_spline_matrix_banded.f90->sourcefile~sll_m_working_precision.f90
sourcefile~sll_m_spline_matrix_base.f90->sourcefile~sll_m_working_precision.f90
sourcefile~sll_m_spline_matrix_dense.f90->sourcefile~sll_m_assert.f90
sourcefile~sll_m_spline_matrix_dense.f90->sourcefile~sll_m_errors.f90
sourcefile~sll_m_spline_matrix_dense.f90->sourcefile~sll_m_spline_matrix_base.f90
sourcefile~sll_m_spline_matrix_dense.f90->sourcefile~sll_m_working_precision.f90
Nodes of different colours represent the following:
Graph Key
Source File
Source File
This Page's Entity
This Page's Entity
Solid arrows point from a file to a file which it depends on. A file
is dependent upon another if the latter must be compiled before the former
can be.
sourcefile~~readstate_vars.f90~~AfferentGraph
sourcefile~readstate_vars.f90
readstate_vars.F90
sourcefile~gvec_post.f90
gvec_post.F90
sourcefile~gvec_post.f90->sourcefile~readstate_vars.f90
sourcefile~restart.f90
restart.F90
sourcefile~gvec_post.f90->sourcefile~restart.f90
sourcefile~mhd3d.f90
mhd3d.F90
sourcefile~gvec_post.f90->sourcefile~mhd3d.f90
sourcefile~gvec_to_jorek.f90
gvec_to_jorek.F90
sourcefile~gvec_to_jorek.f90->sourcefile~readstate_vars.f90
sourcefile~readstate.f90
readstate.F90
sourcefile~gvec_to_jorek.f90->sourcefile~readstate.f90
sourcefile~readstate.f90->sourcefile~readstate_vars.f90
sourcefile~restart.f90->sourcefile~readstate_vars.f90
sourcefile~restart.f90->sourcefile~readstate.f90
sourcefile~state.f90
state.F90
sourcefile~state.f90->sourcefile~readstate_vars.f90
sourcefile~state.f90->sourcefile~restart.f90
sourcefile~state.f90->sourcefile~mhd3d.f90
sourcefile~convert_gvec_to_jorek.f90
convert_gvec_to_jorek.F90
sourcefile~convert_gvec_to_jorek.f90->sourcefile~gvec_to_jorek.f90
sourcefile~mhd3d.f90->sourcefile~restart.f90
sourcefile~mhd3d_minimize.f90
mhd3d_minimize.F90
sourcefile~mhd3d.f90->sourcefile~mhd3d_minimize.f90
sourcefile~mhd3d_minimize.f90->sourcefile~restart.f90
sourcefile~run.f90
run.F90
sourcefile~run.f90->sourcefile~restart.f90
sourcefile~rungvec.f90
rungvec.F90
sourcefile~run.f90->sourcefile~rungvec.f90
sourcefile~rungvec.f90->sourcefile~restart.f90
sourcefile~rungvec.f90->sourcefile~mhd3d.f90
sourcefile~gvec.f90
gvec.F90
sourcefile~gvec.f90->sourcefile~rungvec.f90
Nodes of different colours represent the following:
Graph Key
Source File
Source File
This Page's Entity
This Page's Entity
Solid arrows point from a file to a file which it depends on. A file
is dependent upon another if the latter must be compiled before the former
can be.
Source Code
!===================================================================================================================================
! Copyright (c) 2025 GVEC Contributors, Max Planck Institute for Plasma Physics
! License: MIT
!===================================================================================================================================
#include "defines.FPP"
!===================================================================================================================================
!>
!!# Module ** Read State Variables **
!!
!!
!!
!===================================================================================================================================
MODULE MODgvec_ReadState_Vars
! MODULES
USE MODgvec_Globals , ONLY : wp
USE MODgvec_sgrid , ONLY : t_sgrid
USE MODgvec_base , ONLY : t_base
USE MODgvec_sbase , ONLY : t_sbase
USE MODgvec_hmap , ONLY : PP_T_HMAP
IMPLICIT NONE
PUBLIC
!-----------------------------------------------------------------------------------------------------------------------------------
! GLOBAL VARIABLES
INTEGER :: fileID_r , OutputLevel_r
#ifdef PP_WHICH_HMAP
TYPE ( PP_T_HMAP ), ALLOCATABLE :: hmap_r
#else
CLASS ( PP_T_HMAP ), ALLOCATABLE :: hmap_r
#endif
TYPE ( t_sgrid ) :: sgrid_r !! container for the grid of X1,X2,LA
CLASS ( t_sbase ), ALLOCATABLE :: sbase_prof !! container for base for profiles
CLASS ( t_base ), ALLOCATABLE :: X1_base_r !! container for base of X1
CLASS ( t_base ), ALLOCATABLE :: X2_base_r !! container for base of X2
CLASS ( t_base ), ALLOCATABLE :: LA_base_r !! container for base of LA
REAL ( wp ), ALLOCATABLE :: X1_r (:,:) !! spline x fourier coefs of solution X1
REAL ( wp ), ALLOCATABLE :: X2_r (:,:) !! spline x fourier coefs of solution X2
REAL ( wp ), ALLOCATABLE :: LA_r (:,:) !! spline x fourier coefs of solution LA
REAL ( wp ), ALLOCATABLE :: profiles_1d (:,:) !! spline coefficients for 1d profiles (using X1_base...needs to be improved!)
REAL ( wp ) :: a_minor , r_major , volume !! scalars: average minor and major radius, total volume
!===================================================================================================================================
END MODULE MODgvec_ReadState_Vars