Nektar++
AddModeTo2DFld.cpp
Go to the documentation of this file.
1 #include <SpatialDomains/MeshGraph.h> // for FieldDefinitions, etc
2 #include <StdRegions/StdTriExp.h>
3 #include <cstdio>
4 #include <cstdlib>
5 
6 using namespace std;
7 using namespace Nektar;
8 
9 int main(int argc, char *argv[])
10 {
11  NekDouble scal1, scal2;
12 
13  if (argc != 6)
14  {
15  fprintf(
16  stderr,
17  "Usage: AddModeTo2DFld scal1 scal2 2Dfieldfile1 fieldfile2 "
18  "outfield\n"
19  "\t produces scal1*2Dfieldfiel1 + scal2*fieldfile2 in outfield\n");
20  exit(1);
21  }
22 
23  scal1 = boost::lexical_cast<double>(argv[argc - 5]);
24  scal2 = boost::lexical_cast<double>(argv[argc - 4]);
25 
26  //----------------------------------------------
27  // Import fieldfile1.
28  string fieldfile1(argv[argc - 3]);
29  vector<LibUtilities::FieldDefinitionsSharedPtr> fielddef1;
30  vector<vector<NekDouble>> fielddata1;
31  LibUtilities::Import(fieldfile1, fielddef1, fielddata1);
32  //----------------------------------------------
33 
34  //----------------------------------------------
35  // Import fieldfile2.
36  string fieldfile2(argv[argc - 2]);
37  vector<LibUtilities::FieldDefinitionsSharedPtr> fielddef2;
38  vector<vector<NekDouble>> fielddata2;
39  LibUtilities::Import(fieldfile2, fielddef2, fielddata2);
40  //----------------------------------------------
41 
42  vector<vector<NekDouble>> combineddata;
43 
44  ASSERTL0(fielddata1.size() == fielddata2.size(),
45  "Inner has different size");
46  //----------------------------------------------
47  // Add fielddata2 to fielddata1 using m_fields definition to align data.
48 
49  int i = 0;
50  int j = 0;
51  int k = 0;
52  int n = 0;
53 
54  for (i = 0; i < fielddata2.size(); ++i)
55  {
56  ASSERTL0(fielddef2[i]->m_numHomogeneousDir == 1,
57  "Expected second fld to have one homogeneous direction");
58  ASSERTL0(fielddef2[i]->m_numModes[2] == 2,
59  "Expected Fourier field to have 2 modes");
60 
61  int datalen1 = fielddata1[i].size() / fielddef1[i]->m_fields.size();
62  int datalen2 = fielddata2[i].size() / fielddef2[i]->m_fields.size();
63 
64  ASSERTL0(datalen1 * 2 == datalen2,
65  "Data per fields is note compatible");
66 
67  // Determine the number of coefficients per element
68  int ncoeffs = 0;
69  switch (fielddef2[i]->m_shapeType)
70  {
73  fielddef2[i]->m_numModes[0], fielddef2[i]->m_numModes[1]);
74  break;
76  ncoeffs =
77  fielddef2[i]->m_numModes[0] * fielddef2[i]->m_numModes[1];
78  break;
79  default:
80  ASSERTL0(false, "Shape not recognised");
81  break;
82  }
83 
84  // array for zero packing
85  Array<OneD, NekDouble> Zero(ncoeffs, 0.0);
86 
87  // scale first and second fields
88  Vmath::Smul(fielddata1[i].size(), scal1, &fielddata1[i][0], 1,
89  &fielddata1[i][0], 1);
90  Vmath::Smul(fielddata2[i].size(), scal2, &fielddata2[i][0], 1,
91  &fielddata2[i][0], 1);
92 
93  vector<NekDouble> newdata;
94  auto vec_iter = fielddata2[i].begin();
95 
96  for (k = 0; k < fielddef2[i]->m_fields.size(); ++k)
97  {
98  // get location of 2D field information in order of field2 ordering
99  int offset = 0;
100  for (j = 0; j < fielddef1[i]->m_fields.size(); ++j)
101  {
102  if (fielddef1[i]->m_fields[j] == fielddef2[i]->m_fields[k])
103  {
104  break;
105  }
106  offset += datalen1;
107  }
108 
109  if (j != fielddef1[i]->m_fields.size())
110  {
111  for (n = 0; n < fielddef2[i]->m_elementIDs.size(); ++n)
112  {
113  // Real zero component
114  newdata.insert(
115  newdata.end(), &(fielddata1[i][offset + n * ncoeffs]),
116  &(fielddata1[i][offset + n * ncoeffs]) + ncoeffs);
117 
118  // Imaginary zero component;
119  newdata.insert(newdata.end(), &Zero[0], &Zero[0] + ncoeffs);
120 
121  // Put orginal mode in here.
122  newdata.insert(newdata.end(), vec_iter,
123  vec_iter + 2 * ncoeffs);
124  vec_iter += 2 * ncoeffs;
125  }
126  }
127  else
128  {
129 
130  for (n = 0; n < fielddef2[i]->m_elementIDs.size(); ++n)
131  {
132  // Real & Imag zero component
133  newdata.insert(newdata.end(), &Zero[0], &Zero[0] + ncoeffs);
134  newdata.insert(newdata.end(), &Zero[0], &Zero[0] + ncoeffs);
135 
136  // Put orginal mode in here.
137  newdata.insert(newdata.end(), vec_iter,
138  vec_iter + 2 * ncoeffs);
139  vec_iter += 2 * ncoeffs;
140  }
141  }
142  }
143  combineddata.push_back(newdata);
144  fielddef2[i]->m_numModes[2] += 2;
145  fielddef2[i]->m_homogeneousZIDs.push_back(2);
146  fielddef2[i]->m_homogeneousZIDs.push_back(3);
147 
148  // check to see if any field in fielddef1[i]->m_fields is
149  // not defined in fielddef2[i]->m_fields
150  for (k = 0; k < fielddef1[i]->m_fields.size(); ++k)
151  {
152  for (j = 0; j < fielddef2[i]->m_fields.size(); ++j)
153  {
154  if (fielddef1[i]->m_fields[k] == fielddef2[i]->m_fields[j])
155  {
156  break;
157  }
158  }
159 
160  if (j == fielddef2[i]->m_fields.size())
161  {
162  cout << "Warning: Field \'" << fielddef1[i]->m_fields[k]
163  << "\' was not included in output " << endl;
164  }
165  }
166  }
167  //----------------------------------------------
168 
169  //-----------------------------------------------
170  // Write out datafile.
171  LibUtilities::Write(argv[argc - 1], fielddef2, combineddata);
172  //-----------------------------------------------
173 
174  return 0;
175 }
int main(int argc, char *argv[])
#define ASSERTL0(condition, msg)
Definition: ErrorUtil.hpp:215
void Write(const std::string &outFile, std::vector< FieldDefinitionsSharedPtr > &fielddefs, std::vector< std::vector< NekDouble >> &fielddata, const FieldMetaDataMap &fieldinfomap, const bool backup)
This function allows for data to be written to an FLD file when a session and/or communicator is not ...
Definition: FieldIO.cpp:248
void Import(const std::string &infilename, std::vector< FieldDefinitionsSharedPtr > &fielddefs, std::vector< std::vector< NekDouble >> &fielddata, FieldMetaDataMap &fieldinfomap, const Array< OneD, int > &ElementIDs)
This function allows for data to be imported from an FLD file when a session and/or communicator is n...
Definition: FieldIO.cpp:291
The above copyright notice and this permission notice shall be included.
Definition: CoupledSolver.h:1
double NekDouble
void Smul(int n, const T alpha, const T *x, const int incx, T *y, const int incy)
Scalar multiply y = alpha*x.
Definition: Vmath.cpp:248
void Zero(int n, T *x, const int incx)
Zero vector.
Definition: Vmath.cpp:492