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 _VolIndex_H_ 00030 #define _VolIndex_H_ 00031 00032 #include "REAL.H" 00033 #include "IntVect.H" 00034 #include "SPMD.H" 00035 00037 00045 class VolIndex 00046 { 00047 public: 00049 VolIndex(); 00050 00052 ~VolIndex(); 00053 00055 VolIndex& operator= (const VolIndex& a_vofin); 00056 00058 bool operator== (const VolIndex& a_vofin) const; 00059 00061 const IntVect& gridIndex() const; 00062 00064 const int& cellIndex() const; 00065 00067 bool isDefined() const; 00068 00070 VolIndex(const VolIndex& a_vofin); 00071 00073 void define(const VolIndex& a_vofin); 00074 00076 VolIndex(const IntVect& a_ix,const int& a_vofID); 00077 00079 void define(const IntVect& a_ix,const int& a_vofID); 00080 00081 // not for users 00082 static size_t iv_offset, index_offset; 00083 static int initializeOffsets(); 00084 00085 private: 00086 00087 00088 //cell of the VolIndex 00089 IntVect m_iv; 00090 00091 //which VoF in the cell (0 to nVoF-1) 00092 int m_cellIndex; 00093 00094 bool m_isDefined; 00095 }; 00096 00097 std::ostream& operator<< (std::ostream& os, 00098 const VolIndex& iv); 00099 00100 00101 #endif