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 NODEMGINTERP2_H 00029 #define NODEMGINTERP2_H 00030 00031 #include "REAL.H" 00032 #include "LevelData.H" 00033 #include "NodeFArrayBox.H" 00034 00036 00042 class NodeMGInterp2 00043 { 00044 public: 00046 NodeMGInterp2(); 00047 00049 ~NodeMGInterp2(); 00050 00052 NodeMGInterp2(const DisjointBoxLayout& a_grids, 00053 int a_numcomps, 00054 Real a_dx); 00055 00057 00060 void define(const DisjointBoxLayout& a_grids, // the fine-level grids 00061 int a_numcomps, // number of components 00062 Real a_dx); 00063 00065 00067 void getWeights(const DisjointBoxLayout& a_gridsFine, 00068 Real a_dx); 00069 00071 00077 void interpToFine(LevelData<NodeFArrayBox>& a_fine, 00078 const LevelData<NodeFArrayBox>& a_coarse, 00079 bool a_sameGrids = false); 00080 00082 bool isDefined() const; 00083 00084 00085 protected: 00086 bool is_defined; 00087 00088 // the refinement ratio 00089 int m_refRatio; 00090 00091 // work array for the coarse level data in a domain that is the 00092 // outline of the fine level domain on the coarse level 00093 BoxLayoutData<NodeFArrayBox> m_coarsenedFine; 00094 00095 DisjointBoxLayout m_grids; 00096 00097 // reference box for FORT_NODEINTERPMG 00098 Box m_boxRef; 00099 00100 // weights for FORT_NODEINTERPMG 00101 BoxLayoutData<NodeFArrayBox> m_weights; 00102 }; 00103 00104 #endif