#include <matlabBinaryGraphics.hh>
Public Member Functions | |
MatlabBinaryGraphics (const std::string filename) | |
template<class G > | |
MatlabBinaryGraphics (const concepts::Space< G > &spc, const std::string filename) | |
MatlabBinaryGraphics (concepts::Mesh &msh, const std::string filename, const uint points=5) | |
template<class G , class F > | |
MatlabBinaryGraphics (const concepts::Space< G > &spc, const std::string filename, const concepts::Vector< F > &sol, const concepts::ElementFunction< F, G > *fun=0) | |
template<class G , class F > | |
MatlabBinaryGraphics (const concepts::Space< G > &spc, const std::string filename, const concepts::Vector< F > &sol, const std::string varName, const concepts::ElementFunction< F, G > *fun=0) | |
template<class G , class F > | |
MatlabBinaryGraphics (const concepts::Space< G > &spc, const std::string filename, std::vector< concepts::Vector< F > > &sol, const concepts::ElementFunction< F, G > *fun=0) | |
template<class G , class F > | |
MatlabBinaryGraphics (const concepts::Space< G > &spc, const std::string filename, const concepts::ElementFormula< F, G > &frm) | |
template<class F , class G > | |
void | addSolution (const concepts::Space< G > &spc, const std::string name, const concepts::Vector< F > &sol, const concepts::ElementFunction< F, G > *fun=0) |
template<class F , class G > | |
void | addFunction (const concepts::Space< G > &spc, const std::string name, const concepts::ElementFormula< F, G > &frm) |
template<class T > | |
void | add (const T &u, const std::string varName, enum matio_compression compress=MAT_COMPRESSION_NONE) |
template<class T > | |
void | get (T &u, const std::string varName) |
void | reopen () |
void | close () |
void | clear () |
bool | isOpen () const |
bool | isEmpty () const |
bool | remove (const std::string varName) |
std::string | filename () const |
void | overWrite (bool toOverWrite) |
bool | exists (const std::string &varName) const |
bool | isReal (const std::string &varName) const |
bool | isCmplx (const std::string &varName) const |
bool | isScalar (const std::string &varName) const |
bool | isDense (const std::string &varName) const |
bool | isSparse (const std::string &varName) const |
bool | isInt (const std::string &varName) const |
bool | isUint (const std::string &varName) const |
uint | lengthVector (const std::string &varName) const |
void | assertCmplx (const std::string &varName) const |
void | assertExistence (const std::string &varName) const |
void | assertVector (const std::string &varName) const |
void | assertQuadratic (const std::string &varName) const |
Static Public Attributes | |
static uint | noPoints |
Protected Member Functions | |
template<class G > | |
void | addSpace_ (const concepts::Space< G > &spc) |
template<class G > | |
void | storeData_ (DenseMatrixCollection< G > &dense_ptr_) |
Stores data hold by dense_ptr . | |
virtual std::ostream & | info (std::ostream &os) const |
template<class F , class G > | |
concepts::RCP< concepts::ElementMatrix< F > > | getSolution (const concepts::Space< G > &spc, const concepts::Vector< F > &sol, const concepts::ElementFunction< F, G > *fun=0) |
template<class F , class G > | |
concepts::RCP< concepts::ElementMatrix< typename concepts::Datatype< F >::type > > | getFunction (const concepts::Space< G > &spc, const concepts::ElementFormula< F, G > &frm) |
template<class G > | |
DenseMatrixCollection< G > | getSpace (const concepts::Space< G > &spc) |
DenseMatrixCollection< Real > | getMesh (concepts::Mesh &msh, const uint points=5) |
Protected Attributes | |
uint | data_ |
Information which data should be stored. | |
Class that allows to store graphical infomations in .mat files to use them in Matlab.
Definition at line 27 of file matlabBinaryGraphics.hh.
graphics::MatlabBinaryGraphics::MatlabBinaryGraphics | ( | const std::string | filename | ) |
Constructor that only creates a Matlab binary file of filename filename
for further adding of space, solutions etc.
filename | Filename of the Matlab binary file (".mat" will be added if filename does not end with ".mat") |
graphics::MatlabBinaryGraphics::MatlabBinaryGraphics | ( | const concepts::Space< G > & | spc, |
const std::string | filename | ||
) |
Constructor for output of space only.
spc | Space holding the mesh |
filename | Filename of the Matlab binary file |
Definition at line 162 of file matlabBinaryGraphics.hh.
graphics::MatlabBinaryGraphics::MatlabBinaryGraphics | ( | concepts::Mesh & | msh, |
const std::string | filename, | ||
const uint | points = 5 |
||
) |
Constructor for output of mesh only.
msh | Mesh |
filename | Filename of the Matlab binary file (".mat" will be added if filename does not end with ".mat") |
points | Number of points per edge |
graphics::MatlabBinaryGraphics::MatlabBinaryGraphics | ( | const concepts::Space< G > & | spc, |
const std::string | filename, | ||
const concepts::Vector< F > & | sol, | ||
const concepts::ElementFunction< F, G > * | fun = 0 |
||
) |
Constructor for output of solutions and functions of it.
spc | Space on which the data should be plotted |
filename | Filename of the Matlab binary file (".mat" will be added if filename does not end with ".mat") |
sol | The first solution set which should be plotted |
fun | Function of the FE function, e.g. itself. |
Definition at line 138 of file matlabBinaryGraphics.hh.
graphics::MatlabBinaryGraphics::MatlabBinaryGraphics | ( | const concepts::Space< G > & | spc, |
const std::string | filename, | ||
const concepts::Vector< F > & | sol, | ||
const std::string | varName, | ||
const concepts::ElementFunction< F, G > * | fun = 0 |
||
) |
Constructor for output of solutions and functions of it.
spc | Space on which the data should be plotted |
filename | Filename of the Matlab binary file (".mat" will be added if filename does not end with ".mat") |
sol | The first solution set which should be plotted |
varName | Name of the fem approximation |
fun | Function of the FE function, e.g. by default itself. |
Definition at line 150 of file matlabBinaryGraphics.hh.
graphics::MatlabBinaryGraphics::MatlabBinaryGraphics | ( | const concepts::Space< G > & | spc, |
const std::string | filename, | ||
std::vector< concepts::Vector< F > > & | sol, | ||
const concepts::ElementFunction< F, G > * | fun = 0 |
||
) |
Constructor for output of solutions and functions of it.
spc | Space on which the data should be plotted |
filename | Filename of the Matlab binary file (".mat" will be added if filename does not end with ".mat") |
sol | The first solution set which should be plotted |
fun | Function of the FE function, e.g. itself. |
graphics::MatlabBinaryGraphics::MatlabBinaryGraphics | ( | const concepts::Space< G > & | spc, |
const std::string | filename, | ||
const concepts::ElementFormula< F, G > & | frm | ||
) |
Constructor for output of an element formula
spc | Space on which the data should be plotted |
filename | Filename of the Matlab binary file (".mat" will be added if filename does not end with ".mat") |
frm | Element formula |
Definition at line 170 of file matlabBinaryGraphics.hh.
|
inlineinherited |
Method to add various objects to a current open MatfileIO. Objects that can be added are:
ElementMatrix<T>
(i.e. DenseMatrix<T>)Array<Point<T, dim>>
DiagonalMatrix<T>
SparseMatrix<T>
Array<T>
,std::vector<T>
(i.e. Sequence<T>)Vector<T>
,Point<T, dim>
,Mapping<T, dim>
,Scalars
(Real, Cmplx)This add routine controls the Input quantities and throws an exception, if the MatfileIO instance is not open; the Input class type T
is not supported (yet); a variable with the same name varName
is added in the current MatfileIO instance, before closing it; a variable with the same name varName
already exists in the *.mat-file and is set not to be rewritable. If no error occurs the desired object is added.
u | The object you want to add to the current open *.mat-file |
varName | Name of the variable. |
compress | MAT_COMPRESSION_NONE / MAT_COMPRESSION_ZLIB |
Definition at line 160 of file matfileIO.hh.
void graphics::MatlabBinaryGraphics::addFunction | ( | const concepts::Space< G > & | spc, |
const std::string | name, | ||
const concepts::ElementFormula< F, G > & | frm | ||
) |
Adds a solution vector to the current matfile
spc | The space from which the solution vector was generated |
name | The name of the variable, e.g. "frm" |
frm | The function represented by an element formula |
Definition at line 191 of file matlabBinaryGraphics.hh.
void graphics::MatlabBinaryGraphics::addSolution | ( | const concepts::Space< G > & | spc, |
const std::string | name, | ||
const concepts::Vector< F > & | sol, | ||
const concepts::ElementFunction< F, G > * | fun = 0 |
||
) |
Adds a solution vector to the current matfile
spc | The space from which the solution vector was generated |
name | The name of the variable, e.g. "u0" |
sol | The solution vector |
fun | The type of vector you need (i.e. values, gradient, Laplacian etc.), default argument is Values |
Definition at line 178 of file matlabBinaryGraphics.hh.
|
protected |
Adds informations of a given Space to the matfile
spc | The space that should be stored |
Definition at line 201 of file matlabBinaryGraphics.hh.
|
inherited |
Throws an exception if the variable is not (at least) a complex
|
inherited |
Throws an exception if the variable does not exist
|
inherited |
Throws an exception if the variable is not a quadratic rank 2 object.
|
inherited |
Throws an exception if the variable has no vector struct, that is at most one dimension is larger than one.
|
inherited |
Method to remove all variable in the current *.mat-file.
|
inherited |
Method to close the current *.mat-file. This method has the effect to finish the writing to the *.mat-file. It may be used in combination with reopen(). If you don't close the current MatfileIO-object the deconstructor will do it anyway.
|
inherited |
Returns true if the variable /c varName exists, false otherwise. It throws an exception if no file is opened currently.
|
inlineinherited |
Returns the name of the current open *.mat-file.
Definition at line 306 of file matfileIO.hh.
|
inlineinherited |
Method to get various objects out of the current open MatfileIO. Objects that can be gained:
ElementMatrix<T>
(i.e. DenseMatrix<T>)DiagonalMatrix<T>
SparseMatrix<T>
Array<T>
,std::vector<T>
(i.e.Sequence<T>
)std::vector<Vector<T>
> (i.e. Sequence<Vector< T >
>)Vector<T>
,Point<T, dim>
,Mapping<T, dim>
,Scalars
(Real, Cmplx)This get routine controlls the Input quantities and throws an exception, if no variable named varName
exists in the current open *.mat-file; if the field of the requested variable in the *.mat-file and the field of u
differs, that is concepts::Real or concepts::Cmplx; if the class of u
is not supported (yet). Matlab's multidimensional arrays with rank > 2 are not supported to be read out of a *.mat-file (yet). If no error occurs the desired object gets filled. The object u
does not need to be preallocated, it gets resized due to the *.mat-file informations.
u | The object you want to get out of the current open *.mat-file |
varName | Name of the requested variable. |
Definition at line 234 of file matfileIO.hh.
|
protectedinherited |
Returns a vector with the value of the function on the quadrature-points of a given space using the given concepts::ElementFormula
.
spc | The space on which the Element Formula is defined |
frm | The ElementFormula of the function that should be plotted |
Definition at line 194 of file denseMatrixGraphics.hh.
|
protectedinherited |
Returns a graphics::DenseMatrixCollection<G> that contains informations for graphical output of the given mesh.
msh | The mesh |
dim | The dimension of the mesh |
|
protectedinherited |
Returns a vector with the value of the solution on the quadrature-points of a given space using a given coefficient vector.
spc | The space from which the solution vector was generated |
sol | The solution vector |
fun | Function of the solution (e.g. solution itself, its gradient, it's Laplacien etc.) |
Definition at line 130 of file denseMatrixGraphics.hh.
|
protectedinherited |
Returns a graphics::DenseMatrixCollection<G> that contains informations for graphical output of the given space.
spc | The space |
dim | The dimension of the space |
Definition at line 171 of file denseMatrixGraphics.hh.
|
protectedvirtualinherited |
Gives an overview about the variables that are in a current open *.mat-file.
Reimplemented from concepts::OutputOperator.
|
inherited |
Return true if the variable /c varName is of type double complex
|
inherited |
Returns true if the variable /c varName is dense, else 0
|
inlineinherited |
Routine to check if a *.mat-file is empty, i.e. does not contain any variables.
Definition at line 290 of file matfileIO.hh.
|
inherited |
Returns true if the variable /c varname is int, else 0.
|
inlineinherited |
Routine to check if a *.mat-file is currently open. Might be use with reopen() and close() routines.
Definition at line 283 of file matfileIO.hh.
|
inherited |
Return true if the variable /c varName is of type double
|
inherited |
Return true if the variable /c varName is a scalar
|
inherited |
Returns true if the variable /c varName is sparse, else 0.
|
inherited |
Returns true if the variable /c varname is uint, else 0.
|
inherited |
Return its length if /c varName is a vector, 0 otherwise
|
inlineinherited |
Method with that u can secure already existing variables in a current open *.mat-file. By default variables get overwritten. If you disable overwriting and try to overwrite a secured variable, it will be asserted.
toOverWrite | Parameter to secure (false) or to unsecure (true) variables from overwriting. |
Definition at line 316 of file matfileIO.hh.
|
inherited |
Removes the requested variable named 'str' if it exist in the current matfile. Therefore, first the MatfileIO gets closed to finish writing and then a attempt to delete is performed. If the removal was successful it returns 1, else (i.e. the requested var does not exist in the *.mat-file) it returns 0.
|
inherited |
Method to reopen the *.mat-file that was once opened with the constructor. This could be used in combination with the close()-routine. It may has an application when using the same name for different variables in iterations, where they will be overwritten at each iteration.
|
protected |
Stores data hold by dense_ptr
.
Definition at line 209 of file matlabBinaryGraphics.hh.
|
protected |
Information which data should be stored.
Definition at line 134 of file matlabBinaryGraphics.hh.
|
staticinherited |
Definition at line 78 of file denseMatrixGraphics.hh.