当前位置: 首页>>代码示例>>C++>>正文


C++ input::PressureOutletP方法代码示例

本文整理汇总了C++中input::PressureOutletP方法的典型用法代码示例。如果您正苦于以下问题:C++ input::PressureOutletP方法的具体用法?C++ input::PressureOutletP怎么用?C++ input::PressureOutletP使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在input的用法示例。


在下文中一共展示了input::PressureOutletP方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: GetGhostState


//.........这里部分代码省略.........
      ghostState.data[1] = (*this).U() + normArea.X() * ( (*this).P() - ghostState.P() ) / rhoSoSInt;
      ghostState.data[2] = (*this).V() + normArea.Y() * ( (*this).P() - ghostState.P() ) / rhoSoSInt;
      ghostState.data[3] = (*this).W() + normArea.Z() * ( (*this).P() - ghostState.P() ) / rhoSoSInt;
    }
    else {
      cerr << "ERROR: flow condition for characteristic BC is not recognized!" << endl;
      cerr << "Interior state: " << (*this) << endl;
      cerr << "Ghost state: " << ghostState << endl;
      exit(0);
    }

    if (layer == 2){ //extrapolate to get ghost state at 2nd layer
      ghostState = 2.0 * ghostState - (*this);
    }

  }
  //supersonic inflow boundary condition ------------------------------------------------------------------------------------------------------------
  //this boundary condition enforces the entire state as the specified freestream state
  else if (bcType == "supersonicInflow"){
    //physical boundary conditions - fix everything
    double sos = eqnState.GetSoS(inputVars.PRef(),inputVars.RRef());
    vector3d<double> vel = inputVars.VelRef() / sos;                       //nondimensional velocity
    ghostState.data[0] = 1.0; //nondimensional density
    ghostState.data[1] = vel.X();
    ghostState.data[2] = vel.Y();
    ghostState.data[3] = vel.Z();
    ghostState.data[4] = 1.0 / eqnState.Gamma(); //nondimensional pressure
  }
  //supersonic outflow boundary condition ------------------------------------------------------------------------------------------------------------
  //this boundary condition enforces the entire state as extrapolated from the interior (zeroth order extrapolation)
  else if (bcType == "supersonicOutflow"){
    //do nothing and return boundary state -- numerical BCs for all
    if (layer == 2){ //extrapolate to get ghost state at 2nd layer
      ghostState = 2.0 * ghostState - (*this);
    }
  }
  //stagnation inlet boundary condition --------------------------------------------------------------------------------------------------------------
  //this boundary condition is appropriate for subsonic flow. It is particularly well suited for internal flows. Implementation from Blazek
  else if (bcType == "stagnationInlet"){
    double g = eqnState.Gamma() - 1.0;
    //calculate outgoing riemann invarient
    double rNeg = (*this).Velocity().DotProd(normArea) - 2.0 * (*this).SoS(eqnState) / g;

    //calculate SoS on boundary
    double cosTheta = -1.0 * (*this).Velocity().DotProd(normArea) / (*this).Velocity().Mag();
    double stagSoSsq = pow((*this).SoS(eqnState),2.0) + 0.5 * g * (*this).Velocity().MagSq();

    double sosB = -1.0 * rNeg * g / (g * cosTheta * cosTheta + 2.0) * (1.0 + cosTheta * sqrt( (g * cosTheta * cosTheta + 2.0) * stagSoSsq / 
											      (g * rNeg * rNeg) - 0.5 * g  ) );
    double tb = inputVars.StagInletT0() / inputVars.TRef() * (sosB * sosB / stagSoSsq);
    double aRef = eqnState.GetSoS(inputVars.PRef(),inputVars.RRef());
    double pb = inputVars.StagInletP0() / (inputVars.RRef() * aRef * aRef) * pow(sosB * sosB / stagSoSsq, eqnState.Gamma()/g);
    double vbMag = sqrt(2.0 / g * (inputVars.StagInletT0() / inputVars.TRef() - tb));

    ghostState.data[0] = eqnState.GetDensityTP(tb,pb);
    ghostState.data[1] = vbMag * inputVars.StagInletDx();
    ghostState.data[2] = vbMag * inputVars.StagInletDy();
    ghostState.data[3] = vbMag * inputVars.StagInletDz();
    ghostState.data[4] = pb;

    if (layer == 2){ //extrapolate to get ghost state at 2nd layer
      ghostState = 2.0 * ghostState - (*this);
    }

  }
  //pressure outlet boundary condition ---------------------------------------------------------------------------------------------------------------
  //this boundary condition is appropriate for subsonic flow. Implementation from Blazek
  else if (bcType == "pressureOutlet"){
    double aRef = eqnState.GetSoS(inputVars.PRef(),inputVars.RRef()); //reference speed of sound
    double pb = inputVars.PressureOutletP() / (inputVars.RRef() * aRef * aRef); //nondimensional pressure from input file

    double SoSInt = (*this).SoS(eqnState);
    double rhoSoSInt = (*this).Rho() * SoSInt;
    ghostState.data[4] = pb;
    ghostState.data[0] = (*this).Rho() + ( ghostState.P() - (*this).P() ) / (SoSInt * SoSInt);
    ghostState.data[1] = (*this).U() + normArea.X() * ( (*this).P() - ghostState.P() ) / rhoSoSInt;
    ghostState.data[2] =  (*this).V() + normArea.Y() * ( (*this).P() - ghostState.P() ) / rhoSoSInt;
    ghostState.data[3] =  (*this).W() + normArea.Z() * ( (*this).P() - ghostState.P() ) / rhoSoSInt;

    if (layer == 2){ //extrapolate to get ghost state at 2nd layer
      ghostState = 2.0 * ghostState - (*this);
    }

  }
  //interblock boundary condition ---------------------------------------------------------------------------------------------------------------
  //this boundary condition is appropriate for point matched interfaces between physical blocks or processor blocks
  else if (bcType == "interblock"){
    //do nothing -- assign interior state to ghost state (already done)
    //for second layer of ghost cells interior state should be 2nd interior cell

  }
  else {
    cerr << "ERROR: Error in primVars::GetGhostState ghost state for BC type " << bcType << " is not supported!" << endl;
    cerr << "surface is " << surf << endl;
    exit(0);
  }

  return ghostState;

}
开发者ID:Nasrollah,项目名称:cfd3d,代码行数:101,代码来源:primVars.cpp


注:本文中的input::PressureOutletP方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。