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 // DFMartin, Sun, May 5, 2002 00028 00029 #ifndef _GSRBSMOOTHER_H_ 00030 #define _GSRBSMOOTHER_H_ 00031 00032 #include <iostream> 00033 #include <cmath> 00034 #include <cassert> 00035 #include <cstdlib> 00036 00037 #include "REAL.H" 00038 #include "IntVect.H" 00039 #include "Box.H" 00040 #include "DisjointBoxLayout.H" 00041 #include "LevelData.H" 00042 #include "FArrayBox.H" 00043 #include "ProblemDomain.H" 00044 00045 #include "BaseBottomSmoother.H" 00046 00048 00051 class GSRBSmoother: public BaseBottomSmoother 00052 { 00053 public: 00055 GSRBSmoother(); 00056 00058 virtual ~GSRBSmoother(); 00059 00061 00064 virtual BaseBottomSmoother* new_bottomSmoother() const; 00065 00067 00070 virtual void doBottomSmooth(LevelData<FArrayBox>& a_phi, 00071 const LevelData<FArrayBox>& a_rhs, 00072 LevelOp* a_levelopPtr); 00073 00075 virtual void setNumSmooth(int a_numSmooth); 00076 00078 virtual int numSmooth() const; 00079 00080 // this doesn't really do anything, but is required by BaseBottomSmoother 00081 virtual void setConvergenceMetric(Real a_metric, int a_comp=0) {}; 00082 00084 virtual void setSolverTol(Real a_tol) {}; 00085 00086 protected: 00088 int m_numSmooth; 00089 }; 00090 00091 #endif