1 | /*!\file InputUpdateFromVectorx
|
---|
2 | * \brief: update datasets using parameter inputs
|
---|
3 | */
|
---|
4 |
|
---|
5 | #include "./InputUpdateFromVectorx.h"
|
---|
6 | #include "../../shared/shared.h"
|
---|
7 | #include "../../include/include.h"
|
---|
8 | #include "../../toolkits/toolkits.h"
|
---|
9 | #include "../../EnumDefinitions/EnumDefinitions.h"
|
---|
10 |
|
---|
11 | void InputUpdateFromVectorx( Elements* elements,Nodes* nodes, Vertices* vertices, Loads* loads, Materials* materials, Parameters* parameters,Vector<IssmDouble>* vector, int name, int type){
|
---|
12 |
|
---|
13 | IssmDouble* serial_vector=NULL;
|
---|
14 |
|
---|
15 | serial_vector=vector->ToMPISerial();
|
---|
16 |
|
---|
17 | InputUpdateFromVectorx( elements,nodes, vertices, loads, materials, parameters,serial_vector,name, type);
|
---|
18 |
|
---|
19 | /*Free ressources:*/
|
---|
20 | xDelete<IssmDouble>(serial_vector);
|
---|
21 | }
|
---|
22 |
|
---|
23 |
|
---|
24 | void InputUpdateFromVectorx( Elements* elements,Nodes* nodes, Vertices* vertices, Loads* loads, Materials* materials, Parameters* parameters,IssmDouble* vector, int name, int type){
|
---|
25 |
|
---|
26 | int i;
|
---|
27 |
|
---|
28 | /*Update elements, nodes, loads and materials from inputs: */
|
---|
29 | for(i=0;i<elements->Size();i++){
|
---|
30 | Element* element=(Element*)elements->GetObjectByOffset(i);
|
---|
31 | element->InputUpdateFromVector(vector,name,type);
|
---|
32 | }
|
---|
33 | for(i=0;i<nodes->Size();i++){
|
---|
34 | Node* node=(Node*)nodes->GetObjectByOffset(i);
|
---|
35 | node->InputUpdateFromVector(vector,name,type);
|
---|
36 | }
|
---|
37 | for(i=0;i<loads->Size();i++){
|
---|
38 | Load* load=(Load*)loads->GetObjectByOffset(i);
|
---|
39 | load->InputUpdateFromVector(vector,name,type);
|
---|
40 | }
|
---|
41 | for(i=0;i<materials->Size();i++){
|
---|
42 | Material* material=(Material*)materials->GetObjectByOffset(i);
|
---|
43 | material->InputUpdateFromVector(vector,name,type);
|
---|
44 | }
|
---|
45 | }
|
---|
46 |
|
---|
47 | void InputUpdateFromVectorx( Elements* elements,Nodes* nodes, Vertices* vertices, Loads* loads, Materials* materials, Parameters* parameters,int* vector, int name, int type){
|
---|
48 |
|
---|
49 | int i;
|
---|
50 |
|
---|
51 | /*Update elements, nodes, loads and materials from inputs: */
|
---|
52 | for(i=0;i<elements->Size();i++){
|
---|
53 | Element* element=(Element*)elements->GetObjectByOffset(i);
|
---|
54 | element->InputUpdateFromVector(vector,name,type);
|
---|
55 | }
|
---|
56 | for(i=0;i<nodes->Size();i++){
|
---|
57 | Node* node=(Node*)nodes->GetObjectByOffset(i);
|
---|
58 | node->InputUpdateFromVector(vector,name,type);
|
---|
59 | }
|
---|
60 | for(i=0;i<loads->Size();i++){
|
---|
61 | Load* load=(Load*)loads->GetObjectByOffset(i);
|
---|
62 | load->InputUpdateFromVector(vector,name,type);
|
---|
63 | }
|
---|
64 | for(i=0;i<materials->Size();i++){
|
---|
65 | Material* material=(Material*)materials->GetObjectByOffset(i);
|
---|
66 | material->InputUpdateFromVector(vector,name,type);
|
---|
67 | }
|
---|
68 | }
|
---|
69 |
|
---|
70 | void InputUpdateFromVectorx( Elements* elements,Nodes* nodes, Vertices* vertices, Loads* loads, Materials* materials, Parameters* parameters,bool* vector, int name, int type){
|
---|
71 |
|
---|
72 | int i;
|
---|
73 |
|
---|
74 | /*Update elements, nodes, loads and materials from inputs: */
|
---|
75 | for(i=0;i<elements->Size();i++){
|
---|
76 | Element* element=(Element*)elements->GetObjectByOffset(i);
|
---|
77 | element->InputUpdateFromVector(vector,name,type);
|
---|
78 | }
|
---|
79 | for(i=0;i<nodes->Size();i++){
|
---|
80 | Node* node=(Node*)nodes->GetObjectByOffset(i);
|
---|
81 | node->InputUpdateFromVector(vector,name,type);
|
---|
82 | }
|
---|
83 | for(i=0;i<loads->Size();i++){
|
---|
84 | Load* load=(Load*)loads->GetObjectByOffset(i);
|
---|
85 | load->InputUpdateFromVector(vector,name,type);
|
---|
86 | }
|
---|
87 | for(i=0;i<materials->Size();i++){
|
---|
88 | Material* material=(Material*)materials->GetObjectByOffset(i);
|
---|
89 | material->InputUpdateFromVector(vector,name,type);
|
---|
90 | }
|
---|
91 | }
|
---|