00001 /* _______ __ 00002 / ___/ / ___ __ _ / / ___ 00003 / /__/ _ \/ _ \/ ' \/ _ \/ _ \ 00004 \___/_//_/\___/_/_/_/_.__/\___/ 00005 */ 00006 00007 // basicScalBC.H 00008 00009 // 00010 // This software is copyright (C) by the Lawrence Berkeley 00011 // National Laboratory. Permission is granted to reproduce 00012 // this software for non-commercial purposes provided that 00013 // this notice is left intact. 00014 // 00015 // It is acknowledged that the U.S. Government has rights to 00016 // this software under Contract DE-AC03-765F00098 between 00017 // the U.S. Department of Energy and the University of 00018 // California. 00019 // 00020 // This software is provided as a professional and academic 00021 // contribution for joint exchange. Thus it is experimental, 00022 // is provided ``as is'', with no warranties of any kind 00023 // whatsoever, no support, no promise of updates, or printed 00024 // documentation. By using this software, you acknowledge 00025 // that the Lawrence Berkeley National Laboratory and 00026 // Regents of the University of California shall have no 00027 // liability with respect to the infringement of other 00028 // copyrights by any part of this software. 00029 // 00030 // Dan Martin, Fri, Jan 14, 2000 00031 00032 #ifndef _basicScalBC_H_ 00033 #define _basicScalBC_H_ 00034 00035 #include "FArrayBox.H" 00036 #include "REAL.H" 00037 #include "LevelData.H" 00038 #include "GhostBC.H" 00039 00040 00042 class basicScalBC 00043 { 00044 public: 00045 00047 basicScalBC(); 00048 00050 virtual ~basicScalBC(); 00051 00053 virtual void setBCType(const DomainGhostBC& a_ghostBC); 00054 00056 virtual void setAllBCTypes() = 0; 00057 00059 basicScalBC(); 00060 00062 virtual void applyBCs(FArrayBox& a_state, 00063 const ProblemDomain& a_domain, 00064 const Real a_dx) const; 00065 00067 virtual void applyBCs(LevelData<FArrayBox>& a_stateMF, 00068 const ProblemDomain& a_domain, 00069 const Real a_dx) const; 00070 00071 00073 virtual void applyBCs(FArrayBox& a_state, const Box& a_domain, 00074 const Real a_dx) const; 00075 00077 virtual void applyBCs(LevelData<FArrayBox>& a_stateMF, 00078 const Box& a_domain, const Real a_dx) const; 00079 00080 00081 00082 protected: 00083 DomainGhostBC* m_componentBC; 00084 00085 private: 00086 00087 }; 00088 00089 00090 #endif 00091 00092