1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<title>GeographicTranslator: C:/master/geotrans3.7/CCS/src/dtcc/egm2008_full_grid_package.h Source File</title>
<b><p style="text-align:center;color:green;font-size:20px">UNCLASSIFIED</p></b>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/search.js"></script>
<script type="text/javascript">
$(document).ready(function() { searchBox.OnSelectItem(0); });
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td style="padding-left: 0.5em;">
<div id="projectname">GeographicTranslator
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.2 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
<div id="navrow1" class="tabs">
<ul class="tablist">
<li><a href="index.html"><span>Main Page</span></a></li>
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
<li><a href="annotated.html"><span>Classes</span></a></li>
<li class="current"><a href="files.html"><span>Files</span></a></li>
<li>
<div id="MSearchBox" class="MSearchBoxInactive">
<span class="left">
<img id="MSearchSelect" src="search/mag_sel.png"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
alt=""/>
<input type="text" id="MSearchField" value="Search" accesskey="S"
onfocus="searchBox.OnSearchFieldFocus(true)"
onblur="searchBox.OnSearchFieldFocus(false)"
onkeyup="searchBox.OnSearchFieldChange(event)"/>
</span><span class="right">
<a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
</span>
</div>
</li>
</ul>
</div>
<div id="navrow2" class="tabs2">
<ul class="tablist">
<li><a href="files.html"><span>File List</span></a></li>
<li><a href="globals.html"><span>File Members</span></a></li>
</ul>
</div>
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
onkeydown="return searchBox.OnSearchSelectKey(event)">
<a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark"> </span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark"> </span>Classes</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark"> </span>Namespaces</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark"> </span>Files</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark"> </span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark"> </span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark"> </span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark"> </span>Enumerator</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(8)"><span class="SelectionMark"> </span>Friends</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(9)"><span class="SelectionMark"> </span>Macros</a></div>
<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="javascript:void(0)" frameborder="0"
name="MSearchResults" id="MSearchResults">
</iframe>
</div>
<div id="nav-path" class="navpath">
<ul>
<li class="navelem"><a class="el" href="dir_edf3df7db5b0053f7cba67b155deccfc.html">master</a></li><li class="navelem"><a class="el" href="dir_8b3490cac915c107683d68df3d9c98a6.html">geotrans3.7</a></li><li class="navelem"><a class="el" href="dir_d0951f0e396e7f3ab5db438f6b9f5363.html">CCS</a></li><li class="navelem"><a class="el" href="dir_3b11bca187df89c3daa83d17707827d4.html">src</a></li><li class="navelem"><a class="el" href="dir_ce1728a50ed0f8e5fbefa80fc2874faa.html">dtcc</a></li> </ul>
</div>
</div><!-- top -->
<div class="header">
<div class="headertitle">
<div class="title">egm2008_full_grid_package.h</div> </div>
</div><!--header-->
<div class="contents">
<a href="egm2008__full__grid__package_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"> 1</span> </div>
<div class="line"><a name="l00002"></a><span class="lineno"> 2</span> <span class="comment">// CLASSIFICATION: UNCLASSIFIED</span></div>
<div class="line"><a name="l00003"></a><span class="lineno"> 3</span> </div>
<div class="line"><a name="l00005"></a><span class="lineno"> 5</span> <span class="comment">// //</span></div>
<div class="line"><a name="l00006"></a><span class="lineno"> 6</span> <span class="comment">// File name: egm2008_full_grid_package.h //</span></div>
<div class="line"><a name="l00007"></a><span class="lineno"> 7</span> <span class="comment">// //</span></div>
<div class="line"><a name="l00008"></a><span class="lineno"> 8</span> <span class="comment">// Description of this module: //</span></div>
<div class="line"><a name="l00009"></a><span class="lineno"> 9</span> <span class="comment">// Utility software that interpolates EGM 2008 //</span></div>
<div class="line"><a name="l00010"></a><span class="lineno"> 10</span> <span class="comment">// geoid heights from one of NGA's geoid height grids. //</span></div>
<div class="line"><a name="l00011"></a><span class="lineno"> 11</span> <span class="comment">// //</span></div>
<div class="line"><a name="l00012"></a><span class="lineno"> 12</span> <span class="comment">// This interpolator loads the worldwide EGM 2008 grid upon //</span></div>
<div class="line"><a name="l00013"></a><span class="lineno"> 13</span> <span class="comment">// instantiation, and it interpolates from the worldwide grid. //</span></div>
<div class="line"><a name="l00014"></a><span class="lineno"> 14</span> <span class="comment">// //</span></div>
<div class="line"><a name="l00015"></a><span class="lineno"> 15</span> <span class="comment">// This interpolator gives exactly the same results as //</span></div>
<div class="line"><a name="l00016"></a><span class="lineno"> 16</span> <span class="comment">// the companion egm2008_aoi_grid_package's interpolator. //</span></div>
<div class="line"><a name="l00017"></a><span class="lineno"> 17</span> <span class="comment">// However, this interpolator is faster when //</span></div>
<div class="line"><a name="l00018"></a><span class="lineno"> 18</span> <span class="comment">// users are requesting tens of thousands of geoid //</span></div>
<div class="line"><a name="l00019"></a><span class="lineno"> 19</span> <span class="comment">// heights at widely dispersed horizontal locations. //</span></div>
<div class="line"><a name="l00020"></a><span class="lineno"> 20</span> <span class="comment">// //</span></div>
<div class="line"><a name="l00021"></a><span class="lineno"> 21</span> <span class="comment">// Revision History: //</span></div>
<div class="line"><a name="l00022"></a><span class="lineno"> 22</span> <span class="comment">// Date Name Description //</span></div>
<div class="line"><a name="l00023"></a><span class="lineno"> 23</span> <span class="comment">// ----------- ------------ ----------------------------------------------//</span></div>
<div class="line"><a name="l00024"></a><span class="lineno"> 24</span> <span class="comment">// 19 Nov 2010 RD Craig Release //</span></div>
<div class="line"><a name="l00025"></a><span class="lineno"> 25</span> <span class="comment">// 11 Feg 2011 RD Craig Upgrades following code review //</span></div>
<div class="line"><a name="l00026"></a><span class="lineno"> 26</span> <span class="comment">// 30 May 2013 RD Craig MSP 1.3: ER29758 //</span></div>
<div class="line"><a name="l00027"></a><span class="lineno"> 27</span> <span class="comment">// Added second constructor to //</span></div>
<div class="line"><a name="l00028"></a><span class="lineno"> 28</span> <span class="comment">// permit multiple geoid-height grids //</span></div>
<div class="line"><a name="l00029"></a><span class="lineno"> 29</span> <span class="comment">// when assessing relative interpolation errors. //</span></div>
<div class="line"><a name="l00030"></a><span class="lineno"> 30</span> <span class="comment">// //</span></div>
<div class="line"><a name="l00032"></a><span class="lineno"> 32</span> <span class="comment"></span></div>
<div class="line"><a name="l00033"></a><span class="lineno"> 33</span> <span class="preprocessor">#ifndef EGM2008_FULL_GRID_PACKAGE_H</span></div>
<div class="line"><a name="l00034"></a><span class="lineno"> 34</span> <span class="preprocessor"></span><span class="preprocessor">#define EGM2008_FULL_GRID_PACKAGE_H</span></div>
<div class="line"><a name="l00035"></a><span class="lineno"> 35</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00036"></a><span class="lineno"> 36</span> <span class="comment">// This file declares a C++ class</span></div>
<div class="line"><a name="l00037"></a><span class="lineno"> 37</span> <span class="comment">// that interpolates EGM 2008 geoid heights from a</span></div>
<div class="line"><a name="l00038"></a><span class="lineno"> 38</span> <span class="comment">// reformatted version of NGA's geoid-height grid.</span></div>
<div class="line"><a name="l00039"></a><span class="lineno"> 39</span> </div>
<div class="line"><a name="l00040"></a><span class="lineno"> 40</span> <span class="comment">// THIS DERIVED CLASS IMPLEMENTS COMPUTATIONAL</span></div>
<div class="line"><a name="l00041"></a><span class="lineno"> 41</span> <span class="comment">// DETAILS SPECIFIC TO THE EGM 2008 FULL-GRID ALGORITHM.</span></div>
<div class="line"><a name="l00042"></a><span class="lineno"> 42</span> </div>
<div class="line"><a name="l00043"></a><span class="lineno"> 43</span> <span class="preprocessor">#include "<a class="code" href="_dtcc_api_8h.html">DtccApi.h</a>"</span></div>
<div class="line"><a name="l00044"></a><span class="lineno"> 44</span> <span class="preprocessor">#include "<a class="code" href="egm2008__geoid__grid_8h.html">egm2008_geoid_grid.h</a>"</span></div>
<div class="line"><a name="l00045"></a><span class="lineno"> 45</span> </div>
<div class="line"><a name="l00046"></a><span class="lineno"> 46</span> <span class="keyword">namespace </span>MSP</div>
<div class="line"><a name="l00047"></a><span class="lineno"> 47</span> {</div>
<div class="line"><a name="l00048"></a><span class="lineno"><a class="code" href="class_m_s_p_1_1_egm2008_full_grid.html"> 48</a></span>  <span class="keyword">class </span><a class="code" href="_dtcc_api_8h.html#a5995458476ac88a055b3f40b0238f2ae">MSP_DTCC_API</a> <a class="code" href="class_m_s_p_1_1_egm2008_full_grid.html">Egm2008FullGrid</a> : <span class="keyword">public</span> <a class="code" href="class_m_s_p_1_1_egm2008_geoid_grid.html">Egm2008GeoidGrid</a> {</div>
<div class="line"><a name="l00049"></a><span class="lineno"> 49</span>  </div>
<div class="line"><a name="l00050"></a><span class="lineno"> 50</span>  <span class="keyword">protected</span>:</div>
<div class="line"><a name="l00051"></a><span class="lineno"> 51</span> </div>
<div class="line"><a name="l00052"></a><span class="lineno"> 52</span>  <span class="comment">// heightGrid: A pointer to a</span></div>
<div class="line"><a name="l00053"></a><span class="lineno"> 53</span>  <span class="comment">// one-dimensional array containing</span></div>
<div class="line"><a name="l00054"></a><span class="lineno"> 54</span>  <span class="comment">// the reformatted geoid-height grid.</span></div>
<div class="line"><a name="l00055"></a><span class="lineno"> 55</span> </div>
<div class="line"><a name="l00056"></a><span class="lineno"><a class="code" href="class_m_s_p_1_1_egm2008_full_grid.html#a5ceda027c9b9d5c7176802a413422d1b"> 56</a></span>  <span class="keywordtype">float</span>* <a class="code" href="class_m_s_p_1_1_egm2008_full_grid.html#a5ceda027c9b9d5c7176802a413422d1b">_heightGrid</a>;</div>
<div class="line"><a name="l00057"></a><span class="lineno"> 57</span> </div>
<div class="line"><a name="l00058"></a><span class="lineno"> 58</span>  <span class="keyword">public</span>:</div>
<div class="line"><a name="l00059"></a><span class="lineno"> 59</span> </div>
<div class="line"><a name="l00060"></a><span class="lineno"> 60</span>  <span class="comment">// Basic functions .....</span></div>
<div class="line"><a name="l00061"></a><span class="lineno"> 61</span> </div>
<div class="line"><a name="l00062"></a><span class="lineno"> 62</span>  <a class="code" href="class_m_s_p_1_1_egm2008_full_grid.html">Egm2008FullGrid</a>( <span class="keywordtype">void</span> );</div>
<div class="line"><a name="l00063"></a><span class="lineno"> 63</span> </div>
<div class="line"><a name="l00064"></a><span class="lineno"> 64</span>  <a class="code" href="class_m_s_p_1_1_egm2008_full_grid.html">Egm2008FullGrid</a>( <span class="keyword">const</span> std::string &gridFname ); <span class="comment">// new 5/30/2013</span></div>
<div class="line"><a name="l00065"></a><span class="lineno"> 65</span>  </div>
<div class="line"><a name="l00066"></a><span class="lineno"> 66</span>  <a class="code" href="class_m_s_p_1_1_egm2008_full_grid.html">Egm2008FullGrid</a>( <span class="keyword">const</span> <a class="code" href="class_m_s_p_1_1_egm2008_full_grid.html">Egm2008FullGrid</a>& oldGrid );</div>
<div class="line"><a name="l00067"></a><span class="lineno"> 67</span> </div>
<div class="line"><a name="l00068"></a><span class="lineno"> 68</span>  ~<a class="code" href="class_m_s_p_1_1_egm2008_full_grid.html">Egm2008FullGrid</a>( <span class="keywordtype">void</span> );</div>
<div class="line"><a name="l00069"></a><span class="lineno"> 69</span> </div>
<div class="line"><a name="l00070"></a><span class="lineno"> 70</span>  <a class="code" href="class_m_s_p_1_1_egm2008_full_grid.html">Egm2008FullGrid</a>&</div>
<div class="line"><a name="l00071"></a><span class="lineno"> 71</span>  operator = ( <span class="keyword">const</span> <a class="code" href="class_m_s_p_1_1_egm2008_full_grid.html">Egm2008FullGrid</a>& oldGrid );</div>
<div class="line"><a name="l00072"></a><span class="lineno"> 72</span> </div>
<div class="line"><a name="l00073"></a><span class="lineno"> 73</span>  <span class="comment">// User functions .....</span></div>
<div class="line"><a name="l00074"></a><span class="lineno"> 74</span>  </div>
<div class="line"><a name="l00075"></a><span class="lineno"> 75</span>  <span class="comment">// geoidHeight: A function that interpolates</span></div>
<div class="line"><a name="l00076"></a><span class="lineno"> 76</span>  <span class="comment">// local geoid height (meters) from</span></div>
<div class="line"><a name="l00077"></a><span class="lineno"> 77</span>  <span class="comment">// a reformatted geoid height grid;</span></div>
<div class="line"><a name="l00078"></a><span class="lineno"> 78</span>  <span class="comment">// it uses bi-cubic spline interpolation.</span></div>
<div class="line"><a name="l00079"></a><span class="lineno"> 79</span> </div>
<div class="line"><a name="l00080"></a><span class="lineno"> 80</span>  <span class="keyword">virtual</span> <span class="keywordtype">int</span></div>
<div class="line"><a name="l00081"></a><span class="lineno"> 81</span>  geoidHeight(</div>
<div class="line"><a name="l00082"></a><span class="lineno"> 82</span>  <span class="keywordtype">int</span> wSize, <span class="comment">// input</span></div>
<div class="line"><a name="l00083"></a><span class="lineno"> 83</span>  <span class="keywordtype">double</span> latitude, <span class="comment">// input</span></div>
<div class="line"><a name="l00084"></a><span class="lineno"> 84</span>  <span class="keywordtype">double</span> longitude, <span class="comment">// input</span></div>
<div class="line"><a name="l00085"></a><span class="lineno"> 85</span>  <span class="keywordtype">double</span>& gHeight ); <span class="comment">// output</span></div>
<div class="line"><a name="l00086"></a><span class="lineno"> 86</span> </div>
<div class="line"><a name="l00087"></a><span class="lineno"> 87</span>  <span class="keyword">protected</span>:</div>
<div class="line"><a name="l00088"></a><span class="lineno"> 88</span>  </div>
<div class="line"><a name="l00089"></a><span class="lineno"> 89</span>  <span class="comment">// geoidHeight: A function that interpolates</span></div>
<div class="line"><a name="l00090"></a><span class="lineno"> 90</span>  <span class="comment">// local geoid height (meters) from</span></div>
<div class="line"><a name="l00091"></a><span class="lineno"> 91</span>  <span class="comment">// a reformatted geoid height grid;</span></div>
<div class="line"><a name="l00092"></a><span class="lineno"> 92</span>  <span class="comment">// it uses bilinear interpolation.</span></div>
<div class="line"><a name="l00093"></a><span class="lineno"> 93</span> </div>
<div class="line"><a name="l00094"></a><span class="lineno"> 94</span>  <span class="keyword">virtual</span> <span class="keywordtype">int</span></div>
<div class="line"><a name="l00095"></a><span class="lineno"> 95</span>  geoidHeight(</div>
<div class="line"><a name="l00096"></a><span class="lineno"> 96</span>  <span class="keywordtype">double</span> latitude, <span class="comment">// input</span></div>
<div class="line"><a name="l00097"></a><span class="lineno"> 97</span>  <span class="keywordtype">double</span> longitude, <span class="comment">// input</span></div>
<div class="line"><a name="l00098"></a><span class="lineno"> 98</span>  <span class="keywordtype">double</span>& gHeight ); <span class="comment">// output</span></div>
<div class="line"><a name="l00099"></a><span class="lineno"> 99</span> </div>
<div class="line"><a name="l00100"></a><span class="lineno"> 100</span>  <span class="comment">// loadGrid: A function that </span></div>
<div class="line"><a name="l00101"></a><span class="lineno"> 101</span>  <span class="comment">// retrieves a reformatted</span></div>
<div class="line"><a name="l00102"></a><span class="lineno"> 102</span>  <span class="comment">// EGM 2008 worldwide geoid height grid.</span></div>
<div class="line"><a name="l00103"></a><span class="lineno"> 103</span> </div>
<div class="line"><a name="l00104"></a><span class="lineno"> 104</span>  <span class="keywordtype">int</span></div>
<div class="line"><a name="l00105"></a><span class="lineno"> 105</span>  loadGrid( <span class="keywordtype">void</span> );</div>
<div class="line"><a name="l00106"></a><span class="lineno"> 106</span> </div>
<div class="line"><a name="l00107"></a><span class="lineno"> 107</span>  }; <span class="comment">// End of Egm2008FullGrid class declaration</span></div>
<div class="line"><a name="l00108"></a><span class="lineno"> 108</span> </div>
<div class="line"><a name="l00109"></a><span class="lineno"> 109</span> } <span class="comment">// End of namespace block</span></div>
<div class="line"><a name="l00110"></a><span class="lineno"> 110</span> </div>
<div class="line"><a name="l00111"></a><span class="lineno"> 111</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00112"></a><span class="lineno"> 112</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00113"></a><span class="lineno"> 113</span> <span class="comment">// CLASSIFICATION: UNCLASSIFIED</span></div>
<div class="line"><a name="l00114"></a><span class="lineno"> 114</span> </div>
</div><!-- fragment --></div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated on Tue Feb 16 2016 14:54:02 for GeographicTranslator by doxygen 1.8.2
</small></address>
</body>
</html>
|