00001 #ifdef CH_LANG_CC
00002
00003
00004
00005
00006
00007
00008
00009 #endif
00010
00011
00012
00013 #ifndef _EBFACEFAB_H_
00014 #define _EBFACEFAB_H_
00015
00016 #include <cmath>
00017 #include <cstdlib>
00018 #include "SPACE.H"
00019 #include "BaseEBFaceFAB.H"
00020 #include "FArrayBox.H"
00021 #include "NamespaceHeader.H"
00022
00023
00024
00025
00026
00027
00028 class EBFaceFAB: public BaseEBFaceFAB<Real>
00029 {
00030 public:
00031
00032 EBFaceFAB();
00033
00034
00035
00036
00037
00038
00039 EBFaceFAB(const EBISBox& a_ebisBox,
00040 const Box& a_region,
00041 int a_iDir, int a_nVar);
00042
00043
00044 void define(const EBISBox& a_ebisBox,
00045 const Box& a_region,
00046 int a_iDir, int a_nComp);
00047
00048 virtual ~EBFaceFAB();
00049
00050
00051 const FArrayBox& getFArrayBox() const;
00052
00053
00054
00055
00056
00057
00058 FArrayBox& getFArrayBox();
00059
00060
00061
00062
00063
00064 EBFaceFAB& operator+=(const EBFaceFAB& a_ebfab);
00065
00066
00067
00068 EBFaceFAB(const Interval& a_interval, EBFaceFAB& a_original)
00069 :BaseEBFaceFAB<Real>(a_interval, a_original)
00070 {
00071 }
00072
00073
00074
00075
00076
00077 EBFaceFAB& plus(const EBFaceFAB& a_ebfab,
00078 int a_srccomp,
00079 int a_destcomp,
00080 int a_numcomp);
00081
00082
00083
00084
00085
00086
00087 EBFaceFAB& operator-=(const EBFaceFAB& a_ebfab);
00088
00089
00090
00091
00092
00093 EBFaceFAB& minus(const EBFaceFAB& a_ebfab,
00094 int a_srccomp,
00095 int a_destcomp,
00096 int a_numcomp);
00097
00098
00099
00100
00101
00102
00103 EBFaceFAB& operator*=(const EBFaceFAB& a_ebfab);
00104
00105
00106
00107
00108
00109 EBFaceFAB& mult(const EBFaceFAB& a_ebfab,
00110 int a_srccomp,
00111 int a_destcomp,
00112 int a_numcomp);
00113
00114
00115
00116
00117
00118
00119 EBFaceFAB& operator/=(const EBFaceFAB& a_ebfab);
00120
00121
00122
00123
00124
00125
00126 EBFaceFAB& divide(const EBFaceFAB& a_ebfab,
00127 int a_srccomp,
00128 int a_destcomp,
00129 int a_numcomp);
00130
00131
00132
00133
00134
00135 EBFaceFAB& operator+=(const Real& a_scalar);
00136
00137
00138
00139
00140 EBFaceFAB& operator-=(const Real& a_scalar);
00141
00142
00143
00144
00145 EBFaceFAB& operator*=(const Real& a_scalar);
00146
00147
00148
00149
00150 EBFaceFAB& operator/=(const Real& a_scalar);
00151
00152
00153 Real max(int a_comp = 0) const;
00154
00155
00156 Real min(int a_comp = 0) const;
00157
00158
00159 EBFaceFAB(const Box& a_region, int a_nComp)
00160 {
00161 MayDay::Error("bogus constructor");
00162 }
00163 private:
00164
00165 EBFaceFAB(const EBFaceFAB& ebcin)
00166 {
00167 MayDay::Error("bogus constructor");
00168 }
00169 void operator=(const EBFaceFAB& ebcin)
00170 {
00171 MayDay::Error("bogus constructor");
00172 }
00173
00174 };
00175
00176 #include "NamespaceFooter.H"
00177 #endif