00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029 #ifndef _GENAMRLEVELMGOP_H_
00030 #define _GENAMRLEVELMGOP_H_
00031
00032 #include <iostream>
00033 #include <math.h>
00034 #include <assert.h>
00035 #include <stdlib.h>
00036
00037 #include "REAL.H"
00038
00039 #include "GenLevelMGOp.H"
00040
00042
00046 template <class T> class GenAMRLevelMGOp: public GenLevelMGOp<T>
00047 {
00048 public:
00050
00052
00055 GenAMRLevelMGOp() {};
00056
00058
00061 virtual ~GenAMRLevelMGOp() {};
00062
00064
00067 virtual GenAMRLevelMGOp* newOp() const = 0;
00068
00070
00074 virtual void applyOpI(T& a_phi,
00075 const T* a_phiCoarse,
00076 T& a_LOfPhi) = 0;
00077
00079
00083 virtual void applyOpHcfIphys(T& a_phi,
00084 T& a_LOfPhi) = 0;
00085
00087
00091 virtual void applyOpIcfHphys(T& a_phi,
00092 const T* a_phiCoarse,
00093 T& a_LOfPhi) = 0;
00094
00096
00100 virtual void applyOpH(T& a_phi,
00101 T& a_LOfPhi) = 0;
00102
00103 };
00104
00105 #endif