$extrastylesheet
weighted_patch_recovery_error_estimator.h
Go to the documentation of this file.
00001 // The libMesh Finite Element Library.
00002 // Copyright (C) 2002-2014 Benjamin S. Kirk, John W. Peterson, Roy H. Stogner
00003 
00004 // This library is free software; you can redistribute it and/or
00005 // modify it under the terms of the GNU Lesser General Public
00006 // License as published by the Free Software Foundation; either
00007 // version 2.1 of the License, or (at your option) any later version.
00008 
00009 // This library is distributed in the hope that it will be useful,
00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00012 // Lesser General Public License for more details.
00013 
00014 // You should have received a copy of the GNU Lesser General Public
00015 // License along with this library; if not, write to the Free Software
00016 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
00017 
00018 
00019 
00020 #ifndef LIBMESH_WEIGHTED_PATCH_RECOVERY_ERROR_ESTIMATOR_H
00021 #define LIBMESH_WEIGHTED_PATCH_RECOVERY_ERROR_ESTIMATOR_H
00022 
00023 // C++ includes
00024 #include <vector>
00025 
00026 // Local Includes
00027 #include "libmesh/elem_range.h"
00028 #include "libmesh/enum_order.h"
00029 #include "libmesh/error_estimator.h"
00030 #include "libmesh/fem_function_base.h"
00031 #include "libmesh/patch_recovery_error_estimator.h"
00032 #include "libmesh/patch.h"
00033 #include "libmesh/point.h"
00034 
00035 
00036 namespace libMesh
00037 {
00038 
00039 // Forward Declarations
00040 class Elem;
00041 
00042 
00049 class WeightedPatchRecoveryErrorEstimator : public PatchRecoveryErrorEstimator
00050 {
00051 public:
00052 
00058   WeightedPatchRecoveryErrorEstimator() :
00059     PatchRecoveryErrorEstimator()
00060   {}
00061 
00065   ~WeightedPatchRecoveryErrorEstimator() {}
00066 
00073   virtual void estimate_error (const System& system,
00074                                ErrorVector& error_per_cell,
00075                                const NumericVector<Number>* solution_vector = NULL,
00076                                bool estimate_parent_error = false);
00077 
00082   std::vector<FEMFunctionBase<Number>*> weight_functions;
00083 
00084 private:
00085 
00090   class EstimateError
00091   {
00092   public:
00093     EstimateError (const System& sys,
00094                    const WeightedPatchRecoveryErrorEstimator &ee,
00095                    ErrorVector& epc) :
00096       system(sys),
00097       error_estimator(ee),
00098       error_per_cell(epc)
00099     {}
00100 
00101     void operator()(const ConstElemRange &range) const;
00102 
00108   private:
00109 
00110     const System &system;
00111     const WeightedPatchRecoveryErrorEstimator &error_estimator;
00112     ErrorVector &error_per_cell;
00113   };
00114 
00115   friend class EstimateError;
00116 };
00117 
00118 
00119 } // namespace libMesh
00120 
00121 
00122 #endif // LIBMESH_WEIGHTED_PATCH_RECOVERY_ERROR_ESTIMATOR_H