forked from szy21/pycles_GCM
-
Notifications
You must be signed in to change notification settings - Fork 0
/
PrognosticVariables.pxd
55 lines (51 loc) · 2.52 KB
/
PrognosticVariables.pxd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
from NetCDFIO cimport NetCDFIO_Stats
cimport Grid
cimport ParallelMPI
cimport ReferenceState
cimport Restart
cdef extern from "prognostic_variables.h":
struct VelocityDofs:
Py_ssize_t u
Py_ssize_t v
Py_ssize_t w
cdef extern from "prognostic_variables.h":
void build_buffer(Py_ssize_t nv, Py_ssize_t dim, Py_ssize_t s ,Grid.DimStruct *dims, double* values, double* buffer)
void buffer_to_values(Py_ssize_t dim, Py_ssize_t s, Grid.DimStruct *dims, double* values, double* buffer)
void set_bcs(Py_ssize_t dim, Py_ssize_t s, double bc_factor, Grid.DimStruct *dims, double* values)
void set_to_zero(Py_ssize_t nv, Grid.DimStruct *dims, double* values )
cdef class PrognosticVariables:
cdef:
dict name_index
dict units
dict nice_name
dict desc
list index_name
Py_ssize_t nv
Py_ssize_t nv_scalars
Py_ssize_t nv_velocities
cdef double [:] bc_type
cdef long [:] var_type
cdef double [:] values
cdef double [:] tendencies
cdef long [:] velocity_directions
list velocity_names_directional
cpdef add_variable(self, name,units, nice_name, desc, bc_type, var_type, ParallelMPI.ParallelMPI Pa)
cpdef initialize(self,Grid.Grid Gr, NetCDFIO_Stats NS, ParallelMPI.ParallelMPI Pa)
cdef:
void update_all_bcs(self, Grid.Grid Gr, ParallelMPI.ParallelMPI Pa)
cpdef Update_all_bcs(self,Grid.Grid Gr, ParallelMPI.ParallelMPI Pa)
cpdef debug(self, Grid.Grid Gr, ReferenceState.ReferenceState RS ,NetCDFIO_Stats NS, ParallelMPI.ParallelMPI Pa)
cpdef debug_large_tend(self, Grid.Grid Gr, ReferenceState.ReferenceState RS ,NetCDFIO_Stats NS, ParallelMPI.ParallelMPI Pa, str message)
cpdef set_velocity_direction(self,name,Py_ssize_t direction,ParallelMPI.ParallelMPI Pa)
cdef inline Py_ssize_t get_nv(self, str variable_name):
return self.name_index[variable_name]
cdef inline Py_ssize_t get_varshift(self, Grid.Grid Gr, str variable_name):
return self.name_index[variable_name] * Gr.dims.npg
cpdef get_variable_array(self,name,Grid.Grid Gr)
cpdef get_tendency_array(self,name,Grid.Grid Gr)
cpdef tend_nan(self,PA,message)
cpdef val_nan(self,PA,message)
cpdef val_bounds(self,var_name,Grid.Grid Gr)
cpdef stats_io(self, Grid.Grid Gr, ReferenceState.ReferenceState RS, NetCDFIO_Stats NS, ParallelMPI.ParallelMPI Pa)
cpdef restart(self, Grid.Grid Gr, Restart.Restart Re)
cpdef init_from_restart(self, Grid.Grid Gr, Restart.Restart Re)