31#ifndef hyperReduction_H
32#define hyperReduction_H
39#include "fvMeshSubset.H"
42#include <unsupported/Eigen/NNLS>
47template <
typename... SnapshotsLists>
53 using SnapshotsListTuple = std::tuple<std::decay_t<SnapshotsLists>...>;
55 std::tuple<typename std::decay_t<SnapshotsLists>::value_type ...>;
56 static constexpr auto n_fields =
sizeof...(SnapshotsLists);
59 unsigned int vectorial_dim;
60 unsigned int sumFieldsDim;
62 template <std::
size_t N>
63 using NthFieldListType =
typename
64 std::tuple_element<N, SnapshotsListTuple>::type;
66 template <std::
size_t N>
67 using NthFieldType =
typename NthFieldListType<N>::value_type;
81 Eigen::VectorXi initialSeeds,
83 SnapshotsLists &&...snapshotsLists);
98 unsigned int vectorial_dim,
100 Eigen::VectorXi initialSeeds,
102 Eigen::VectorXd
volumes = Eigen::VectorXd::Constant(1,0.0));
108 label n_boundary_patches;
111 List<label> n_boundary_cells_list;
114 label n_boundary_cells;
126 Eigen::VectorXi initialSeeds;
129 Eigen::VectorXi nodes;
175 Eigen::VectorXd normalizingWeights;
181 Eigen::MatrixXd pinvPU;
187 Eigen::VectorXd eigenValueseig;
190 Eigen::SparseMatrix<double>
P;
193 Eigen::SparseMatrix<double> field2submesh;
196 Eigen::SparseMatrix<double> submesh2nodes;
199 Eigen::VectorXi submesh2nodesMask;
203 List<Eigen::VectorXd> quadratureWeightsSubspaces;
218 Eigen::VectorXd& normalizingWeights)
220 methodName =
"GappyDEIM";
221 word name =
"ITHACAoutput/" +
problemName +
"/" + methodName;
226 Eigen::VectorXd& normalizingWeights, word folderMethodName);
232 Eigen::VectorXd& normalizingWeights)
235 word name =
"ITHACAoutput/" +
problemName +
"/" + methodName;
236 offlineECP(snapshotsModes, normalizingWeights, name);
239 void offlineECP(Eigen::MatrixXd& snapshotsModes,
240 Eigen::VectorXd& normalizingWeights, word folderMethodName)
242 List<Eigen::MatrixXd> listSnapshotsModes(1);
243 listSnapshotsModes[0] = snapshotsModes.leftCols(
n_modes);
244 offlineECP(listSnapshotsModes, normalizingWeights, folderMethodName);
252 void offlineECP(List<Eigen::MatrixXd>& listSnapshotsModes,
253 Eigen::VectorXd& weights, word folderMethodName);
259 void initSeeds(Eigen::VectorXd mp_not_mask, std::set<label> nodePointsSet);
264 void computeLS(Eigen::MatrixXd& J, Eigen::MatrixXd& JWhole, Eigen::VectorXd& b,
265 Eigen::VectorXd& q,
bool NNLS);
273 void getModesSVD(SnapshotsListTuple& SnapshotsListTuple,
274 Eigen::MatrixXd& modesSVD, Eigen::VectorXd& fieldWeights,
275 bool saveModesFlag =
false);
284 Eigen::MatrixXd& modesSVD, Eigen::VectorXd& fieldWeights,
285 Eigen::MatrixXd& modesSVDBoundary, Eigen::VectorXd& fieldWeightsBoundary,
294 void updateNodes(Eigen::SparseMatrix<double>&
P, label& ind_max,
295 Eigen::VectorXd& mp_not_mask);
311 template <
typename SnapshotsList>
312 void stackSnapshots(SnapshotsList sList, Eigen::MatrixXd& snapshotsMatrix,
313 Eigen::VectorXd& fieldWeights);
321 template <
typename SnapshotsList>
323 List<Eigen::MatrixXd>& snapshotsMatrixBoundary,
324 List<Eigen::VectorXd>& fieldWeightsBoundary);
332 template <
typename SnapshotsList>
333 void saveModes(SnapshotsList sList, Eigen::MatrixXd& snapshotsMatrix,
334 unsigned int& rowIndex,
unsigned int& modeIndex, word folder);
342 template <
typename SnapshotsList>
343 void saveModes(SnapshotsList sList, Eigen::MatrixXd& snapshotsMatrix,
344 Eigen::MatrixXd& snapshotsMatrixBoundary,
unsigned int& rowIndex,
345 unsigned int& rowIndexBoundary,
unsigned int& modeIndex, word folder);
353 template <
typename SnapshotsList>
365 template <
typename SnapshotsList>
377 template <
typename SnapshotsList>
389 void evaluatePinv(Eigen::SparseMatrix<double>& Projector,
390 Eigen::MatrixXd&
Modes, Eigen::VectorXd& fieldWeights);
398 void evaluateWPU(Eigen::SparseMatrix<double>& Projector,
399 Eigen::MatrixXd&
Modes, Eigen::VectorXd& fieldWeights,
425 template <
typename FieldType>
428 return autoPtr<FieldType>(
new FieldType(
submesh->interpolate(field)));
437 template <
typename Field>
440 return std::is_same<Field, volScalarField>::value ? 1 : 3;
448 template <
typename LastList>
459 template <
typename List,
typename... RemainingLists>
461 RemainingLists &&...tail)
475 std::sqrt((A.transpose() * A).determinant()) / \
476 A.colwise().lpNorm<2>().prod(),
485 template <
typename... FieldsArgs>
488 unsigned int cumulativeSize{0}, ith_field{0};
489 ([ & ](
auto & oFieldsArg)
491 double ith_fieldSize =
fieldDims[ith_field] * oFieldsArg.size();
492 Eigen::VectorXd vec = eFields.segment(cumulativeSize, ith_fieldSize);
494 cumulativeSize += ith_fieldSize;
519 void getSnapMatrix(Eigen::MatrixXd& snapMatrix, Eigen::VectorXd& fieldWeights);
526 void getSnapMatrix(Eigen::MatrixXd& snapMatrix, Eigen::VectorXd& fieldWeights,
527 List<Eigen::MatrixXd>& snapMatrixBoundary,
528 List<Eigen::VectorXd>& fieldWeightsBoundary);
Header file of the EigenFunctions class.
Header file of the Foam2Eigen class.
Header file of the ITHACAPOD class.
Header file of the ITHACAutilities namespace.
static GeometricField< scalar, PatchField, GeoMesh > Eigen2field(GeometricField< scalar, PatchField, GeoMesh > &field, Eigen::VectorXd &eigen_vector, bool correctBC=true)
Convert a vector in Eigen format into an OpenFOAM scalar GeometricField.
void stackSnapshotsBoundary(SnapshotsList sList, List< Eigen::MatrixXd > &snapshotsMatrixBoundary, List< Eigen::VectorXd > &fieldWeightsBoundary)
TODO.
SnapshotsListTuple snapshotsListTuple
The snapshots matrix containing the nonlinear function or operator.
label n_modes
The maximum number of modes to be considered.
void evaluateWPU(Eigen::SparseMatrix< double > &Projector, Eigen::MatrixXd &Modes, Eigen::VectorXd &fieldWeights, Eigen::VectorXd &quadratureWeights)
Compute the pseudo-inverse of the matrix M restricted with the projector P.
label n_nodes
The maximum number of modes to be considered.
word folderMethod
Folder for the selected HR method.
void stackNames(SnapshotsList sList)
TODO.
List< word > fieldNames
Names of the fields.
void generateSubmesh(label layers, const fvMesh &mesh)
Compute the submesh common to all fields in SnapshotsLists.
autoPtr< FieldType > interpolateField(const FieldType &field)
TODO.
autoPtr< fvMeshSubset > submesh
Submesh of the HyperReduction method.
Eigen::MatrixXd renormalizedBasisMatrix
Renormalized basis of HR.
void offlineGappyDEIM(Eigen::MatrixXd &snapshotsModes, Eigen::VectorXd &normalizingWeights)
Methods implemented: 'GappyDEIM' from "DEIM, Chaturantabut, Saifon, and Danny C. Sorensen....
void updateNodes(Eigen::SparseMatrix< double > &P, label &ind_max, Eigen::VectorXd &mp_not_mask)
TODO.
void evaluatePinv(Eigen::SparseMatrix< double > &Projector, Eigen::MatrixXd &Modes, Eigen::VectorXd &fieldWeights)
Compute the pseudo-inverse of the matrix M restricted with the projector P.
Eigen::VectorXd quadratureWeights
Quadrature weights. Ordered in the same order of matrix P.
autoPtr< IOList< labelList > > totalNodePoints
List of label lists of the nodes and corresponding surrounding nodes.
void sumDimensions(double sum, SnapshotsList sList)
TODO.
Eigen::MatrixXd MatrixOnline
Online Matrix.
List< label > global2local(List< label > &points, fvMeshSubset &submesh)
Get local indices in the submesh from indices in the global ones.
void stackDimensions(SnapshotsList sList)
TODO.
constexpr unsigned int compute_vectorial_dim(LastList x)
TODO.
void getSnapMatrix(Eigen::MatrixXd &snapMatrix, Eigen::VectorXd &fieldWeights)
TODO.
List< label > localNodePoints
Indices of the local node points in the subMesh.
constexpr unsigned int get_field_dim()
TODO.
void offlineECP(Eigen::MatrixXd &snapshotsModes, Eigen::VectorXd &normalizingWeights)
Methods implemented: 'ECP' from "ECP, Hernandez, Joaquin Alberto, Manuel Alejandro Caicedo,...
word problemName
The name of the non-linear function e.g. HR_method/residual.
constexpr unsigned int compute_vectorial_dim(List &&head, RemainingLists &&...tail)
TODO.
void eigen2fields(Eigen::VectorXd &eFields, FieldsArgs &&... oFields)
TODO.
HyperReduction(label n_modes, label n_nodes, Eigen::VectorXi initialSeeds, word problemName, SnapshotsLists &&...snapshotsLists)
Construct HyperReduction class, interpolation-based.
void updateNodesRemove(Eigen::SparseMatrix< double > &P, Eigen::VectorXd weights)
Remove from the nodes the weights equal to 0 (used with NNLS).
Eigen::SparseMatrix< double > P
The P matrix of the HyperReduction method. The nodes are ordered in the order of insertion during the...
label n_cells
Int Number of Cells;.
void initReshapeMat(Eigen::SparseMatrix< double > &reshapeMat)
TODO.
void initSeeds(Eigen::VectorXd mp_not_mask, std::set< label > nodePointsSet)
TODO.
autoPtr< IOList< label > > nodePoints
Nodes in the case of the a nonlinear function.
Eigen::VectorXd volumes
Volume of each cell.
Eigen::SparseMatrix< double > maskToOtherDim(int newDim)
Compute the sparse mask matrix P with a vectorial dimension different from the snapshots (enlarged or...
static double s_optimality(Eigen::MatrixXd &A)
TODO.
void getModesSVD(SnapshotsListTuple &SnapshotsListTuple, Eigen::MatrixXd &modesSVD, Eigen::VectorXd &fieldWeights, bool saveModesFlag=false)
TODO.
autoPtr< volVectorField > submesh_field
Submeshes.
label n_snapshots
The length of the snapshots lists.
autoPtr< IOList< label > > uniqueNodePoints
List of the unique indices of the nodes that define the submesh.
List< unsigned int > fieldDims
Dimensions of the fields.
void saveModes(SnapshotsList sList, Eigen::MatrixXd &snapshotsMatrix, unsigned int &rowIndex, unsigned int &modeIndex, word folder)
TODO.
word folderProblem
Folder for the HR problem.
void stackSnapshots(SnapshotsList sList, Eigen::MatrixXd &snapshotsMatrix, Eigen::VectorXd &fieldWeights)
TODO.
Eigen::MatrixXd basisMatrix
Orthonormal basis of HR.
void computeLS(Eigen::MatrixXd &J, Eigen::MatrixXd &JWhole, Eigen::VectorXd &b, Eigen::VectorXd &q, bool NNLS)
TODO.
label n_cellsSubfields
Int Number of Cells in submeshes;.
void createMasks(bool offlineStage=true)
TODO.
Class for the definition of some general parameters, the parameters must be defined from the file ITH...
Implementation of a container class derived from PtrList.