RSTT  3.1.0
Regional Seismic Travel Time
GeoTessModelPathUnc.h
Go to the documentation of this file.
1 //- ****************************************************************************
2 //-
3 //- Copyright 2009 National Technology & Engineering Solutions of Sandia, LLC
4 //- (NTESS). Under the terms of Contract DE-NA0003525 with NTESS, the U.S.
5 //- Government retains certain rights in this software.
6 //-
7 //- BSD Open Source License
8 //- All rights reserved.
9 //-
10 //- Redistribution and use in source and binary forms, with or without
11 //- modification, are permitted provided that the following conditions are met:
12 //-
13 //- 1. Redistributions of source code must retain the above copyright notice,
14 //- this list of conditions and the following disclaimer.
15 //-
16 //- 2. Redistributions in binary form must reproduce the above copyright
17 //- notice, this list of conditions and the following disclaimer in the
18 //- documentation and/or other materials provided with the distribution.
19 //-
20 //- 3. Neither the name of the copyright holder nor the names of its
21 //- contributors may be used to endorse or promote products derived from
22 //- this software without specific prior written permission.
23 //-
24 //- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
25 //- AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26 //- IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 //- ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
28 //- LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
29 //- CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
30 //- SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
31 //- INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
32 //- CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
33 //- ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34 //- POSSIBILITY OF SUCH DAMAGE.
35 //-
36 //- ****************************************************************************
37 
38 #pragma once
39 
40 #ifndef GEOTESSMODELPATHUNC_H_
41 #define GEOTESSMODELPATHUNC_H_
42 
43 // **** _SYSTEM INCLUDES_ ******************************************************
44 
45 #include <iostream>
46 #include <string>
47 #include <fstream>
48 #include <vector>
49 #include <map>
50 
51 // use standard library objects
52 
53 // **** _LOCAL INCLUDES_ *******************************************************
54 
55 #include "SLBMGlobals.h"
56 #include "CPPGlobals.h"
57 #include "CPPUtils.h"
58 #include "GeoTessUtils.h"
59 #include "GeoTessException.h"
60 #include "GeoTessModel.h"
61 #include "GeoTessModelSLBM.h"
62 #include "GeoTessOptimizationType.h"
63 #include "Uncertainty.h"
64 #include "UncertaintyPathDep.h"
65 
66 using namespace geotess;
67 using namespace std;
68 
69 // **** _BEGIN GEOTESS NAMESPACE_ **********************************************
70 
71 namespace slbm
72 {
73 
74  // **** _FORWARD REFERENCES_ ***************************************************
75 
76 
77  // **** _CLASS DEFINITION_ *****************************************************
78 
87  {
88  private:
89 
93  vector<UncertaintyPathDep*>& pathDepUncertainty;
94 
95  protected:
96 
113  void loadModelAscii(IFStreamAscii& input, const string& inputDirectory,
114  const string& relGridFilePath);
115 
131  void loadModelBinary(IFStreamBinary& input, const string& inputDirectory,
132  const string& relGridFilePath);
133 
143  void writeModelAscii(IFStreamAscii& output, const string& gridFileName);
144 
154  void writeModelBinary(IFStreamBinary& output, const string& gridFileName);
155 
156  public:
157 
163  {
164  return true;
165  }
166 
173  GeoTessModelPathUnc(vector<UncertaintyPathDep*>& pathDepUncert, vector<vector<Uncertainty*> >& uncert);
174 
201  GeoTessModelPathUnc(const string& modelInputFile, const string& relativeGridPath,
202  vector<UncertaintyPathDep*>& pathDepUncertainties,
203  vector<vector<Uncertainty*> >& uncertainties);
204 
219  GeoTessModelPathUnc(const string& modelInputFile,
220  vector<UncertaintyPathDep*>& pathDepUncertainties,
221  vector<vector<Uncertainty*> >& uncertainties);
222 
257  GeoTessModelPathUnc(const string& gridFileName, GeoTessMetaData* metaData,
258  vector<UncertaintyPathDep*>& pathDepUncertainties,
259  vector<vector<Uncertainty*> >& uncertainties, double* avgMantleVel);
260 
300  GeoTessModelPathUnc(GeoTessGrid* grid, GeoTessMetaData* metaData,
301  vector<UncertaintyPathDep*>& pathDepUncertainties,
302  vector<vector<Uncertainty*> >& uncertainties, double* avgMantleVel);
303 
308 
313  static string class_name() { return "GeoTessModelPathUnc"; }
314 
318  static bool isGeoTessModelPathUnc(const string& fileName);
319 
320  };
321  // end class GeoTessModelPathUnc
322 
323 }// end namespace geotess
324 
325 #endif // GEOTESSMODELPATHUNC_H_
slbm::GeoTessModelPathUnc::GeoTessModelPathUnc
GeoTessModelPathUnc(const string &gridFileName, GeoTessMetaData *metaData, vector< UncertaintyPathDep * > &pathDepUncertainties, vector< vector< Uncertainty * > > &uncertainties, double *avgMantleVel)
slbm::GeoTessModelPathUnc::loadModelBinary
void loadModelBinary(IFStreamBinary &input, const string &inputDirectory, const string &relGridFilePath)
slbm::GeoTessModelPathUnc::GeoTessModelPathUnc
GeoTessModelPathUnc(const string &modelInputFile, const string &relativeGridPath, vector< UncertaintyPathDep * > &pathDepUncertainties, vector< vector< Uncertainty * > > &uncertainties)
slbm::GeoTessModelPathUnc
Definition: GeoTessModelPathUnc.h:87
UncertaintyPathDep.h
slbm::GeoTessModelPathUnc::isGeoTessModelPathUnc
static bool isGeoTessModelPathUnc(const string &fileName)
slbm::GeoTessModelPathUnc::GeoTessModelPathUnc
GeoTessModelPathUnc(GeoTessGrid *grid, GeoTessMetaData *metaData, vector< UncertaintyPathDep * > &pathDepUncertainties, vector< vector< Uncertainty * > > &uncertainties, double *avgMantleVel)
Uncertainty.h
SLBM_EXP
#define SLBM_EXP
Definition: SLBMGlobals.h:181
SLBMGlobals.h
slbm::GeoTessModelPathUnc::loadModelAscii
void loadModelAscii(IFStreamAscii &input, const string &inputDirectory, const string &relGridFilePath)
slbm::GeoTessModelPathUnc::~GeoTessModelPathUnc
virtual ~GeoTessModelPathUnc()
slbm::GeoTessModelPathUnc::writeModelAscii
void writeModelAscii(IFStreamAscii &output, const string &gridFileName)
slbm::GeoTessModelPathUnc::GeoTessModelPathUnc
GeoTessModelPathUnc(vector< UncertaintyPathDep * > &pathDepUncert, vector< vector< Uncertainty * > > &uncert)
slbm::GeoTessModelPathUnc::GeoTessModelPathUnc
GeoTessModelPathUnc(const string &modelInputFile, vector< UncertaintyPathDep * > &pathDepUncertainties, vector< vector< Uncertainty * > > &uncertainties)
slbm::GeoTessModelPathUnc::isPathDepUncModel
bool isPathDepUncModel()
Definition: GeoTessModelPathUnc.h:162
slbm::GeoTessModelPathUnc::class_name
static string class_name()
Definition: GeoTessModelPathUnc.h:313
GeoTessModelSLBM.h
slbm
Definition: CrustalProfile.h:59
slbm::GeoTessModelSLBM
Definition: GeoTessModelSLBM.h:83
slbm::GeoTessModelPathUnc::writeModelBinary
void writeModelBinary(IFStreamBinary &output, const string &gridFileName)