00001 /* _______ __ 00002 / ___/ / ___ __ _ / / ___ 00003 / /__/ _ \/ _ \/ ' \/ _ \/ _ \ 00004 \___/_//_/\___/_/_/_/_.__/\___/ 00005 */ 00006 // 00007 // This software is copyright (C) by the Lawrence Berkeley 00008 // National Laboratory. Permission is granted to reproduce 00009 // this software for non-commercial purposes provided that 00010 // this notice is left intact. 00011 // 00012 // It is acknowledged that the U.S. Government has rights to 00013 // this software under Contract DE-AC03-765F00098 between 00014 // the U.S. Department of Energy and the University of 00015 // California. 00016 // 00017 // This software is provided as a professional and academic 00018 // contribution for joint exchange. Thus it is experimental, 00019 // is provided ``as is'', with no warranties of any kind 00020 // whatsoever, no support, no promise of updates, or printed 00021 // documentation. By using this software, you acknowledge 00022 // that the Lawrence Berkeley National Laboratory and 00023 // Regents of the University of California shall have no 00024 // liability with respect to the infringement of other 00025 // copyrights by any part of this software. 00026 // 00027 00028 #ifndef ROTORMHDIBC_H_ 00029 #define ROTORMHDIBC_H_ 00030 00031 #include <iostream> 00032 00033 #include "LevelData.H" 00034 #include "FArrayBox.H" 00035 #include "Vector.H" 00036 #include "RealVect.H" 00037 #include "AMRIO.H" 00038 00039 #include "PhysIBC.H" 00040 00041 class RotorMHDIBC:public PhysIBC 00042 { 00043 public: 00045 00047 RotorMHDIBC(); 00048 00050 00052 RotorMHDIBC(const Real& a_gamma); 00053 00055 00057 ~RotorMHDIBC() {}; 00058 00060 00062 void setFortranCommon(const Real& a_gamma); 00063 00065 00070 void setFortranCommonSet(); 00071 00073 00078 PhysIBC *new_physIBC(); 00079 00081 00083 void fluxBC(FArrayBox& a_F, 00084 const FArrayBox& a_W, 00085 const FArrayBox& a_Wextrap, 00086 const int& a_dir, 00087 const Side::LoHiSide& a_side, 00088 const Real& a_time); 00089 00091 00096 void setBdrySlopes(FArrayBox& a_dW, 00097 const FArrayBox& a_W, 00098 const int& a_dir, 00099 const Real& a_time); 00100 00102 00104 void initialize(LevelData<FArrayBox>& a_U); 00105 00106 protected: 00107 // True if the Fortran common block has been set 00108 bool m_isFortranCommonSet; 00109 }; 00110 00111 #endif