65 using namespace navier;
71 double t_final = 250*dt;
74 double fluid_kin_vis = 0.001;
77 int ode_solver_type = 3;
78 double alpha = 1.0e-2;
120 virtual void ImplicitSolve(
const double dt,
const Vector &
u,
Vector &k);
125 virtual ~ConductionOperator();
130 int x = 0,
int y = 0,
int w = 400,
int h = 400,
133 int main(
int argc,
char *argv[])
137 MPI_Init(&argc, &argv);
138 MPI_Comm_size(MPI_COMM_WORLD, &num_procs);
139 MPI_Comm_rank(MPI_COMM_WORLD, &myid);
145 rs_levels(lim_meshes);
148 bool visualization =
true;
151 args.
AddOption(&np_list[0],
"-np1",
"--np1",
152 "number of MPI ranks for mesh 1");
153 args.
AddOption(&np_list[1],
"-np2",
"--np2",
154 "number of MPI ranks for mesh 1");
155 args.
AddOption(&rs_levels[0],
"-r1",
"--refine-serial 1",
156 "Number of times to refine the mesh 1 uniformly in serial.");
157 args.
AddOption(&rs_levels[1],
"-r2",
"--refine-serial 2",
158 "Number of times to refine the mesh 2 uniformly in serial.");
159 args.
AddOption(&visualization,
"-vis",
"--visualization",
"-no-vis",
160 "--no-visualization",
161 "Enable or disable GLVis visualization.");
174 const int nmeshes = 2;
175 mesh_file_list[0] =
"fluid-cht.mesh";
176 mesh_file_list[1] =
"solid-cht.mesh";
179 MPI_Comm *comml =
new MPI_Comm;
182 for (
int i = 0; i < nmeshes; i++)
185 if (myid < npsum) { color = i;
break; }
187 MPI_Comm_split(MPI_COMM_WORLD, color, myid, comml);
188 int myidlocal, numproclocal;
189 MPI_Comm_rank(*comml, &myidlocal);
190 MPI_Comm_size(*comml, &numproclocal);
192 Mesh *mesh =
new Mesh(mesh_file_list[color], 1, 1);
196 for (
int lev = 0; lev < rs_levels[color]; lev++)
202 if (color == 0 && myidlocal == 0)
204 std::cout <<
"Number of elements: " << mesh->
GetNE() << std::endl;
209 pmesh =
new ParMesh(*comml, *mesh);
219 ConductionOperator *coper = NULL;
225 bool last_step =
false;
247 flowsolver->
Setup(dt);
256 switch (
schwarz.ode_solver_type)
264 case 12: ode_solver =
new RK2Solver(0.5);
break;
266 case 14: ode_solver =
new RK4Solver;
break;
273 std::cout <<
"Unknown ODE solver type: " <<
schwarz.ode_solver_type <<
'\n';
296 finder.
Setup(*pmesh, color);
301 for (
int i = 0; i < color_array.
Size(); i++)
303 color_array[i] = (
unsigned int)color;
310 finder.
Interpolate(vxyz, color_array, *u_gf, interp_vals);
318 coper =
new ConductionOperator(*fes_s,
schwarz.alpha,
schwarz.kappa,
320 coper->SetParameters(adv_gf_c);
327 int Ww = 350,
Wh = 350;
328 int Wx = color*Ww+10,
Wy = 0;
334 "Velocity", Wx, Wy, Ww,
Wh);
339 "Temperature", Wx, Wy, Ww,
Wh);
343 if (ode_solver) { ode_solver->
Init(*coper); }
345 for (
int step = 0; !last_step; ++step)
347 if (t + dt >= t_final - dt / 2)
355 flowsolver->
Step(t, dt, step);
360 ode_solver->
Step(t_tdof, t, dt);
363 finder.
Interpolate(vxyz, color_array, *u_gf, interp_vals);
368 coper->SetParameters(adv_gf_c);
376 "Velocity", Wx, Wy, Ww,
Wh);
381 "Temperature", Wx, Wy, Ww,
Wh);
385 if (color == 0 && myidlocal == 0)
387 printf(
"%11s %11s %11s\n",
"Time",
"dt",
"CFL");
388 printf(
"%.5E %.5E %.5E\n", t, dt,cfl);
398 if (color == 1) {
delete u_gf; }
416 T(NULL), current_dt(0.0),
417 M_solver(f.GetComm()), T_solver(f.GetComm()), udir(10), z(height)
419 const double rel_tol = 1e-8;
433 M->FormSystemMatrix(ess_tdof_list, Mmat);
435 M_solver.iterative_mode =
false;
436 M_solver.SetRelTol(rel_tol);
437 M_solver.SetAbsTol(0.0);
438 M_solver.SetMaxIter(100);
439 M_solver.SetPrintLevel(0);
440 M_prec.SetType(HypreSmoother::Jacobi);
441 M_solver.SetPreconditioner(M_prec);
442 M_solver.SetOperator(Mmat);
447 T_solver.iterative_mode =
false;
448 T_solver.SetRelTol(rel_tol);
449 T_solver.SetAbsTol(0.0);
450 T_solver.SetMaxIter(100);
451 T_solver.SetPrintLevel(0);
452 T_solver.SetPreconditioner(T_prec);
454 SetParameters(adv_gf_c);
465 K->EliminateVDofsInRHS(ess_tdof_list, u, z);
467 M_solver.Mult(z, du_dt);
472 void ConductionOperator::ImplicitSolve(
const double dt,
480 T =
Add(1.0, Mmat, dt, Kmat);
482 T_solver.SetOperator(*T);
484 MFEM_VERIFY(dt == current_dt,
"");
487 K->EliminateVDofsInRHS(ess_tdof_list, u, z);
489 T_solver.Mult(z, du_dt);
497 u_alpha_gf.ProjectCoefficient(kapfuncoef);
507 K->FormSystemMatrix(ess_tdof_list, Kmat);
512 ConductionOperator::~ConductionOperator()
521 int x,
int y,
int w,
int h,
bool vec)
525 MPI_Comm comm = pmesh.
GetComm();
528 MPI_Comm_size(comm, &num_procs);
529 MPI_Comm_rank(comm, &myid);
531 bool newly_opened =
false;
532 int connection_failed;
540 sock.
open(vishost, visport);
544 sock <<
"solution\n";
550 if (myid == 0 && newly_opened)
553 ?
"mAcRjlmm" :
"mmaaAcl";
555 sock <<
"window_title '" << title <<
"'\n"
556 <<
"window_geometry "
557 << x <<
" " << y <<
" " << w <<
" " << h <<
"\n"
559 if ( vec ) { sock <<
"vvv"; }
565 connection_failed = !sock && !newly_opened;
567 MPI_Bcast(&connection_failed, 1, MPI_INT, 0, comm);
569 while (connection_failed);
581 if (std::fabs(xi+2.5)<1.e-5) {
u(0) = 0.25*yi*(3-yi)/(1.5*1.5); }
588 return x(1) <= 1.0 && std::fabs(x(0)) < 0.5 ? 5.: 1.0;
597 t_init = 10*(std::exp(-x(1)*x(1)));
599 if (std::fabs(x(0)) >= 0.5)
601 double dx = std::fabs(x(0))-0.5;
602 t_init *= std::exp(-10*dx*dx);
void PrintTimingData()
Print timing summary of the solving routine.
int Size() const
Return the logical size of the array.
void SetSubVector(const Array< int > &dofs, const double value)
Set the entries listed in dofs to the given value.
virtual void GetEssentialTrueDofs(const Array< int > &bdr_attr_is_ess, Array< int > &ess_tdof_list, int component=-1)
Conjugate gradient method.
ParMesh * GetParMesh() const
double kappa_fun(const Vector &x)
Solid data.
Base abstract class for first order time dependent operators.
Vector coefficient that is constant in space and time.
void Mult(const Table &A, const Table &B, Table &C)
C = A * B (as boolean matrices)
virtual void Step(Vector &x, double &t, double &dt)=0
Perform a time step from time t [in] to time t [out] based on the requested step size dt [in]...
void vel_dbc(const Vector &x, double t, Vector &u)
Fluid data.
Coefficient defined by a GridFunction. This coefficient is mesh dependent.
int Size() const
Returns the size of the vector.
Abstract class for solving systems of ODEs: dx/dt = f(x,t)
int GetNE() const
Returns number of elements.
Abstract parallel finite element space.
virtual void ProjectCoefficient(Coefficient &coeff)
Project coeff Coefficient to this GridFunction. The projection computation depends on the choice of t...
Backward Euler ODE solver. L-stable.
struct schwarz_common schwarz
void Setup(double dt)
Initialize forms, solvers and preconditioners.
void Add(const DenseMatrix &A, const DenseMatrix &B, double alpha, DenseMatrix &C)
C = A + alpha*B.
void SetTrueVector()
Shortcut for calling GetTrueDofs() with GetTrueVector() as argument.
virtual void SetFromTrueDofs(const Vector &tv)
Set the GridFunction from the given true-dof vector.
void Parse()
Parse the command-line options. Note that this function expects all the options provided through the ...
double ComputeCFL(ParGridFunction &u, double dt)
Compute CFL.
OversetFindPointsGSLIB enables use of findpts for arbitrary number of overlapping grids...
Mesh * GetMesh() const
Returns the mesh.
void UniformRefinement(int i, const DSTable &, int *, int *, int *)
virtual void SetCurvature(int order, bool discont=false, int space_dim=-1, int ordering=1)
T Max() const
Find the maximal element in the array, using the comparison operator < for class T.
void EnablePA(bool pa)
Enable partial assembly for every operator.
void AddVelDirichletBC(VectorCoefficient *coeff, Array< int > &attr)
Add a Dirichlet boundary condition to the velocity field.
Parallel smoothers in hypre.
void VisualizeField(socketstream &sock, const char *vishost, int visport, ParGridFunction &gf, const char *title, int x=0, int y=0, int w=400, int h=400, bool vec=false)
FiniteElementSpace * FESpace()
void PrintUsage(std::ostream &out) const
Print the usage message.
virtual const double * HostRead() const
Shortcut for mfem::Read(vec.GetMemory(), vec.Size(), false).
The classical explicit forth-order Runge-Kutta method, RK4.
Array< int > bdr_attributes
A list of all unique boundary attributes used by the Mesh.
bool is_open()
True if the socketstream is open, false otherwise.
void Print(std::ostream &out=mfem::out, int width=8) const
Prints vector to stream out.
void AddOption(bool *var, const char *enable_short_name, const char *enable_long_name, const char *disable_short_name, const char *disable_long_name, const char *description, bool required=false)
Add a boolean option and set 'var' to receive the value. Enable/disable tags are used to set the bool...
void SetSize(int nsize)
Change the logical size of the array, keep existing entries.
Third-order, strong stability preserving (SSP) Runge-Kutta method.
ParGridFunction * GetCurrentVelocity()
Return a pointer to the current velocity ParGridFunction.
void SaveAsOne(const char *fname, int precision=16) const
Implicit midpoint method. A-stable, not L-stable.
void SetGridFunction(const GridFunction *gf)
Set the grid function for this coefficient. Also sets the Vector dimension to match that of the gf...
void PrintOptions(std::ostream &out) const
Print the options.
void Interpolate(const Vector &point_pos, Array< unsigned int > &point_id, const GridFunction &field_in, Vector &field_out)
HypreParVector * GetTrueDofs() const
Returns the true dofs in a new HypreParVector.
int open(const char hostname[], int port)
Open the socket stream on 'port' at 'hostname'.
double temp_init(const Vector &x)
A general function coefficient.
void GetNodes(Vector &node_coord) const
Vector coefficient defined by a vector GridFunction.
void PrintAsOne(std::ostream &out=mfem::out) const
Arbitrary order H1-conforming (continuous) finite elements.
void Step(double &time, double dt, int cur_step, bool provisional=false)
Compute solution at the next time step t+dt.
double u(const Vector &xvec)
Class for parallel grid function.
The classical forward Euler method.
Wrapper for hypre's ParCSR matrix class.
Class for parallel meshes.
Transient incompressible Navier Stokes solver in a split scheme formulation.
void Setup(Mesh &m, const int meshid, GridFunction *gfmax=NULL, const double bb_t=0.1, const double newt_tol=1.0e-12, const int npt_max=256)
virtual void Init(TimeDependentOperator &f_)
Associate a TimeDependentOperator with the ODE solver.
double f(const Vector &p)
ParFiniteElementSpace * ParFESpace() const
bool Good() const
Return true if the command line options were parsed successfully.