00001 /*************************************************************************** 00002 ** 00003 ** This file is part of gpparam2model. 00004 ** 00005 ** This file may be distributed and/or modified under the terms of the 00006 ** GNU General Public License version 2 or 3 as published by the Free 00007 ** Software Foundation and appearing in the file LICENSE.GPL included 00008 ** in the packaging of this file. 00009 ** 00010 ** This file is distributed in the hope that it will be useful, but WITHOUT 00011 ** ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 00012 ** FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 00013 ** more details. 00014 ** 00015 ** You should have received a copy of the GNU General Public License 00016 ** along with this program. If not, see <http://www.gnu.org/licenses/>. 00017 ** 00018 ** See http://www.geopsy.org for more information. 00019 ** 00020 ** Created : 2008-06-03 00021 ** Authors: 00022 ** Marc Wathelet 00023 ** Marc Wathelet (LGIT, Grenoble, France) 00024 ** 00025 ***************************************************************************/ 00026 00027 #ifndef MODELGENERATOR_H 00028 #define MODELGENERATOR_H 00029 00030 #include <DinverCore.h> 00031 #include <DinverDCCore.h> 00032 00033 class ModelGenerator : public AbstractForward 00034 { 00035 TRANSLATIONS("ModelGenerator") 00036 public: 00037 ModelGenerator(); 00038 ~ModelGenerator(); 00039 00040 bool setParamSpace(ParamGroundModel * gm); 00041 00042 AbstractForward * clone() const; 00043 virtual double misfit(bool& ok); 00044 inline virtual void valueChanged(const Parameter * from=0); 00045 inline bool isFussyOk(const Parameter * from); 00046 private: 00047 ParamGroundModel * _paramModel; 00048 ParamProfile * _vp, * _vs, * _rho; 00049 PoissonCondition * _poissonCondition; 00050 }; 00051 00052 inline void ModelGenerator::valueChanged(const Parameter * from) 00053 { 00054 _paramModel->updateFinalProfiles(static_cast<const GroundParameter *>(from)); 00055 } 00056 00057 inline bool ModelGenerator::isFussyOk(const Parameter * from) 00058 { 00059 if(_poissonCondition) 00060 return _poissonCondition->isOk(static_cast<const GroundParameter *>(from)); 00061 else 00062 return true; 00063 } 00064 00065 #endif // MODELGENERATOR_H