Rheolef  7.2
an efficient C++ finite element environment
 
Loading...
Searching...
No Matches
transport_tensor_error_dg.cc

The tensorial transport benchmark – error computation.

The tensorial transport benchmark – error computation

#include "rheolef.h"
using namespace rheolef;
using namespace std;
int main(int argc, char**argv) {
environment rheolef (argc, argv);
Float tol = (argc > 1) ? atof(argv[1]) : 1e-10;
bool dump = (argc > 2);
Float nu, t0;
field sigma_h;
din >> catchmark("nu") >> nu
>> catchmark("t0") >> t0
>> catchmark("sigma") >> sigma_h;
size_t k = sigma_h.get_space().degree();
iopt.set_family(integrate_option::gauss);
iopt.set_order(3*(k+1));
Float err_l2 = sqrt(integrate (sigma_h.get_geo(), norm2(sigma_h - sigma_exact(nu,t0)), iopt));
space Th1 (sigma_h.get_geo(), "P"+to_string(3*(k+1))+"d", "tensor");
field eh = lazy_interpolate(Th1, sigma_h - sigma_exact(nu,t0));
Float err_linf = eh.max_abs();
dout << "err_l2 = " << err_l2 << endl
<< "err_linf = " << err_linf << endl;
return (err_l2 < tol) ? 0 : 1;
}
see the Float page for the full documentation
see the field page for the full documentation
see the catchmark page for the full documentation
Definition catchmark.h:67
see the environment page for the full documentation
see the integrate_option page for the full documentation
void set_family(family_type type)
see the space page for the full documentation
int main()
Definition field2bb.cc:58
verbose clean transpose logscale grid shrink ball stereo iso volume skipvtk deformation fastfieldload lattice reader_on_stdin color format format format format format format format format format format format format format format format format format format dump
This file is part of Rheolef.
STL namespace.
rheolef - reference manual
Definition nu.h:26
The tensorial transport benchmark – right-hand-side and exact solution.