Ice Sheet System Model  4.18
Code documentation
Seg.h
Go to the documentation of this file.
1 
5 #ifndef _SEG_H_
6 #define _SEG_H_
7 
8 /*Headers:*/
9 /*{{{*/
10 #include "./Element.h"
11 #include "./ElementHook.h"
12 #include "./SegRef.h"
13 class Parameters;
14 class Inputs;
15 class IoModel;
16 class Results;
17 class Node;
18 class Material;
19 class ElementMatrix;
20 class ElementVector;
21 class Vertex;
22 
23 #include "../../shared/Exceptions/exceptions.h"
24 #include "../../shared/Enum/Enum.h"
25 /*}}}*/
26 
27 class Seg: public Element,public ElementHook,public SegRef{
28 
29  public:
31  int collapsed_ids[2];
32 
33  /*Seg constructors, destructors {{{*/
34  Seg(){};
35  Seg(int seg_id,int seg_sid,int seg_lid,IoModel* iomodel,int nummodels);
36  ~Seg();
37  /*}}}*/
38  /*Object virtual functions definitions:{{{ */
39  Object *copy();
40  void Marshall(char** pmarshalled_data,int* pmarshalled_data_size, int marshall_direction);
41  int ObjectEnum();
42  /*}}}*/
43  /*Element virtual functions definitions: {{{*/
44  void AverageOntoPartition(Vector<IssmDouble>* partition_contributions,Vector<IssmDouble>* partition_areas,IssmDouble* vertex_response,IssmDouble* qmu_part){_error_("not implemented yet");};
45  void CalvingRateLevermann(void){_error_("not implemented yet");};
47  void ComputeDeviatoricStressTensor(){_error_("not implemented yet");};
48  void ComputeEsaStrainAndVorticity(){_error_("not implemented yet!");};
49  void ComputeSigmaNN(){_error_("not implemented yet");};
50  void ComputeStressTensor(){_error_("not implemented yet");};
51  void Configure(Elements* elements,Loads* loads,Nodes* nodesin,Vertices* verticesin,Materials* materials,Parameters* parameters,Inputs2* inputs2in){_error_("not implemented yet");};
52  void ControlInputSetGradient(IssmDouble* gradient,int enum_type,int control_index,int offset,int N,int M){_error_("not implemented yet");};
53  void ControlInputSetGradient(IssmDouble* gradient,int enum_type,int control_index){_error_("not implemented yet");};
54  void ControlToVectors(Vector<IssmPDouble>* vector_control, Vector<IssmPDouble>* vector_gradient,int control_enum){_error_("not implemented yet");};
55  void ElementResponse(IssmDouble* presponse,int response_enum){_error_("not implemented yet");};
56  void ElementSizes(IssmDouble* hx,IssmDouble* hy,IssmDouble* hz){_error_("not implemented yet");};
57  int FiniteElement(void);
58  IssmDouble FloatingArea(bool scaled){_error_("not implemented yet");};
59  void FSContactMigration(Vector<IssmDouble>* vertexgrounded,Vector<IssmDouble>* vertexfloating){_error_("not implemented yet");};
60  Element* GetBasalElement(void){_error_("not implemented yet");};
61  int GetElementType(void){_error_("not implemented yet");};
62  void GetGroundedPart(int* point1,IssmDouble* fraction1, IssmDouble* fraction2,bool* mainlyfloating){_error_("not implemented yet");};
64  void GetIcefrontCoordinates(IssmDouble** pxyz_front,IssmDouble* xyz_list,int levelsetenum);
65  Input2* GetInput2(int enumtype);
66  Input2* GetInput2(int enumtype,IssmDouble time);
67  Input2* GetInput2(int inputenum,IssmDouble start_time,IssmDouble end_time,int averaging_method){_error_("not implemented yet!");};
68  void GetInputListOnVertices(IssmDouble* pvalue,Input2* input,IssmDouble default_value);
69  void GetInputListOnNodes(IssmDouble* pvalue,Input2* input,IssmDouble default_value);
70  void GetInputValue(IssmDouble* pvalue,Vertex* vertex,int enumtype){_error_("not implemented yet");};
71  void GetLevelCoordinates(IssmDouble** pxyz_front,IssmDouble* xyz_list,int levelsetenum,IssmDouble level){_error_("not implemented");};
72  void GetLevelsetPositivePart(int* point1,IssmDouble* fraction1,IssmDouble* fraction2, bool* mainlynegative,IssmDouble* levelsetvalues){_error_("not implemented yet");};
73  int GetNumberOfNodes(void);
74  int GetNumberOfNodes(int enum_type){_error_("not implemented yet");};
75  int GetNumberOfVertices(void);
76  void GetVectorFromControlInputs(Vector<IssmDouble>* gradient,int control_enum,int control_index,const char* data,int offset){_error_("not implemented yet");};
77  void GetVectorFromControlInputs(Vector<IssmDouble>* gradient,int control_enum,int control_index,const char* data){_error_("not implemented yet");};
78  void GetVerticesCoordinates(IssmDouble** pxyz_list);
79  void GetVerticesCoordinatesBase(IssmDouble** pxyz_list){_error_("not implemented yet");};
80  void GetVerticesCoordinatesTop(IssmDouble** pxyz_list){_error_("not implemented yet");};
81  IssmDouble GroundedArea(bool scaled){_error_("not implemented yet");};
82  IssmDouble IceVolume(bool scaled){_error_("not implemented yet");};
83  IssmDouble IceVolumeAboveFloatation(bool scaled){_error_("not implemented yet");};
84  void InputDepthAverageAtBase(int enum_type,int average_enum_type){_error_("not implemented yet");};
85  void InputExtrude(int enum_type,int start){_error_("not implemented"); /*For penta only*/};
86  void InputUpdateFromIoModel(int index, IoModel* iomodel){_error_("not implemented yet");};
87  void InputUpdateFromSolutionOneDof(IssmDouble* solution,int inputenum){_error_("not implemented yet");};
88  void InputUpdateFromSolutionOneDofCollapsed(IssmDouble* solution,int inputenum){_error_("not implemented yet");};
89  void InputUpdateFromVector(IssmDouble* vector, int name, int type){_error_("not implemented yet");};
90  bool IsFaceOnBoundary(void){_error_("not implemented yet");};
91  bool IsIcefront(void);
92  bool IsNodeOnShelfFromFlags(IssmDouble* flags){_error_("not implemented yet");};
93  bool IsZeroLevelset(int levelset_enum){_error_("not implemented");};
94  void JacobianDeterminant(IssmDouble* Jdet, IssmDouble* xyz_list,Gauss* gauss);
95  void JacobianDeterminantBase(IssmDouble* pJdet,IssmDouble* xyz_list_base,Gauss* gauss){_error_("not implemented yet");};
96  void JacobianDeterminantLine(IssmDouble* Jdet, IssmDouble* xyz_list,Gauss* gauss){_error_("not implemented yet");};
97  void JacobianDeterminantSurface(IssmDouble* pJdet, IssmDouble* xyz_list,Gauss* gauss);
98  void JacobianDeterminantTop(IssmDouble* pJdet,IssmDouble* xyz_list_base,Gauss* gauss){_error_("not implemented yet");};
99  IssmDouble Masscon(IssmDouble* levelset){_error_("not implemented yet");};
100  IssmDouble MassFlux(IssmDouble* segment){_error_("not implemented yet");};
101  IssmDouble MassFlux(IssmDouble x1,IssmDouble y1, IssmDouble x2, IssmDouble y2,int segment_id){_error_("not implemented yet");}
102  void MaterialUpdateFromTemperature(void){_error_("not implemented yet");};
103  IssmDouble MinEdgeLength(IssmDouble* xyz_list){_error_("not implemented yet");};
104  IssmDouble Misfit(int modelenum,int observationenum,int weightsenum){_error_("not implemented yet");};
105  IssmDouble MisfitArea(int weightsenum){_error_("not implemented yet");};
106  Gauss* NewGauss(void);
107  Gauss* NewGauss(int order);
108  Gauss* NewGauss(IssmDouble* xyz_list, IssmDouble* xyz_list_front,int order);
109  Gauss* NewGauss(IssmDouble* xyz_list, IssmDouble* xyz_list_front,int order_horiz,int order_vert){_error_("not implemented yet");};
110  Gauss* NewGauss(int point1,IssmDouble fraction1,IssmDouble fraction2,bool mainlyfloating,int order){_error_("not implemented yet");};
111  Gauss* NewGauss(int point1,IssmDouble fraction1,IssmDouble fraction2,int order){_error_("not implemented yet");};
112  Gauss* NewGaussBase(int order){_error_("not implemented yet");};
113  Gauss* NewGaussLine(int vertex1,int vertex2,int order){_error_("not implemented yet");};
114  Gauss* NewGaussTop(int order){_error_("not implemented yet");};
115  int NodalValue(IssmDouble* pvalue, int index, int natureofdataenum){_error_("not implemented yet");};
116  void NodalFunctions(IssmDouble* basis,Gauss* gauss);
117  void NodalFunctionsDerivatives(IssmDouble* dbasis,IssmDouble* xyz_list,Gauss* gauss);
118  void NodalFunctionsDerivativesVelocity(IssmDouble* dbasis,IssmDouble* xyz_list,Gauss* gauss){_error_("not implemented yet");};
119  void NodalFunctionsMINIDerivatives(IssmDouble* dbasis,IssmDouble* xyz_list,Gauss* gauss){_error_("not implemented yet");};
120  void NodalFunctionsPressure(IssmDouble* basis,Gauss* gauss){_error_("not implemented yet");};
121  void NodalFunctionsP1(IssmDouble* basis,Gauss* gauss);
122  void NodalFunctionsP1Derivatives(IssmDouble* dbasis,IssmDouble* xyz_list,Gauss* gauss){_error_("not implemented yet");};
123  void NodalFunctionsP2(IssmDouble* basis,Gauss* gauss);
124  void NodalFunctionsTensor(IssmDouble* basis,Gauss* gauss){_error_("not implemented yet");};
125  void NodalFunctionsVelocity(IssmDouble* basis,Gauss* gauss){_error_("not implemented yet");};
126  void NormalBase(IssmDouble* normal,IssmDouble* xyz_list){_error_("not implemented yet");};
127  void NormalSection(IssmDouble* normal,IssmDouble* xyz_list);
128  void NormalTop(IssmDouble* normal,IssmDouble* xyz_list){_error_("not implemented yet");};
129  int NumberofNodesPressure(void){_error_("not implemented yet");};
130  int NumberofNodesVelocity(void){_error_("not implemented yet");};
131  void PotentialUngrounding(Vector<IssmDouble>* potential_sheet_ungrounding){_error_("not implemented yet");};
132  int PressureInterpolation(void){_error_("not implemented yet");};
133  void ReduceMatrices(ElementMatrix* Ke,ElementVector* pe){_error_("not implemented yet");};
134  void ResetFSBasalBoundaryCondition(void){_error_("not implemented yet");};
135  void ResetHooks(){_error_("not implemented yet");};
136  void SetControlInputsFromVector(IssmDouble* vector,int control_enum,int control_index,int offset,int N,int M){_error_("not implemented yet");};
137  void SetControlInputsFromVector(IssmDouble* vector,int control_enum,int control_index){_error_("not implemented yet");};
138  void SetCurrentConfiguration(Elements* elements,Loads* loads,Nodes* nodes,Materials* materials,Parameters* parameters){_error_("not implemented yet");};
139  void SetTemporaryElementType(int element_type_in){_error_("not implemented yet");};
140  Element* SpawnBasalElement(void){_error_("not implemented yet");};
141  Element* SpawnTopElement(void){_error_("not implemented yet");};
142  IssmDouble StabilizationParameter(IssmDouble u, IssmDouble v, IssmDouble w, IssmDouble diameter, IssmDouble kappa){_error_("not implemented yet");};
143  void StabilizationParameterAnisotropic(IssmDouble* tau_parameter_anisotropic, IssmDouble u, IssmDouble v, IssmDouble w, IssmDouble hx, IssmDouble hy, IssmDouble hz, IssmDouble kappa){_error_("not implemented yet");};
144  void StrainRateparallel(void){_error_("not implemented yet");};
145  void StrainRateperpendicular(void){_error_("not implemented yet");};
146  void StressIntensityFactor(void){_error_("not implemented yet");};
147  IssmDouble SurfaceArea(void){_error_("not implemented yet");};
148  int TensorInterpolation(void){_error_("not implemented yet");};
149  IssmDouble TimeAdapt(){_error_("not implemented yet");};
150  IssmDouble TotalFloatingBmb(bool scaled){_error_("not implemented yet");};
151  IssmDouble TotalGroundedBmb(bool scaled){_error_("not implemented yet");};
152  IssmDouble TotalSmb(bool scaled){_error_("not implemented yet");};
153  void Update(Inputs2* inputs2,int index, IoModel* iomodel,int analysis_counter,int analysis_type,int finitelement){_error_("not implemented yet");};
154  void UpdateConstraintsExtrudeFromBase(){_error_("not implemented");};
155  void UpdateConstraintsExtrudeFromTop(){_error_("not implemented");};
156  int UpdatePotentialUngrounding(IssmDouble* vertices_potentially_ungrounding,Vector<IssmDouble>* vec_nodes_on_iceshelf,IssmDouble* nodes_on_iceshelf){_error_("not implemented yet");};
157  void ValueP1DerivativesOnGauss(IssmDouble* dvalue,IssmDouble* values,IssmDouble* xyz_list,Gauss* gauss){_error_("not implemented yet");};
158  void ValueP1OnGauss(IssmDouble* pvalue,IssmDouble* values,Gauss* gauss){_error_("not implemented yet");};
159  int VelocityInterpolation(void){_error_("not implemented yet");};
160  int VertexConnectivity(int vertexindex){_error_("not implemented yet");};
161  void VerticalSegmentIndices(int** pindices,int* pnumseg){_error_("not implemented yet");};
162  void VerticalSegmentIndicesBase(int** pindices,int* pnumseg){_error_("not implemented yet");};
163  IssmDouble GetArea3D(void){_error_("not implemented yet!");};
164  IssmDouble GetAreaSpherical(void){_error_("not implemented yet!");};
165 
166 #ifdef _HAVE_GIA_
167  void GiaDeflection(Vector<IssmDouble>* wg,Vector<IssmDouble>* dwgdt,IssmDouble* x,IssmDouble* y){_error_("not implemented yet");};
168 #endif
169 #ifdef _HAVE_ESA_
170  void EsaGeodetic2D(Vector<IssmDouble>* pUp,Vector<IssmDouble>* pNorth,Vector<IssmDouble>* pEast,Vector<IssmDouble>* pX,Vector<IssmDouble>* pY,IssmDouble* xx,IssmDouble* yy){_error_("not implemented yet!");};
171  void EsaGeodetic3D(Vector<IssmDouble>* pUp,Vector<IssmDouble>* pNorth,Vector<IssmDouble>* pEast,IssmDouble* latitude,IssmDouble* longitude,IssmDouble* radius,IssmDouble* xx,IssmDouble* yy,IssmDouble* zz){_error_("not implemented yet!");};
172 #endif
173 #ifdef _HAVE_SEALEVELRISE_
174  void SealevelriseMomentOfInertia(IssmDouble* dI_list,IssmDouble* Sg_old, SealevelMasks* masks){_error_("not implemented yet!");};
175  void SetSealevelMasks(SealevelMasks* masks){_error_("not implemented yet!");};
176  void SealevelriseGeometry(IssmDouble* latitude,IssmDouble* longitude,IssmDouble* radius,IssmDouble* xx, IssmDouble* yy, IssmDouble* zz){_error_("not implemented yet!");};
177  void SealevelriseEustatic(IssmDouble* Sgi, IssmDouble* peustatic, SealevelMasks* masks,IssmDouble oceanarea){_error_("not implemented yet!");};
178  void SealevelriseNonEustatic(IssmDouble* Sgo,IssmDouble* Sg_old, SealevelMasks* masks){_error_("not implemented yet!");};
179  void SealevelriseGeodetic(IssmDouble* Up, IssmDouble* North, IssmDouble* East, IssmDouble* Sg, SealevelMasks* masks){_error_("not implemented yet!");};
180  IssmDouble OceanAverage(IssmDouble* Sg, SealevelMasks* masks){_error_("not implemented yet!");};
181 #endif
182 
183 #ifdef _HAVE_DAKOTA_
184  void InputUpdateFromMatrixDakota(IssmDouble* matrix, int nows, int ncols, int name, int type){_error_("not implemented yet");};
185  void InputUpdateFromVectorDakota(IssmDouble* vector, int name, int type){_error_("not implemented yet");};
186 #endif
187  /*}}}*/
188 };
189 #endif /* _SEG_H */
Seg::ElementSizes
void ElementSizes(IssmDouble *hx, IssmDouble *hy, IssmDouble *hz)
Definition: Seg.h:56
Vertices
Declaration of Vertices class.
Definition: Vertices.h:15
Seg::ComputeStressTensor
void ComputeStressTensor()
Definition: Seg.h:50
Seg::NewGauss
Gauss * NewGauss(int point1, IssmDouble fraction1, IssmDouble fraction2, int order)
Definition: Seg.h:111
Seg::Marshall
void Marshall(char **pmarshalled_data, int *pmarshalled_data_size, int marshall_direction)
Definition: Seg.cpp:122
IssmDouble
double IssmDouble
Definition: types.h:37
Nodes
Declaration of Nodes class.
Definition: Nodes.h:19
Seg::ValueP1DerivativesOnGauss
void ValueP1DerivativesOnGauss(IssmDouble *dvalue, IssmDouble *values, IssmDouble *xyz_list, Gauss *gauss)
Definition: Seg.h:157
Seg::NormalSection
void NormalSection(IssmDouble *normal, IssmDouble *xyz_list)
Definition: Seg.cpp:429
Seg::IsFaceOnBoundary
bool IsFaceOnBoundary(void)
Definition: Seg.h:90
Seg::SetControlInputsFromVector
void SetControlInputsFromVector(IssmDouble *vector, int control_enum, int control_index)
Definition: Seg.h:137
Seg::Update
void Update(Inputs2 *inputs2, int index, IoModel *iomodel, int analysis_counter, int analysis_type, int finitelement)
Definition: Seg.h:153
Seg::Seg
Seg()
Definition: Seg.h:34
Seg::GetVectorFromControlInputs
void GetVectorFromControlInputs(Vector< IssmDouble > *gradient, int control_enum, int control_index, const char *data, int offset)
Definition: Seg.h:76
Seg::TimeAdapt
IssmDouble TimeAdapt()
Definition: Seg.h:149
Seg::NodalFunctionsPressure
void NodalFunctionsPressure(IssmDouble *basis, Gauss *gauss)
Definition: Seg.h:120
Seg::GetElementType
int GetElementType(void)
Definition: Seg.h:61
Parameters
Declaration of Parameters class.
Definition: Parameters.h:18
Seg::NumberofNodesPressure
int NumberofNodesPressure(void)
Definition: Seg.h:129
Seg::NewGauss
Gauss * NewGauss(IssmDouble *xyz_list, IssmDouble *xyz_list_front, int order_horiz, int order_vert)
Definition: Seg.h:109
Seg::NormalTop
void NormalTop(IssmDouble *normal, IssmDouble *xyz_list)
Definition: Seg.h:128
Seg::collapsed_ids
int collapsed_ids[2]
Definition: Seg.h:31
SegRef
Definition: SegRef.h:12
Seg::iscollapsed
int iscollapsed
Definition: Seg.h:30
Seg::GetVectorFromControlInputs
void GetVectorFromControlInputs(Vector< IssmDouble > *gradient, int control_enum, int control_index, const char *data)
Definition: Seg.h:77
Elements
Declaration of Elements class.
Definition: Elements.h:17
Seg::NodalFunctionsP2
void NodalFunctionsP2(IssmDouble *basis, Gauss *gauss)
Definition: Seg.cpp:422
Seg::NormalBase
void NormalBase(IssmDouble *normal, IssmDouble *xyz_list)
Definition: Seg.h:126
Material
Definition: Material.h:21
Seg::StressIntensityFactor
void StressIntensityFactor(void)
Definition: Seg.h:146
Seg::UpdateConstraintsExtrudeFromBase
void UpdateConstraintsExtrudeFromBase()
Definition: Seg.h:154
Seg::NodalFunctionsDerivatives
void NodalFunctionsDerivatives(IssmDouble *dbasis, IssmDouble *xyz_list, Gauss *gauss)
Definition: Seg.cpp:408
Seg::VerticalSegmentIndicesBase
void VerticalSegmentIndicesBase(int **pindices, int *pnumseg)
Definition: Seg.h:162
Seg::NewGaussLine
Gauss * NewGaussLine(int vertex1, int vertex2, int order)
Definition: Seg.h:113
Seg::NewGauss
Gauss * NewGauss(int point1, IssmDouble fraction1, IssmDouble fraction2, bool mainlyfloating, int order)
Definition: Seg.h:110
ElementHook
Definition: ElementHook.h:11
Seg::GetGroundedPortion
IssmDouble GetGroundedPortion(IssmDouble *xyz_list)
Definition: Seg.cpp:257
Seg::Misfit
IssmDouble Misfit(int modelenum, int observationenum, int weightsenum)
Definition: Seg.h:104
Seg::NodalValue
int NodalValue(IssmDouble *pvalue, int index, int natureofdataenum)
Definition: Seg.h:115
Seg::ResetHooks
void ResetHooks()
Definition: Seg.h:135
Element::nodes
Node ** nodes
Definition: Element.h:48
Element
Definition: Element.h:41
Seg::MinEdgeLength
IssmDouble MinEdgeLength(IssmDouble *xyz_list)
Definition: Seg.h:103
Seg::copy
Object * copy()
Definition: Seg.cpp:59
Element.h
abstract class for Element object This class is a place holder for the Tria and the Penta elements....
Seg::NodalFunctionsVelocity
void NodalFunctionsVelocity(IssmDouble *basis, Gauss *gauss)
Definition: Seg.h:125
Object
Definition: Object.h:13
Seg::NodalFunctions
void NodalFunctions(IssmDouble *basis, Gauss *gauss)
Definition: Seg.cpp:401
SegRef.h
abstract class for handling Seg oriented routines, like nodal functions, strain rate generation,...
Seg::NodalFunctionsTensor
void NodalFunctionsTensor(IssmDouble *basis, Gauss *gauss)
Definition: Seg.h:124
Seg::NewGaussBase
Gauss * NewGaussBase(int order)
Definition: Seg.h:112
Seg::GetLevelsetPositivePart
void GetLevelsetPositivePart(int *point1, IssmDouble *fraction1, IssmDouble *fraction2, bool *mainlynegative, IssmDouble *levelsetvalues)
Definition: Seg.h:72
Element::inputs2
Inputs2 * inputs2
Definition: Element.h:47
Materials
Declaration of Materials class.
Definition: Materials.h:16
Seg::ControlInputSetGradient
void ControlInputSetGradient(IssmDouble *gradient, int enum_type, int control_index)
Definition: Seg.h:53
Seg::NumberofNodesVelocity
int NumberofNodesVelocity(void)
Definition: Seg.h:130
Seg::CharacteristicLength
IssmDouble CharacteristicLength(void)
Definition: Seg.cpp:142
Seg::NodalFunctionsP1
void NodalFunctionsP1(IssmDouble *basis, Gauss *gauss)
Definition: Seg.cpp:415
Seg::StabilizationParameterAnisotropic
void StabilizationParameterAnisotropic(IssmDouble *tau_parameter_anisotropic, IssmDouble u, IssmDouble v, IssmDouble w, IssmDouble hx, IssmDouble hy, IssmDouble hz, IssmDouble kappa)
Definition: Seg.h:143
Seg::GroundedArea
IssmDouble GroundedArea(bool scaled)
Definition: Seg.h:81
Seg::GetNumberOfNodes
int GetNumberOfNodes(void)
Definition: Seg.cpp:286
Seg::GetAreaSpherical
IssmDouble GetAreaSpherical(void)
Definition: Seg.h:164
Seg::PressureInterpolation
int PressureInterpolation(void)
Definition: Seg.h:132
Seg::VerticalSegmentIndices
void VerticalSegmentIndices(int **pindices, int *pnumseg)
Definition: Seg.h:161
Seg::GetNumberOfNodes
int GetNumberOfNodes(int enum_type)
Definition: Seg.h:74
Seg::GetArea3D
IssmDouble GetArea3D(void)
Definition: Seg.h:163
Seg::VertexConnectivity
int VertexConnectivity(int vertexindex)
Definition: Seg.h:160
Seg::MaterialUpdateFromTemperature
void MaterialUpdateFromTemperature(void)
Definition: Seg.h:102
Inputs2
Declaration of Inputs class.
Definition: Inputs2.h:23
Seg::UpdateConstraintsExtrudeFromTop
void UpdateConstraintsExtrudeFromTop()
Definition: Seg.h:155
Seg::GetVerticesCoordinatesBase
void GetVerticesCoordinatesBase(IssmDouble **pxyz_list)
Definition: Seg.h:79
Seg::GetIcefrontCoordinates
void GetIcefrontCoordinates(IssmDouble **pxyz_front, IssmDouble *xyz_list, int levelsetenum)
Definition: Seg.cpp:159
Seg::SetCurrentConfiguration
void SetCurrentConfiguration(Elements *elements, Loads *loads, Nodes *nodes, Materials *materials, Parameters *parameters)
Definition: Seg.h:138
Seg::UpdatePotentialUngrounding
int UpdatePotentialUngrounding(IssmDouble *vertices_potentially_ungrounding, Vector< IssmDouble > *vec_nodes_on_iceshelf, IssmDouble *nodes_on_iceshelf)
Definition: Seg.h:156
Seg::IsIcefront
bool IsIcefront(void)
Definition: Seg.cpp:343
Seg::GetLevelCoordinates
void GetLevelCoordinates(IssmDouble **pxyz_front, IssmDouble *xyz_list, int levelsetenum, IssmDouble level)
Definition: Seg.h:71
Seg::GetGroundedPart
void GetGroundedPart(int *point1, IssmDouble *fraction1, IssmDouble *fraction2, bool *mainlyfloating)
Definition: Seg.h:62
Input2
Definition: Input2.h:18
Seg::FloatingArea
IssmDouble FloatingArea(bool scaled)
Definition: Seg.h:58
Seg::ResetFSBasalBoundaryCondition
void ResetFSBasalBoundaryCondition(void)
Definition: Seg.h:134
Seg::TotalFloatingBmb
IssmDouble TotalFloatingBmb(bool scaled)
Definition: Seg.h:150
Seg
Definition: Seg.h:27
Seg::CalvingRateLevermann
void CalvingRateLevermann(void)
Definition: Seg.h:45
Seg::ValueP1OnGauss
void ValueP1OnGauss(IssmDouble *pvalue, IssmDouble *values, Gauss *gauss)
Definition: Seg.h:158
Seg::GetInputListOnVertices
void GetInputListOnVertices(IssmDouble *pvalue, Input2 *input, IssmDouble default_value)
Definition: Seg.cpp:303
Seg::TotalSmb
IssmDouble TotalSmb(bool scaled)
Definition: Seg.h:152
Seg::ObjectEnum
int ObjectEnum()
Definition: Seg.cpp:442
Seg::SetTemporaryElementType
void SetTemporaryElementType(int element_type_in)
Definition: Seg.h:139
Seg::IsNodeOnShelfFromFlags
bool IsNodeOnShelfFromFlags(IssmDouble *flags)
Definition: Seg.h:92
Seg::MassFlux
IssmDouble MassFlux(IssmDouble x1, IssmDouble y1, IssmDouble x2, IssmDouble y2, int segment_id)
Definition: Seg.h:101
Loads
Declaration of Loads class.
Definition: Loads.h:16
Seg::MisfitArea
IssmDouble MisfitArea(int weightsenum)
Definition: Seg.h:105
Seg::StrainRateparallel
void StrainRateparallel(void)
Definition: Seg.h:144
Node
Definition: Node.h:23
Seg::TotalGroundedBmb
IssmDouble TotalGroundedBmb(bool scaled)
Definition: Seg.h:151
_error_
#define _error_(StreamArgs)
Definition: exceptions.h:49
Seg::IceVolumeAboveFloatation
IssmDouble IceVolumeAboveFloatation(bool scaled)
Definition: Seg.h:83
Seg::NodalFunctionsDerivativesVelocity
void NodalFunctionsDerivativesVelocity(IssmDouble *dbasis, IssmDouble *xyz_list, Gauss *gauss)
Definition: Seg.h:118
Element::parameters
Parameters * parameters
Definition: Element.h:51
Seg::IceVolume
IssmDouble IceVolume(bool scaled)
Definition: Seg.h:82
Seg::ControlToVectors
void ControlToVectors(Vector< IssmPDouble > *vector_control, Vector< IssmPDouble > *vector_gradient, int control_enum)
Definition: Seg.h:54
Seg::NewGaussTop
Gauss * NewGaussTop(int order)
Definition: Seg.h:114
Seg::SetControlInputsFromVector
void SetControlInputsFromVector(IssmDouble *vector, int control_enum, int control_index, int offset, int N, int M)
Definition: Seg.h:136
Seg::JacobianDeterminant
void JacobianDeterminant(IssmDouble *Jdet, IssmDouble *xyz_list, Gauss *gauss)
Definition: Seg.cpp:362
Seg::NodalFunctionsMINIDerivatives
void NodalFunctionsMINIDerivatives(IssmDouble *dbasis, IssmDouble *xyz_list, Gauss *gauss)
Definition: Seg.h:119
Seg::TensorInterpolation
int TensorInterpolation(void)
Definition: Seg.h:148
Seg::ReduceMatrices
void ReduceMatrices(ElementMatrix *Ke, ElementVector *pe)
Definition: Seg.h:133
Seg::InputUpdateFromVector
void InputUpdateFromVector(IssmDouble *vector, int name, int type)
Definition: Seg.h:89
Seg::FiniteElement
int FiniteElement(void)
Definition: Seg.cpp:155
Seg::GetBasalElement
Element * GetBasalElement(void)
Definition: Seg.h:60
Seg::PotentialUngrounding
void PotentialUngrounding(Vector< IssmDouble > *potential_sheet_ungrounding)
Definition: Seg.h:131
Seg::JacobianDeterminantBase
void JacobianDeterminantBase(IssmDouble *pJdet, IssmDouble *xyz_list_base, Gauss *gauss)
Definition: Seg.h:95
Seg::ComputeSigmaNN
void ComputeSigmaNN()
Definition: Seg.h:49
Seg::InputUpdateFromIoModel
void InputUpdateFromIoModel(int index, IoModel *iomodel)
Definition: Seg.h:86
Seg::GetVerticesCoordinates
void GetVerticesCoordinates(IssmDouble **pxyz_list)
Definition: Seg.cpp:294
Seg::GetInput2
Input2 * GetInput2(int enumtype)
Definition: Seg.cpp:188
Seg::GetVerticesCoordinatesTop
void GetVerticesCoordinatesTop(IssmDouble **pxyz_list)
Definition: Seg.h:80
Seg::JacobianDeterminantTop
void JacobianDeterminantTop(IssmDouble *pJdet, IssmDouble *xyz_list_base, Gauss *gauss)
Definition: Seg.h:98
Seg::InputUpdateFromSolutionOneDof
void InputUpdateFromSolutionOneDof(IssmDouble *solution, int inputenum)
Definition: Seg.h:87
Seg::NodalFunctionsP1Derivatives
void NodalFunctionsP1Derivatives(IssmDouble *dbasis, IssmDouble *xyz_list, Gauss *gauss)
Definition: Seg.h:122
Seg::JacobianDeterminantSurface
void JacobianDeterminantSurface(IssmDouble *pJdet, IssmDouble *xyz_list, Gauss *gauss)
Definition: Seg.cpp:369
Seg::SpawnBasalElement
Element * SpawnBasalElement(void)
Definition: Seg.h:140
Seg::InputDepthAverageAtBase
void InputDepthAverageAtBase(int enum_type, int average_enum_type)
Definition: Seg.h:84
Seg::GetInputListOnNodes
void GetInputListOnNodes(IssmDouble *pvalue, Input2 *input, IssmDouble default_value)
Definition: Seg.cpp:321
ElementVector
Definition: ElementVector.h:20
Seg::NewGauss
Gauss * NewGauss(void)
Definition: Seg.cpp:375
Seg::JacobianDeterminantLine
void JacobianDeterminantLine(IssmDouble *Jdet, IssmDouble *xyz_list, Gauss *gauss)
Definition: Seg.h:96
Seg::SpawnTopElement
Element * SpawnTopElement(void)
Definition: Seg.h:141
Vertex
Definition: Vertex.h:19
IoModel
Definition: IoModel.h:48
Seg::ElementResponse
void ElementResponse(IssmDouble *presponse, int response_enum)
Definition: Seg.h:55
Seg::InputUpdateFromSolutionOneDofCollapsed
void InputUpdateFromSolutionOneDofCollapsed(IssmDouble *solution, int inputenum)
Definition: Seg.h:88
Seg::ControlInputSetGradient
void ControlInputSetGradient(IssmDouble *gradient, int enum_type, int control_index, int offset, int N, int M)
Definition: Seg.h:52
Seg::~Seg
~Seg()
Definition: Seg.cpp:55
Seg::SurfaceArea
IssmDouble SurfaceArea(void)
Definition: Seg.h:147
Seg::FSContactMigration
void FSContactMigration(Vector< IssmDouble > *vertexgrounded, Vector< IssmDouble > *vertexfloating)
Definition: Seg.h:59
ElementMatrix
Definition: ElementMatrix.h:19
Vector< IssmDouble >
Seg::Masscon
IssmDouble Masscon(IssmDouble *levelset)
Definition: Seg.h:99
Results
Declaration of Results class.
Definition: Results.h:14
ElementHook.h
prototypes for ElementHook.h
Seg::MassFlux
IssmDouble MassFlux(IssmDouble *segment)
Definition: Seg.h:100
Seg::ComputeDeviatoricStressTensor
void ComputeDeviatoricStressTensor()
Definition: Seg.h:47
Gauss
Definition: Gauss.h:8
Seg::AverageOntoPartition
void AverageOntoPartition(Vector< IssmDouble > *partition_contributions, Vector< IssmDouble > *partition_areas, IssmDouble *vertex_response, IssmDouble *qmu_part)
Definition: Seg.h:44
Seg::StabilizationParameter
IssmDouble StabilizationParameter(IssmDouble u, IssmDouble v, IssmDouble w, IssmDouble diameter, IssmDouble kappa)
Definition: Seg.h:142
SealevelMasks
Definition: SealevelMasks.h:10
Seg::StrainRateperpendicular
void StrainRateperpendicular(void)
Definition: Seg.h:145
Seg::GetNumberOfVertices
int GetNumberOfVertices(void)
Definition: Seg.cpp:290
Seg::VelocityInterpolation
int VelocityInterpolation(void)
Definition: Seg.h:159
Seg::InputExtrude
void InputExtrude(int enum_type, int start)
Definition: Seg.h:85
Seg::ComputeEsaStrainAndVorticity
void ComputeEsaStrainAndVorticity()
Definition: Seg.h:48
Seg::GetInputValue
void GetInputValue(IssmDouble *pvalue, Vertex *vertex, int enumtype)
Definition: Seg.h:70
Seg::GetInput2
Input2 * GetInput2(int inputenum, IssmDouble start_time, IssmDouble end_time, int averaging_method)
Definition: Seg.h:67
Seg::Configure
void Configure(Elements *elements, Loads *loads, Nodes *nodesin, Vertices *verticesin, Materials *materials, Parameters *parameters, Inputs2 *inputs2in)
Definition: Seg.h:51
Seg::IsZeroLevelset
bool IsZeroLevelset(int levelset_enum)
Definition: Seg.h:93