2017-01-05 14:33:13 +00:00
|
|
|
// adiabaticwall.cpp
|
|
|
|
//
|
|
|
|
// last-edit-by: J.A. de Jong
|
|
|
|
//
|
|
|
|
// Description:
|
|
|
|
//
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
#include "adiabaticwall.h"
|
|
|
|
#include "ductbc.pb.h"
|
|
|
|
#include "tasmet_tracer.h"
|
|
|
|
#include "tasmet_assert.h"
|
2017-01-08 19:55:03 +00:00
|
|
|
#include "tasystem.h"
|
|
|
|
#include "duct.h"
|
2017-01-05 14:33:13 +00:00
|
|
|
|
2017-01-22 09:34:46 +00:00
|
|
|
AdiabaticWall::AdiabaticWall(const TaSystem& sys,
|
|
|
|
const us id,
|
|
|
|
const pb::DuctBc& dbc):
|
|
|
|
DuctBc(sys,id,dbc)
|
2017-01-08 19:55:03 +00:00
|
|
|
|
2017-01-05 14:33:13 +00:00
|
|
|
{
|
|
|
|
TRACE(15,"AdiabaticWall(id,sys,dbc)");
|
|
|
|
tasmet_assert(dbc.type() == pb::AdiabaticWall,"Wrong type given to constructor");
|
|
|
|
|
|
|
|
}
|
2017-01-22 09:34:46 +00:00
|
|
|
AdiabaticWall::AdiabaticWall(const TaSystem& sys,
|
|
|
|
const AdiabaticWall& o):
|
|
|
|
DuctBc(sys,o)
|
2017-01-08 19:55:03 +00:00
|
|
|
{
|
2017-01-05 14:33:13 +00:00
|
|
|
TRACE(15,"AdiabaticWall(o)");
|
|
|
|
|
|
|
|
}
|
|
|
|
AdiabaticWall::~AdiabaticWall() {
|
|
|
|
|
|
|
|
}
|
2017-01-22 09:34:46 +00:00
|
|
|
AdiabaticWall* AdiabaticWall::copy(const TaSystem& sys) const {
|
|
|
|
return new AdiabaticWall(sys,*this);
|
2017-01-05 14:33:13 +00:00
|
|
|
}
|
2017-01-22 09:34:46 +00:00
|
|
|
vd AdiabaticWall::initialSolution() const {
|
2017-01-05 14:33:13 +00:00
|
|
|
return vd();
|
|
|
|
}
|
|
|
|
|
2017-01-22 09:34:46 +00:00
|
|
|
void AdiabaticWall::residualJac(arma::subview_col<d>&& residual
|
2017-01-08 19:55:03 +00:00
|
|
|
) const {
|
2017-01-05 14:33:13 +00:00
|
|
|
|
|
|
|
TRACE(15,"AdiabaticWall::residual()");
|
2017-01-15 19:56:12 +00:00
|
|
|
const pb::Duct& dpb = getDuct(sys).getDuctPb();
|
|
|
|
us Ns = sys.Ns();
|
|
|
|
|
|
|
|
const Duct& duct = getDuct(sys);
|
|
|
|
if(_side == pb::left) {
|
|
|
|
residual.subvec(0,Ns-1) = duct.ut(sys,0);
|
|
|
|
if(dpb.htmodel() != pb::Isentropic) {
|
|
|
|
// TODO: Put the boundary condition of zero heat flux here
|
|
|
|
// residual.subvec(Ns,2*Ns-1) =
|
|
|
|
tasmet_assert(false,"");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
residual.subvec(0,Ns-1) = duct.ut(sys,-1);
|
|
|
|
if(dpb.htmodel() != pb::Isentropic) {
|
|
|
|
// TODO: Put the boundary condition of zero heat flux here
|
|
|
|
// residual.subvec(Ns,2*Ns-1) = duct.Tt(sys,-1) - _T;
|
|
|
|
tasmet_assert(false,"");
|
|
|
|
}
|
|
|
|
}
|
2017-01-05 14:33:13 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2017-01-22 09:34:46 +00:00
|
|
|
us AdiabaticWall::getNEqs() const {
|
2017-01-05 14:33:13 +00:00
|
|
|
TRACE(15,"AdiabaticWall::getNEqs()");
|
2017-01-08 19:55:03 +00:00
|
|
|
// u = 0
|
2017-01-15 19:56:12 +00:00
|
|
|
// dT/dx = 0 --> if htmodel is not Isentropic
|
|
|
|
// dTs/dx = 0 => if stempmodel is not Prescribed
|
|
|
|
|
|
|
|
const pb::Duct& dpb = getDuct(sys).getDuctPb();
|
|
|
|
|
|
|
|
bool has_solideq = dpb.stempmodel() != pb::Prescribed;
|
|
|
|
|
|
|
|
us neqs = sys.Ns()*(has_solideq ? 2: 1);
|
|
|
|
if(dpb.htmodel() != pb::Isentropic) neqs+= sys.Ns();
|
|
|
|
|
|
|
|
VARTRACE(15,neqs);
|
|
|
|
return neqs;
|
2017-01-05 14:33:13 +00:00
|
|
|
}
|
2017-01-22 09:34:46 +00:00
|
|
|
void AdiabaticWall::show(us verbosity_level) const {
|
2017-01-05 14:33:13 +00:00
|
|
|
TRACE(15,"AdiabaticWall::show()");
|
|
|
|
}
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|