Rheolef  7.1
an efficient C++ finite element environment
convect_hdg.cc
Go to the documentation of this file.
1 #include "rheolef.h"
26 using namespace rheolef;
27 using namespace std;
28 #include "rotating-hill-statio.h"
29 int main (int argc, char **argv) {
30  environment rheolef (argc,argv);
31  geo omega (argv[1]);
32  string approx = (argc > 2) ? argv[2] : "P1d";
33  Float nu = (argc > 3) ? atof(argv[3]) : 1e-2;
34  Float beta = (argc > 4) ? atof(argv[4]) : 1;
35  space Th (omega, approx, "vector"),
36  Xh (omega, approx),
37  Yh = Th*Xh,
38  Mh (omega["sides"], approx);
39  Mh.block("boundary");
40  space Wh(Mh.get_geo()["boundary"],approx);
41  size_t d = omega.dimension();
42  trial x(Yh);
43  trial lambda(Mh);
44  test y(Yh);
45  test mu(Mh);
46  integrate_option iopt;
47  iopt.invert = true;
48  form inv_a = integrate((1/nu)*dot(x[0],y[0]) + x[1]*div_h(y[0])
49  + y[1]*div_h(x[0]) - phi::sigma(d,nu)*x[1]*y[1]
50  + x[1]*dot(u(d),grad_h(y[1]))
51  - on_local_sides((beta+abs(dot(u(d),normal())))*x[1]*y[1]), iopt);
52  form b1 = integrate("internal_sides", (-dot(jump(x[0]),normal())
53  + 2*(beta+abs(dot(u(d),normal())))*average(x[1])
54  - dot(u(d),normal())*jump(x[1]))*mu);
55  form b2 = integrate("internal_sides", (-dot(jump(x[0]),normal())
56  + 2*(beta+abs(dot(u(d),normal())))*average(x[1]))*mu);
57  form c = integrate("internal_sides",
58  2*(beta+abs(dot(u(d),normal())))*lambda*mu);
59  field lh = integrate(omega, -f(d,nu)*y[1])
60  + integrate("boundary", phi(d,nu)*(dot(y[0],normal())
61  - (beta+abs(dot(u(d),normal()))-dot(u(d),normal()))*y[1]));
62  field kh(Mh,0), lambda_h(Mh,0);
63  lambda_h["boundary"] = interpolate(Wh,phi(d,nu));
64  form s = c + b2*inv_a*trans(b1);
65  field rh = b2*(inv_a*lh) - kh;
66  problem p(s);
67  p.solve (rh, lambda_h);
68  field xh = inv_a*(lh - b1.trans_mult(lambda_h));
69  dout << catchmark("nu") << nu << endl
70  << catchmark("phi") << xh[1]
71  << catchmark("sigma") << xh[0]
72  << catchmark("lambda") << lambda_h;
73 }
form
see the form page for the full documentation
rheolef::catchmark
see the catchmark page for the full documentation
Definition: catchmark.h:67
rheolef::dot
rheolef::std enable_if ::type dot const Expr1 expr1, const Expr2 expr2 dot(const Expr1 &expr1, const Expr2 &expr2)
dot(x,y): see the expression page for the full documentation
Definition: vec_expr_v2.h:415
field
see the field page for the full documentation
rheolef::normal
details::field_expr_v2_nonlinear_terminal_function< details::normal_pseudo_function< Float > > normal()
normal: see the expression page for the full documentation
Definition: field_expr_terminal.h:439
mkgeo_ball.f
int f
Definition: mkgeo_ball.sh:221
nu
Definition: nu.h:26
rheolef::integrate
std::enable_if< details::is_field_expr_v2_nonlinear_arg< Expr >::value &&! is_undeterminated< Result >::value, Result >::type integrate(const geo_basic< T, M > &omega, const Expr &expr, const integrate_option &iopt, Result dummy=Result())
see the integrate page for the full documentation
Definition: integrate.h:202
mkgeo_ball.d
int d
Definition: mkgeo_ball.sh:154
phi
Float phi(const point &nu, Float a, Float b)
Definition: burgers_flux_godunov.icc:25
space
see the space page for the full documentation
rheolef::div_h
std::enable_if< details::is_field_convertible< Expr >::value,details::field_expr_v2_nonlinear_terminal_field< typename Expr::scalar_type,typename Expr::memory_type,details::differentiate_option::divergence >>::type div_h(const Expr &expr)
div_h(uh): see the expression page for the full documentation
Definition: field_expr_terminal.h:1069
rheolef.h
rheolef - reference manual
p
Definition: sphere.icc:25
rheolef::integrate_option
see the integrate_option page for the full documentation
Definition: integrate_option.h:125
rheolef::on_local_sides
std::enable_if< details::is_field_expr_v2_variational_arg< Expr >::value,details::field_expr_quadrature_on_sides< Expr > >::type on_local_sides(const Expr &expr)
on_local_sides(expr): see the expression page for the full documentation
Definition: field_expr_quadrature.h:321
rheolef::interpolate
field_basic< T, M > interpolate(const space_basic< T, M > &V2h, const field_basic< T, M > &u1h)
see the interpolate page for the full documentation
Definition: interpolate.cc:233
main
int main(int argc, char **argv)
Definition: convect_hdg.cc:29
rheolef::environment
see the environment page for the full documentation
Definition: environment.h:115
lh
field lh(Float epsilon, Float t, const test &v)
Definition: burgers_diffusion_operators.icc:25
rheolef
This file is part of Rheolef.
Definition: compiler_eigen.h:37
rheolef::integrate_option::invert
bool invert
Definition: integrate_option.h:168
test
see the test page for the full documentation
problem
see the problem page for the full documentation
Float
see the Float page for the full documentation
u
Float u(const point &x)
Definition: transmission_error.cc:26
rotating-hill-statio.h
phi::sigma
Float sigma
Definition: transport_dg_error.cc:27
mkgeo_contraction.mu
mu
Definition: mkgeo_contraction.sh:193
rheolef::grad_h
std::enable_if< details::is_field_convertible< Expr >::value,details::field_expr_v2_nonlinear_terminal_field< typename Expr::scalar_type,typename Expr::memory_type,details::differentiate_option::gradient >>::type grad_h(const Expr &expr)
grad_h(uh): see the expression page for the full documentation
Definition: field_expr_terminal.h:949
trial
see the test page for the full documentation
rheolef::dout
odiststream dout(cout)
see the diststream page for the full documentation
Definition: diststream.h:430
rheolef::trans
csr< T, sequential > trans(const csr< T, sequential > &a)
trans(a): see the form page for the full documentation
Definition: csr.h:455
rheolef::std
Definition: vec_expr_v2.h:402
geo
see the geo page for the full documentation
mkgeo_ball.c
int c
Definition: mkgeo_ball.sh:153
rk::beta
Float beta[][pmax+1]
Definition: runge_kutta_semiimplicit.icc:60
lambda
Definition: yield_slip_circle.h:34