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 // ANAG, LBNL 00028 00029 #ifndef _IrregNodeNode_H_ 00030 #define _IrregNodeNode_H_ 00031 00032 #include "REAL.H" 00033 #include "IntVect.H" 00034 #include "IntVectSet.H" 00035 #include "VolIndex.H" 00036 #include "Interval.H" 00037 #include "FaceIndex.H" 00038 #include "IntVectSet.H" 00039 #include "RealVect.H" 00040 #include "BaseFab.H" 00041 #include "SPMD.H" 00043 00046 class IrregNode 00047 { 00048 public: 00050 IrregNode(); 00051 00053 ~IrregNode(); 00054 00056 int index(int a_idir, Side::LoHiSide a_side) const; 00057 00059 IntVect m_cell; 00061 00062 //volume centered data 00064 Real m_volFrac; 00065 00067 00070 int m_cellIndex; 00071 00073 RealVect m_volCentroid; 00074 00076 RealVect m_bndryCentroid; 00077 00078 //face centered irregular data 00079 00081 00089 Vector<int> m_arc[2*SpaceDim]; 00090 00092 Vector<Real> m_areaFrac[2*SpaceDim]; 00093 00095 Vector<RealVect> m_faceCentroid[2*SpaceDim]; 00096 00097 00099 00105 void makeRegular(const IntVect& iv); 00106 void faceReserve(int location, int size); 00107 }; 00108 #endif