9 int main(
int argc,
char *argv[])
15 fprintf(stderr,
"Usage: AddModeTo2DFld scal1 scal2 2Dfieldfile1 fieldfile2 outfield\n"
16 "\t produces scal1*2Dfieldfiel1 + scal2*fieldfile2 in outfield\n" );
20 scal1 = boost::lexical_cast<double>(argv[argc-5]);
21 scal2 = boost::lexical_cast<double>(argv[argc-4]);
25 string fieldfile1(argv[argc-3]);
26 vector<LibUtilities::FieldDefinitionsSharedPtr> fielddef1;
27 vector<vector<NekDouble> > fielddata1;
33 string fieldfile2(argv[argc-2]);
34 vector<LibUtilities::FieldDefinitionsSharedPtr> fielddef2;
35 vector<vector<NekDouble> > fielddata2;
39 vector<vector<NekDouble> > combineddata;
41 ASSERTL0(fielddata1.size() == fielddata2.size(),
"Inner has different size");
50 for(i = 0; i < fielddata2.size(); ++i)
52 ASSERTL0(fielddef2[i]->m_numHomogeneousDir == 1,
"Expected second fld to have one homogeneous direction");
53 ASSERTL0(fielddef2[i]->m_numModes[2] == 2,
"Expected Fourier field to have 2 modes");
55 int datalen1 = fielddata1[i].size()/fielddef1[i]->m_fields.size();
56 int datalen2 = fielddata2[i].size()/fielddef2[i]->m_fields.size();
58 ASSERTL0(datalen1*2 == datalen2,
"Data per fields is note compatible");
62 switch(fielddef2[i]->m_shapeType)
68 ncoeffs = fielddef2[i]->m_numModes[0]*fielddef2[i]->m_numModes[1];
71 ASSERTL0(
false,
"Shape not recognised");
79 Vmath::Smul(fielddata1[i].size(), scal1, &fielddata1[i][0], 1,
80 &fielddata1[i][0], 1);
81 Vmath::Smul(fielddata2[i].size(), scal2, &fielddata2[i][0], 1,
82 &fielddata2[i][0], 1);
84 vector<NekDouble> newdata;
85 auto vec_iter = fielddata2[i].begin();
87 for(k = 0; k < fielddef2[i]->m_fields.size(); ++k)
91 for(j = 0; j < fielddef1[i]->m_fields.size(); ++j)
93 if(fielddef1[i]->m_fields[j] == fielddef2[i]->m_fields[k])
100 if(j != fielddef1[i]->m_fields.size())
102 for(n = 0; n < fielddef2[i]->m_elementIDs.size(); ++n)
105 newdata.insert(newdata.end(),
106 &(fielddata1[i][offset+n*ncoeffs]),
107 &(fielddata1[i][offset+n*ncoeffs])
111 newdata.insert(newdata.end(),&
Zero[0],&
Zero[0] + ncoeffs);
114 newdata.insert(newdata.end(),vec_iter, vec_iter+2*ncoeffs);
115 vec_iter += 2*ncoeffs;
121 for(n = 0; n < fielddef2[i]->m_elementIDs.size(); ++n)
124 newdata.insert(newdata.end(),&
Zero[0],&
Zero[0] + ncoeffs);
125 newdata.insert(newdata.end(),&
Zero[0],&
Zero[0] + ncoeffs);
128 newdata.insert(newdata.end(),vec_iter, vec_iter+2*ncoeffs);
129 vec_iter += 2*ncoeffs;
133 combineddata.push_back(newdata);
134 fielddef2[i]->m_numModes[2] += 2;
135 fielddef2[i]->m_homogeneousZIDs.push_back(2);
136 fielddef2[i]->m_homogeneousZIDs.push_back(3);
140 for(k = 0; k < fielddef1[i]->m_fields.size(); ++k)
142 for(j = 0; j < fielddef2[i]->m_fields.size(); ++j)
144 if(fielddef1[i]->m_fields[k] == fielddef2[i]->m_fields[j])
150 if(j == fielddef2[i]->m_fields.size())
152 cout <<
"Warning: Field \'" << fielddef1[i]->m_fields[k]
153 <<
"\' was not included in output " << endl;
int main(int argc, char *argv[])
#define ASSERTL0(condition, msg)
int getNumberOfCoefficients(int Na)
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...
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 ...
The above copyright notice and this permission notice shall be included.
void Smul(int n, const T alpha, const T *x, const int incx, T *y, const int incy)
Scalar multiply y = alpha*x.
void Zero(int n, T *x, const int incx)
Zero vector.