PageRenderTime 70ms CodeModel.GetById 23ms RepoModel.GetById 0ms app.codeStats 2ms

/doc/html/vabsSudo_8cpp_source.html

https://bitbucket.org/slawton/windturbinemdo-stevebitb
HTML | 3945 lines | 3932 code | 12 blank | 1 comment | 0 complexity | c0b71c54c03e62d2c468912abbc05e88 MD5 | raw file
Possible License(s): GPL-2.0, BSD-3-Clause
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  5. <title>WindTurbineMDO: structural/VABS_Calc/source/ver_2/vabsSudo.cpp Source File</title>
  6. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  7. <link href="doxygen.css" rel="stylesheet" type="text/css" />
  8. <link href="navtree.css" rel="stylesheet" type="text/css"/>
  9. <script type="text/javascript" src="jquery.js"></script>
  10. <script type="text/javascript" src="resize.js"></script>
  11. <script type="text/javascript" src="navtree.js"></script>
  12. <script type="text/javascript">
  13. $(document).ready(initResizable);
  14. </script>
  15. <link href="search/search.css" rel="stylesheet" type="text/css"/>
  16. <script type="text/javascript" src="search/search.js"></script>
  17. <script type="text/javascript">
  18. $(document).ready(function() { searchBox.OnSelectItem(0); });
  19. </script>
  20. </head>
  21. <body>
  22. <div id="top"><!-- do not remove this div! -->
  23. <div id="titlearea">
  24. <table cellspacing="0" cellpadding="0">
  25. <tbody>
  26. <tr style="height: 56px;">
  27. <td style="padding-left: 0.5em;">
  28. <div id="projectname">WindTurbineMDO
  29. </div>
  30. </td>
  31. </tr>
  32. </tbody>
  33. </table>
  34. </div>
  35. <!-- Generated by Doxygen 1.7.5.1 -->
  36. <script type="text/javascript">
  37. var searchBox = new SearchBox("searchBox", "search",false,'Search');
  38. </script>
  39. <div id="navrow1" class="tabs">
  40. <ul class="tablist">
  41. <li><a href="index.html"><span>Main&#160;Page</span></a></li>
  42. <li><a href="namespaces.html"><span>Namespaces</span></a></li>
  43. <li><a href="annotated.html"><span>Classes</span></a></li>
  44. <li class="current"><a href="files.html"><span>Files</span></a></li>
  45. <li>
  46. <div id="MSearchBox" class="MSearchBoxInactive">
  47. <span class="left">
  48. <img id="MSearchSelect" src="search/mag_sel.png"
  49. onmouseover="return searchBox.OnSearchSelectShow()"
  50. onmouseout="return searchBox.OnSearchSelectHide()"
  51. alt=""/>
  52. <input type="text" id="MSearchField" value="Search" accesskey="S"
  53. onfocus="searchBox.OnSearchFieldFocus(true)"
  54. onblur="searchBox.OnSearchFieldFocus(false)"
  55. onkeyup="searchBox.OnSearchFieldChange(event)"/>
  56. </span><span class="right">
  57. <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
  58. </span>
  59. </div>
  60. </li>
  61. </ul>
  62. </div>
  63. <div id="navrow2" class="tabs2">
  64. <ul class="tablist">
  65. <li><a href="files.html"><span>File&#160;List</span></a></li>
  66. <li><a href="globals.html"><span>File&#160;Members</span></a></li>
  67. </ul>
  68. </div>
  69. </div>
  70. <div id="side-nav" class="ui-resizable side-nav-resizable">
  71. <div id="nav-tree">
  72. <div id="nav-tree-contents">
  73. </div>
  74. </div>
  75. <div id="splitbar" style="-moz-user-select:none;"
  76. class="ui-resizable-handle">
  77. </div>
  78. </div>
  79. <script type="text/javascript">
  80. initNavTree('vabsSudo_8cpp.html','');
  81. </script>
  82. <div id="doc-content">
  83. <div class="header">
  84. <div class="headertitle">
  85. <div class="title">structural/VABS_Calc/source/ver_2/vabsSudo.cpp</div> </div>
  86. </div>
  87. <div class="contents">
  88. <a href="vabsSudo_8cpp.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001
  89. <a name="l00002"></a>00002 <span class="comment">// #include &quot;matrix/matrixClass.h&quot;</span>
  90. <a name="l00003"></a>00003 <span class="comment">// #include &quot;/home/mike/work/UVic/NonlinearBeam/CAD_Calc/source/ver_1/meshSudo.cpp&quot;</span>
  91. <a name="l00004"></a>00004 <span class="comment">// #include &quot;/home/mike/work/UVic/NonlinearBeam/matrix_Solver/source/ver_1/matrixSolverSudo.cpp&quot;</span>
  92. <a name="l00005"></a>00005 <span class="comment">// #include &quot;/home/mike/work/UVic/NonlinearBeam/GEBT_Calc/source/ver_2/femSudoCode.cpp&quot;</span>
  93. <a name="l00006"></a>00006 <span class="comment">// #include &quot;material.cpp&quot;</span>
  94. <a name="l00007"></a>00007 <span class="preprocessor">#include &lt;algorithm&gt;</span>
  95. <a name="l00008"></a>00008 <span class="preprocessor">#include &lt;memory&gt;</span>
  96. <a name="l00009"></a>00009
  97. <a name="l00010"></a>00010 <span class="comment">// #define ADJOINT_VABS</span>
  98. <a name="l00011"></a>00011
  99. <a name="l00012"></a>00012 <span class="comment">// #define SVD_BASED_VABS_SOLUTION</span>
  100. <a name="l00013"></a>00013
  101. <a name="l00014"></a>00014 <span class="comment">// #define PRINT_VABS_PROGRESS</span>
  102. <a name="l00015"></a>00015
  103. <a name="l00016"></a>00016 <span class="comment">// #define TIME_ADJOINT_CALCULATION</span>
  104. <a name="l00017"></a>00017
  105. <a name="l00018"></a>00018 <span class="comment">// #include &lt;sys/time.h&gt;</span>
  106. <a name="l00019"></a>00019
  107. <a name="l00020"></a>00020 <span class="comment">// so lets talk about the VABS....</span>
  108. <a name="l00021"></a>00021
  109. <a name="l00022"></a>00022 <span class="comment">// ok the mesh program retrieves the minimal geometric information required to build a VABS model...</span>
  110. <a name="l00023"></a>00023
  111. <a name="l00024"></a>00024 <span class="comment">// A vabs element is only responsible for building a matrix</span>
  112. <a name="l00025"></a>00025
  113. <a name="l00026"></a>00026 <span class="comment">// Here is a structure</span>
  114. <a name="l00027"></a>00027 <span class="comment">// we have VABS elements that are like FEM elements with shape functions and matrix building abilities</span>
  115. <a name="l00028"></a>00028 <span class="comment">// we have VABS nodes that contain information from the mesh to build the matrices</span>
  116. <a name="l00029"></a>00029 <span class="comment">// we have a VABS assembly that takes a matrix solver and uses the assembly to get the matrices and solve the constituitive matrix</span>
  117. <a name="l00030"></a>00030
  118. <a name="l00031"></a>00031 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  119. <a name="l00032"></a><a class="code" href="classVABSNode.html">00032</a> <span class="keyword">class </span><a class="code" href="classVABSNode.html">VABSNode</a>
  120. <a name="l00033"></a>00033 {
  121. <a name="l00034"></a>00034 <span class="keyword">public</span>:
  122. <a name="l00035"></a>00035
  123. <a name="l00036"></a><a class="code" href="classVABSNode.html#afe63b8307d6bd3082ec5eddfd36ab28d">00036</a> <span class="keyword">virtual</span> <a class="code" href="classVABSNode.html#afe63b8307d6bd3082ec5eddfd36ab28d">~VABSNode</a>()
  124. <a name="l00037"></a>00037 {}
  125. <a name="l00038"></a>00038
  126. <a name="l00039"></a>00039 <span class="comment">// need to know position (2 scalars or 2-vect)</span>
  127. <a name="l00040"></a>00040 <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;dataType&gt;</a>&amp; <a class="code" href="classVABSNode.html#a04a4be0511f905869894e34c0b2901d8">x</a>() <span class="keyword">const</span> =0;
  128. <a name="l00041"></a>00041 <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;dataType&gt;</a>&amp; <a class="code" href="classVABSNode.html#ab8825545b32b55e848a2cdf394ebf8ed">y</a>() <span class="keyword">const</span> =0;
  129. <a name="l00042"></a>00042 <span class="comment">// need to know through thickness posisition (scalar)</span>
  130. <a name="l00043"></a>00043 <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;dataType&gt;</a>&amp; <a class="code" href="classVABSNode.html#a47bb48aeeb59af55084e7743bd2963b5">h</a>() <span class="keyword">const</span> =0;
  131. <a name="l00044"></a>00044 <span class="comment">// need to know ply angle (scalar)</span>
  132. <a name="l00045"></a>00045 <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;dataType&gt;</a>&amp; <a class="code" href="classVABSNode.html#acfd688e05d010009439d3459923ef7c0">plyAngle</a>() <span class="keyword">const</span> =0;
  133. <a name="l00046"></a>00046
  134. <a name="l00047"></a>00047 <span class="comment">// I am not sure if I need this as it could be stored in the material model as an h dependence</span>
  135. <a name="l00048"></a>00048 <span class="comment">// need to know fiber angle (scalar) (optional for now ...)</span>
  136. <a name="l00049"></a>00049
  137. <a name="l00050"></a>00050 <span class="comment">// this is where the results of the VABS calculate is stored</span>
  138. <a name="l00051"></a>00051 <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;matrixStatic&lt;dataType,3,4&gt;</a> &gt;&amp; <a class="code" href="classVABSNode.html#a7bd73fd4e4208bb66e157c3882d01a29">warping</a>() <span class="keyword">const</span> =0;
  139. <a name="l00052"></a>00052
  140. <a name="l00053"></a>00053 };
  141. <a name="l00054"></a>00054
  142. <a name="l00055"></a>00055 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  143. <a name="l00056"></a><a class="code" href="classVABSNode__common.html">00056</a> <span class="keyword">class </span><a class="code" href="classVABSNode__common.html">VABSNode_common</a>
  144. <a name="l00057"></a>00057 {
  145. <a name="l00058"></a>00058 <span class="keyword">private</span>:
  146. <a name="l00059"></a>00059
  147. <a name="l00060"></a>00060 <a class="code" href="classdataSource__Data.html">dataSource_Data&lt;dataType&gt;</a> xSrc;
  148. <a name="l00061"></a>00061 <a class="code" href="classdataSource__Data.html">dataSource_Data&lt;dataType&gt;</a> ySrc;
  149. <a name="l00062"></a>00062 <a class="code" href="classdataSource__Data.html">dataSource_Data&lt;matrixStatic&lt;dataType,3,4&gt;</a>,<a class="code" href="classmatrixRdWtStatic__pData.html">matrixRdWtStatic_pData&lt;dataType,3,4&gt;</a> &gt; warpSrc;
  150. <a name="l00063"></a>00063
  151. <a name="l00064"></a>00064 <span class="keyword">public</span>:
  152. <a name="l00065"></a>00065
  153. <a name="l00066"></a><a class="code" href="classVABSNode__common.html#aa09906e00648ab7fb541a85432a53aff">00066</a> <a class="code" href="classVABSNode__common.html#aa09906e00648ab7fb541a85432a53aff">VABSNode_common</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> x_in=0.0,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> y_in=0.0) : xSrc(x_in) , ySrc(y_in)
  154. <a name="l00067"></a>00067 {}
  155. <a name="l00068"></a>00068
  156. <a name="l00069"></a><a class="code" href="classVABSNode__common.html#ac7174c77d18117ebb8304c9f325262d8">00069</a> <a class="code" href="classVABSNode__common.html">VABSNode_common</a>&amp; <a class="code" href="classVABSNode__common.html#ac7174c77d18117ebb8304c9f325262d8">setX</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> x_in)
  157. <a name="l00070"></a>00070 {
  158. <a name="l00071"></a>00071 xSrc.<a class="code" href="classdataSource__Data.html#aefa4c87ef5fb27413a5f2ce1356638d7">getData</a>()=x_in;
  159. <a name="l00072"></a>00072 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  160. <a name="l00073"></a>00073 }
  161. <a name="l00074"></a>00074
  162. <a name="l00075"></a><a class="code" href="classVABSNode__common.html#ae9c8384acbcc1a44b7424cfee345df20">00075</a> <a class="code" href="classVABSNode__common.html">VABSNode_common</a>&amp; <a class="code" href="classVABSNode__common.html#ae9c8384acbcc1a44b7424cfee345df20">setY</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> y_in)
  163. <a name="l00076"></a>00076 {
  164. <a name="l00077"></a>00077 ySrc.<a class="code" href="classdataSource__Data.html#aefa4c87ef5fb27413a5f2ce1356638d7">getData</a>()=y_in;
  165. <a name="l00078"></a>00078 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  166. <a name="l00079"></a>00079 }
  167. <a name="l00080"></a>00080
  168. <a name="l00081"></a><a class="code" href="classVABSNode__common.html#a08b644d8490442f08872ef2679d119f3">00081</a> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;dataType&gt;</a>&amp; <a class="code" href="classVABSNode__common.html#a08b644d8490442f08872ef2679d119f3">x</a>()<span class="keyword"> const</span>
  169. <a name="l00082"></a>00082 <span class="keyword"> </span>{
  170. <a name="l00083"></a>00083 <span class="keywordflow">return</span> xSrc;
  171. <a name="l00084"></a>00084 }
  172. <a name="l00085"></a>00085
  173. <a name="l00086"></a><a class="code" href="classVABSNode__common.html#a091a6d771873b52c822d009c7bd8178e">00086</a> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;dataType&gt;</a>&amp; <a class="code" href="classVABSNode__common.html#a091a6d771873b52c822d009c7bd8178e">y</a>()<span class="keyword"> const</span>
  174. <a name="l00087"></a>00087 <span class="keyword"> </span>{
  175. <a name="l00088"></a>00088 <span class="keywordflow">return</span> ySrc;
  176. <a name="l00089"></a>00089 }
  177. <a name="l00090"></a>00090
  178. <a name="l00091"></a><a class="code" href="classVABSNode__common.html#ab53b3d818bb3881738bed7b8a47c9eb2">00091</a> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;matrixStatic&lt;dataType,3,4&gt;</a> &gt;&amp; <a class="code" href="classVABSNode__common.html#ab53b3d818bb3881738bed7b8a47c9eb2">warping</a>()<span class="keyword"> const</span>
  179. <a name="l00092"></a>00092 <span class="keyword"> </span>{
  180. <a name="l00093"></a>00093 <span class="keywordflow">return</span> warpSrc;
  181. <a name="l00094"></a>00094 }
  182. <a name="l00095"></a>00095
  183. <a name="l00096"></a><a class="code" href="classVABSNode__common.html#af6524af5c58ff7a1c177aaf3aaba0cee">00096</a> <span class="keywordtype">void</span> <a class="code" href="classVABSNode__common.html#af6524af5c58ff7a1c177aaf3aaba0cee">setWarping</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>,<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>* pntr)
  184. <a name="l00097"></a>00097 {
  185. <a name="l00098"></a>00098 warpSrc.<a class="code" href="classdataSource__Data.html#aefa4c87ef5fb27413a5f2ce1356638d7">getData</a>().setPointer(i,j,pntr,<span class="keyword">false</span>);
  186. <a name="l00099"></a>00099 }
  187. <a name="l00100"></a>00100 };
  188. <a name="l00101"></a>00101
  189. <a name="l00102"></a>00102 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  190. <a name="l00103"></a><a class="code" href="classVABSNode__element.html">00103</a> <span class="keyword">class </span><a class="code" href="classVABSNode__element.html">VABSNode_element</a> : <span class="keyword">public</span> <a class="code" href="classVABSNode.html">VABSNode</a>&lt;dataType&gt;
  191. <a name="l00104"></a>00104 {
  192. <a name="l00105"></a>00105 <span class="keyword">private</span>:
  193. <a name="l00106"></a>00106
  194. <a name="l00107"></a>00107 <a class="code" href="classdataSource__Data.html">dataSource_Data&lt;dataType&gt;</a> hSrc;
  195. <a name="l00108"></a>00108 <a class="code" href="classdataSource__Data.html">dataSource_Data&lt;dataType&gt;</a> angSrc;
  196. <a name="l00109"></a>00109 <a class="code" href="classVABSNode__common.html">VABSNode_common&lt;dataType&gt;</a>* common;
  197. <a name="l00110"></a>00110
  198. <a name="l00111"></a>00111 <span class="keyword">public</span>:
  199. <a name="l00112"></a>00112
  200. <a name="l00113"></a><a class="code" href="classVABSNode__element.html#a74b8f4f8455445ec22c902dd7190f69e">00113</a> <a class="code" href="classVABSNode__element.html#a74b8f4f8455445ec22c902dd7190f69e">VABSNode_element</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> h_in=0.5,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> ang_in=0.0,<a class="code" href="classVABSNode__common.html">VABSNode_common&lt;dataType&gt;</a>* common_in=NULL) : hSrc(h_in) , angSrc(ang_in) , common(common_in)
  201. <a name="l00114"></a>00114 {}
  202. <a name="l00115"></a>00115
  203. <a name="l00116"></a><a class="code" href="classVABSNode__element.html#a89fa980bf57dbff7ee2b322e4e7e37a1">00116</a> <a class="code" href="classVABSNode__element.html">VABSNode_element</a>&amp; <a class="code" href="classVABSNode__element.html#a89fa980bf57dbff7ee2b322e4e7e37a1">setH</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> h_in)
  204. <a name="l00117"></a>00117 {
  205. <a name="l00118"></a>00118 hSrc.<a class="code" href="classdataSource__Data.html#aefa4c87ef5fb27413a5f2ce1356638d7">getData</a>()=h_in;
  206. <a name="l00119"></a>00119 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  207. <a name="l00120"></a>00120 }
  208. <a name="l00121"></a>00121
  209. <a name="l00122"></a><a class="code" href="classVABSNode__element.html#ab65defe78f48f9e7d9eb8f41f24a86dd">00122</a> <a class="code" href="classVABSNode__element.html">VABSNode_element</a>&amp; <a class="code" href="classVABSNode__element.html#ab65defe78f48f9e7d9eb8f41f24a86dd">setAng</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> ang_in)
  210. <a name="l00123"></a>00123 {
  211. <a name="l00124"></a>00124 angSrc.<a class="code" href="classdataSource__Data.html#aefa4c87ef5fb27413a5f2ce1356638d7">getData</a>()=ang_in;
  212. <a name="l00125"></a>00125 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  213. <a name="l00126"></a>00126 }
  214. <a name="l00127"></a>00127
  215. <a name="l00128"></a><a class="code" href="classVABSNode__element.html#a86c4d761fb1b24efac2356d8527f5196">00128</a> <a class="code" href="classVABSNode__element.html">VABSNode_element</a>&amp; <a class="code" href="classVABSNode__element.html#a86c4d761fb1b24efac2356d8527f5196">setCommon</a>(<a class="code" href="classVABSNode__common.html">VABSNode_common&lt;dataType&gt;</a>* common_in)
  216. <a name="l00129"></a>00129 {
  217. <a name="l00130"></a>00130 common=common_in;
  218. <a name="l00131"></a>00131 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  219. <a name="l00132"></a>00132 }
  220. <a name="l00133"></a>00133
  221. <a name="l00134"></a><a class="code" href="classVABSNode__element.html#a201c12a31d10e45f0036ecc3e7509fe4">00134</a> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;dataType&gt;</a>&amp; <a class="code" href="classVABSNode__element.html#a201c12a31d10e45f0036ecc3e7509fe4">x</a>()<span class="keyword"> const</span>
  222. <a name="l00135"></a>00135 <span class="keyword"> </span>{
  223. <a name="l00136"></a>00136 <span class="keywordflow">if</span>(common==NULL)
  224. <a name="l00137"></a>00137 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABSNode_element::x(): The common node data has not been set&quot;</span>);
  225. <a name="l00138"></a>00138 <span class="keywordflow">return</span> common-&gt;x();
  226. <a name="l00139"></a>00139 }
  227. <a name="l00140"></a>00140
  228. <a name="l00141"></a><a class="code" href="classVABSNode__element.html#a5b4524069dfe5115920e9efe1aeebe13">00141</a> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;dataType&gt;</a>&amp; <a class="code" href="classVABSNode__element.html#a5b4524069dfe5115920e9efe1aeebe13">y</a>()<span class="keyword"> const</span>
  229. <a name="l00142"></a>00142 <span class="keyword"> </span>{
  230. <a name="l00143"></a>00143 <span class="keywordflow">if</span>(common==NULL)
  231. <a name="l00144"></a>00144 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABSNode_element::y(): The common node data has not been set&quot;</span>);
  232. <a name="l00145"></a>00145 <span class="keywordflow">return</span> common-&gt;y();
  233. <a name="l00146"></a>00146 }
  234. <a name="l00147"></a>00147
  235. <a name="l00148"></a><a class="code" href="classVABSNode__element.html#ad2dbcf0c1d265e3a2edcaa542e8f22c2">00148</a> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;matrixStatic&lt;dataType,3,4&gt;</a> &gt;&amp; <a class="code" href="classVABSNode__element.html#ad2dbcf0c1d265e3a2edcaa542e8f22c2">warping</a>()<span class="keyword"> const</span>
  236. <a name="l00149"></a>00149 <span class="keyword"> </span>{
  237. <a name="l00150"></a>00150 <span class="keywordflow">if</span>(common==NULL)
  238. <a name="l00151"></a>00151 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABSNode_element::warping(): The common node data has not been set&quot;</span>);
  239. <a name="l00152"></a>00152 <span class="keywordflow">return</span> common-&gt;warping();
  240. <a name="l00153"></a>00153 }
  241. <a name="l00154"></a>00154
  242. <a name="l00155"></a><a class="code" href="classVABSNode__element.html#acfb36b6a9bdc5e5b39586adb35dc5514">00155</a> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;dataType&gt;</a>&amp; <a class="code" href="classVABSNode__element.html#acfb36b6a9bdc5e5b39586adb35dc5514">h</a>()<span class="keyword"> const</span>
  243. <a name="l00156"></a>00156 <span class="keyword"> </span>{
  244. <a name="l00157"></a>00157 <span class="keywordflow">return</span> hSrc;
  245. <a name="l00158"></a>00158 }
  246. <a name="l00159"></a>00159
  247. <a name="l00160"></a><a class="code" href="classVABSNode__element.html#a71ba830ae4368a2d368624a48a4b0dad">00160</a> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource&lt;dataType&gt;</a>&amp; <a class="code" href="classVABSNode__element.html#a71ba830ae4368a2d368624a48a4b0dad">plyAngle</a>()<span class="keyword"> const</span>
  248. <a name="l00161"></a>00161 <span class="keyword"> </span>{
  249. <a name="l00162"></a>00162 <span class="keywordflow">return</span> angSrc;
  250. <a name="l00163"></a>00163 }
  251. <a name="l00164"></a>00164 };
  252. <a name="l00165"></a>00165
  253. <a name="l00166"></a>00166 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  254. <a name="l00167"></a><a class="code" href="classVABS1__MatrixSource.html">00167</a> <span class="keyword">class </span><a class="code" href="classVABS1__MatrixSource.html">VABS1_MatrixSource</a>
  255. <a name="l00168"></a>00168 {
  256. <a name="l00169"></a>00169 <span class="keyword">public</span>:
  257. <a name="l00170"></a>00170
  258. <a name="l00171"></a><a class="code" href="classVABS1__MatrixSource.html#a5a3abf044ac45bc7c7f19847bedc8db8">00171</a> <span class="keyword">virtual</span> <a class="code" href="classVABS1__MatrixSource.html#a5a3abf044ac45bc7c7f19847bedc8db8">~VABS1_MatrixSource</a>()
  259. <a name="l00172"></a>00172 {}
  260. <a name="l00173"></a>00173
  261. <a name="l00174"></a>00174 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classVABS1__MatrixSource.html#a161e7c3230c9372c9e70e68ebea02d34">addE</a>()=0;
  262. <a name="l00175"></a>00175 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classVABS1__MatrixSource.html#a2569e6b04d8c73c5615829db929066b9">addDee</a>()=0;
  263. <a name="l00176"></a>00176 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classVABS1__MatrixSource.html#a16927e196fd23ba8c8809097aee990cb">addDae</a>()=0;
  264. <a name="l00177"></a>00177 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classVABS1__MatrixSource.html#a73c217bf4f8c74b74223f724a7cad571">addH</a>()=0;
  265. <a name="l00178"></a>00178 <span class="comment">// virtual void addPsi()=0;</span>
  266. <a name="l00179"></a>00179 };
  267. <a name="l00180"></a>00180
  268. <a name="l00181"></a>00181 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  269. <a name="l00182"></a><a class="code" href="classfunction2D__Gamma__a.html">00182</a> <span class="keyword">class </span><a class="code" href="classfunction2D__Gamma__a.html">function2D_Gamma_a</a> : <span class="keyword">public</span> <a class="code" href="classfunction2D.html">function2D</a>&lt;matrixRdWtSz_Data&lt;dataType&gt;,dataType&gt;
  270. <a name="l00183"></a>00183 {
  271. <a name="l00184"></a>00184 <span class="keyword">private</span>:
  272. <a name="l00185"></a>00185
  273. <a name="l00186"></a>00186 std::vector&lt;isoGrad2D&lt;dataType,dataType&gt; &gt;* shpGrad;
  274. <a name="l00187"></a>00187
  275. <a name="l00188"></a>00188 <span class="keyword">public</span>:
  276. <a name="l00189"></a>00189
  277. <a name="l00190"></a><a class="code" href="classfunction2D__Gamma__a.html#a2fa3ec16927f9f8a113a5881c42abf25">00190</a> <a class="code" href="classfunction2D__Gamma__a.html#a2fa3ec16927f9f8a113a5881c42abf25">function2D_Gamma_a</a>(std::vector&lt;<a class="code" href="classisoGrad2D.html">isoGrad2D&lt;dataType,dataType&gt;</a> &gt;* shpGrad_in=NULL) : shpGrad(shpGrad_in)
  278. <a name="l00191"></a>00191 {}
  279. <a name="l00192"></a>00192
  280. <a name="l00193"></a><a class="code" href="classfunction2D__Gamma__a.html#ada070084c7e4862d43d00e273e866398">00193</a> <span class="keyword">virtual</span> <a class="code" href="classfunction2D__Gamma__a.html#ada070084c7e4862d43d00e273e866398">~function2D_Gamma_a</a>()
  281. <a name="l00194"></a>00194 {}
  282. <a name="l00195"></a>00195
  283. <a name="l00196"></a><a class="code" href="classfunction2D__Gamma__a.html#a87b84825cd3c347f8bc7681402a4b015">00196</a> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> <a class="code" href="classfunction2D__Gamma__a.html#a87b84825cd3c347f8bc7681402a4b015">getValue2D</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> at1,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> at2)
  284. <a name="l00197"></a>00197 {
  285. <a name="l00198"></a>00198 <span class="keywordflow">if</span>(shpGrad==NULL)
  286. <a name="l00199"></a>00199 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;function2D_Gamma_a::getValue2D(): The shape grad has not been set&quot;</span>);
  287. <a name="l00200"></a>00200 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> colCnt=shpGrad-&gt;size();
  288. <a name="l00201"></a>00201 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> retVal(6,colCnt*3);
  289. <a name="l00202"></a>00202 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;colCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  290. <a name="l00203"></a>00203 {
  291. <a name="l00204"></a>00204 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;6;j++)
  292. <a name="l00205"></a>00205 {
  293. <a name="l00206"></a>00206 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k&lt;3;k++)
  294. <a name="l00207"></a>00207 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(j,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+k)=0.0;
  295. <a name="l00208"></a>00208 }
  296. <a name="l00209"></a>00209 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(1,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1)=(*shpGrad)[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].getGrad1(at1,at2); <span class="comment">// 22</span>
  297. <a name="l00210"></a>00210 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(2,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2)=(*shpGrad)[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].getGrad2(at1,at2); <span class="comment">// 33</span>
  298. <a name="l00211"></a>00211 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(3,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3)=(*shpGrad)[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].getGrad1(at1,at2); <span class="comment">// 12</span>
  299. <a name="l00212"></a>00212 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(4,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3)=(*shpGrad)[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].getGrad2(at1,at2); <span class="comment">// 13</span>
  300. <a name="l00213"></a>00213 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(5,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1)=(*shpGrad)[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].getGrad2(at1,at2); <span class="comment">// 23</span>
  301. <a name="l00214"></a>00214 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(5,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2)=(*shpGrad)[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].getGrad1(at1,at2); <span class="comment">// 23</span>
  302. <a name="l00215"></a>00215 }
  303. <a name="l00216"></a>00216 <span class="keywordflow">return</span> retVal;
  304. <a name="l00217"></a>00217 }
  305. <a name="l00218"></a>00218 };
  306. <a name="l00219"></a>00219
  307. <a name="l00220"></a>00220 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  308. <a name="l00221"></a><a class="code" href="classfunction2D__Gamma__e.html">00221</a> <span class="keyword">class </span><a class="code" href="classfunction2D__Gamma__e.html">function2D_Gamma_e</a> : <span class="keyword">public</span> <a class="code" href="classfunction2D.html">function2D</a>&lt;matrixRdWtStatic_Data&lt;dataType,6,4&gt;,dataType&gt;
  309. <a name="l00222"></a>00222 {
  310. <a name="l00223"></a>00223 <span class="keyword">private</span>:
  311. <a name="l00224"></a>00224
  312. <a name="l00225"></a>00225 <a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* xLoc;
  313. <a name="l00226"></a>00226 <a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* yLoc;
  314. <a name="l00227"></a>00227
  315. <a name="l00228"></a>00228 <span class="keyword">static</span> <span class="keywordtype">bool</span> isFirst;
  316. <a name="l00229"></a>00229
  317. <a name="l00230"></a>00230 <span class="keyword">public</span>:
  318. <a name="l00231"></a>00231
  319. <a name="l00232"></a><a class="code" href="classfunction2D__Gamma__e.html#aec36edf5f06e62dad57f89d47accc153">00232</a> <a class="code" href="classfunction2D__Gamma__e.html#aec36edf5f06e62dad57f89d47accc153">function2D_Gamma_e</a>(<a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* xLoc_in=NULL,<a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* yLoc_in=NULL) : xLoc(xLoc_in) , yLoc(yLoc_in)
  320. <a name="l00233"></a>00233 {}
  321. <a name="l00234"></a>00234
  322. <a name="l00235"></a><a class="code" href="classfunction2D__Gamma__e.html#a1fe0800dade51e4093b894ac7f30536f">00235</a> <a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data&lt;dataType,6,4&gt;</a> <a class="code" href="classfunction2D__Gamma__e.html#a1fe0800dade51e4093b894ac7f30536f">getValue2D</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> at1,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> at2)
  323. <a name="l00236"></a>00236 {
  324. <a name="l00237"></a>00237 <span class="keywordflow">if</span>(xLoc==NULL || yLoc==NULL)
  325. <a name="l00238"></a>00238 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;function2D_Gamma_e::getValue2D(): The x and y locations have not been set&quot;</span>);
  326. <a name="l00239"></a>00239 <a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data&lt;dataType,6,4&gt;</a> retVal;
  327. <a name="l00240"></a>00240 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;6;j++)
  328. <a name="l00241"></a>00241 {
  329. <a name="l00242"></a>00242 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k&lt;4;k++)
  330. <a name="l00243"></a>00243 retVal.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(j,k)=0.0;
  331. <a name="l00244"></a>00244 }
  332. <a name="l00245"></a>00245 retVal.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(0,0)=1.0; <span class="comment">// 11</span>
  333. <a name="l00246"></a>00246 retVal.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(0,2)=yLoc-&gt;<a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2); <span class="comment">// 11</span>
  334. <a name="l00247"></a>00247 retVal.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(0,3)=-(xLoc-&gt;<a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2)); <span class="comment">// 11</span>
  335. <a name="l00248"></a>00248 retVal.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(3,1)=-(yLoc-&gt;<a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2)); <span class="comment">// 12</span>
  336. <a name="l00249"></a>00249 retVal.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(4,1)=xLoc-&gt;<a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2); <span class="comment">// 13</span>
  337. <a name="l00250"></a>00250
  338. <a name="l00251"></a>00251 <span class="keywordflow">if</span>(isFirst)
  339. <a name="l00252"></a>00252 {
  340. <a name="l00253"></a>00253 std::cout &lt;&lt; <span class="stringliteral">&quot;Remember that you have to include the metric tensor into VABS for the case where there is initial curvature&quot;</span> &lt;&lt; std::endl;
  341. <a name="l00254"></a>00254 std::cout &lt;&lt; <span class="stringliteral">&quot;One other thing... the vabs blade does not shift the cross section to the desired origin. Just to the Xbar and Ybar&quot;</span> &lt;&lt; std::endl;
  342. <a name="l00255"></a>00255 isFirst=<span class="keyword">false</span>;
  343. <a name="l00256"></a>00256 }
  344. <a name="l00257"></a>00257
  345. <a name="l00258"></a>00258 <span class="keywordflow">return</span> retVal;
  346. <a name="l00259"></a>00259 }
  347. <a name="l00260"></a>00260 };
  348. <a name="l00261"></a>00261
  349. <a name="l00262"></a>00262 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  350. <a name="l00263"></a>00263 <span class="keywordtype">bool</span> <a class="code" href="classfunction2D__Gamma__e.html">function2D_Gamma_e&lt;dataType&gt;::isFirst</a>=<span class="keyword">true</span>;
  351. <a name="l00264"></a>00264
  352. <a name="l00265"></a>00265 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  353. <a name="l00266"></a><a class="code" href="classfunction2D__ShapeDiag.html">00266</a> <span class="keyword">class </span><a class="code" href="classfunction2D__ShapeDiag.html">function2D_ShapeDiag</a> : <span class="keyword">public</span> <a class="code" href="classfunction2D.html">function2D</a>&lt;matrixRdWtSz_Data&lt;dataType&gt;,dataType&gt;
  354. <a name="l00267"></a>00267 {
  355. <a name="l00268"></a>00268 <span class="keyword">private</span>:
  356. <a name="l00269"></a>00269
  357. <a name="l00270"></a>00270 std::vector&lt;isoGrad2D&lt;dataType,dataType&gt; &gt;* shpGrad;
  358. <a name="l00271"></a>00271
  359. <a name="l00272"></a>00272 <span class="keyword">public</span>:
  360. <a name="l00273"></a>00273
  361. <a name="l00274"></a><a class="code" href="classfunction2D__ShapeDiag.html#a4826cb643557ee732da15604ba877c4c">00274</a> <a class="code" href="classfunction2D__ShapeDiag.html#a4826cb643557ee732da15604ba877c4c">function2D_ShapeDiag</a>(std::vector&lt;<a class="code" href="classisoGrad2D.html">isoGrad2D&lt;dataType,dataType&gt;</a> &gt;* shpGrad_in=NULL) : shpGrad(shpGrad_in)
  362. <a name="l00275"></a>00275 {}
  363. <a name="l00276"></a>00276
  364. <a name="l00277"></a><a class="code" href="classfunction2D__ShapeDiag.html#a72675ea3d3e7fc00fc05fb34f3ff1d29">00277</a> <span class="keyword">virtual</span> <a class="code" href="classfunction2D__ShapeDiag.html#a72675ea3d3e7fc00fc05fb34f3ff1d29">~function2D_ShapeDiag</a>()
  365. <a name="l00278"></a>00278 {}
  366. <a name="l00279"></a>00279
  367. <a name="l00280"></a><a class="code" href="classfunction2D__ShapeDiag.html#a332be29feaa9b2b691036da939c2eb43">00280</a> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> <a class="code" href="classfunction2D__ShapeDiag.html#a332be29feaa9b2b691036da939c2eb43">getValue2D</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> at1,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> at2)
  368. <a name="l00281"></a>00281 {
  369. <a name="l00282"></a>00282 <span class="keywordflow">if</span>(shpGrad==NULL)
  370. <a name="l00283"></a>00283 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;function2D_ShapeDiag::getValue2D(): The shape grad has not been set&quot;</span>);
  371. <a name="l00284"></a>00284 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> colCnt=shpGrad-&gt;size();
  372. <a name="l00285"></a>00285 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> retVal(3,colCnt*3);
  373. <a name="l00286"></a>00286 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;colCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  374. <a name="l00287"></a>00287 {
  375. <a name="l00288"></a>00288 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;3;j++)
  376. <a name="l00289"></a>00289 {
  377. <a name="l00290"></a>00290 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k&lt;3;k++)
  378. <a name="l00291"></a>00291 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(j,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+k)=0.0;
  379. <a name="l00292"></a>00292 }
  380. <a name="l00293"></a>00293 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(0,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3)=(*shpGrad)[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].getValue2D(at1,at2);
  381. <a name="l00294"></a>00294 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(1,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1)=(*shpGrad)[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].getValue2D(at1,at2);
  382. <a name="l00295"></a>00295 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(2,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2)=(*shpGrad)[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].getValue2D(at1,at2);
  383. <a name="l00296"></a>00296 }
  384. <a name="l00297"></a>00297
  385. <a name="l00298"></a>00298 <span class="keywordflow">return</span> retVal;
  386. <a name="l00299"></a>00299 }
  387. <a name="l00300"></a>00300 };
  388. <a name="l00301"></a>00301
  389. <a name="l00302"></a>00302 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  390. <a name="l00303"></a><a class="code" href="classfunction2D__vabsNull.html">00303</a> <span class="keyword">class </span><a class="code" href="classfunction2D__vabsNull.html">function2D_vabsNull</a> : <span class="keyword">public</span> <a class="code" href="classfunction2D.html">function2D</a>&lt;matrixRdWtSz_Data&lt;dataType&gt;,dataType&gt;
  391. <a name="l00304"></a>00304 {
  392. <a name="l00305"></a>00305 <span class="keyword">private</span>:
  393. <a name="l00306"></a>00306
  394. <a name="l00307"></a>00307 <a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* xFunc;
  395. <a name="l00308"></a>00308 <a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* yFunc;
  396. <a name="l00309"></a>00309 <span class="keywordtype">bool</span> deleteX;
  397. <a name="l00310"></a>00310 <span class="keywordtype">bool</span> deleteY;
  398. <a name="l00311"></a>00311
  399. <a name="l00312"></a>00312 <span class="keyword">public</span>:
  400. <a name="l00313"></a>00313
  401. <a name="l00314"></a><a class="code" href="classfunction2D__vabsNull.html#abed270cdd88dffa0f3520bc651b6e28e">00314</a> <a class="code" href="classfunction2D__vabsNull.html#abed270cdd88dffa0f3520bc651b6e28e">function2D_vabsNull</a>(
  402. <a name="l00315"></a>00315 <a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* xFunc_in=NULL
  403. <a name="l00316"></a>00316 , <a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* yFunc_in=NULL
  404. <a name="l00317"></a>00317 , <span class="keywordtype">bool</span> deleteX_in=<span class="keyword">false</span>
  405. <a name="l00318"></a>00318 , <span class="keywordtype">bool</span> deleteY_in=<span class="keyword">false</span>
  406. <a name="l00319"></a>00319 )
  407. <a name="l00320"></a>00320 : xFunc(xFunc_in)
  408. <a name="l00321"></a>00321 , yFunc(yFunc_in)
  409. <a name="l00322"></a>00322 , deleteX(deleteX_in)
  410. <a name="l00323"></a>00323 , deleteY(deleteY_in)
  411. <a name="l00324"></a>00324 {}
  412. <a name="l00325"></a>00325
  413. <a name="l00326"></a><a class="code" href="classfunction2D__vabsNull.html#a8895ac9819cb9b1044913567cb283325">00326</a> <span class="keyword">virtual</span> <a class="code" href="classfunction2D__vabsNull.html#a8895ac9819cb9b1044913567cb283325">~function2D_vabsNull</a>()
  414. <a name="l00327"></a>00327 {
  415. <a name="l00328"></a>00328 <span class="keywordflow">if</span>(deleteX &amp;&amp; xFunc!=NULL)
  416. <a name="l00329"></a>00329 <span class="keyword">delete</span> xFunc;
  417. <a name="l00330"></a>00330 <span class="keywordflow">if</span>(deleteY &amp;&amp; yFunc!=NULL)
  418. <a name="l00331"></a>00331 <span class="keyword">delete</span> yFunc;
  419. <a name="l00332"></a>00332 }
  420. <a name="l00333"></a>00333
  421. <a name="l00334"></a><a class="code" href="classfunction2D__vabsNull.html#a842b1f91ef7d5ed7c17eaadfb6de2400">00334</a> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> <a class="code" href="classfunction2D__vabsNull.html#a842b1f91ef7d5ed7c17eaadfb6de2400">getValue2D</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> at1,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> at2)
  422. <a name="l00335"></a>00335 {
  423. <a name="l00336"></a>00336 <span class="keywordflow">if</span>(xFunc==NULL)
  424. <a name="l00337"></a>00337 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;function2D_vabsNull::getValue2D(): The x function has not been specified&quot;</span>);
  425. <a name="l00338"></a>00338 <span class="keywordflow">if</span>(yFunc==NULL)
  426. <a name="l00339"></a>00339 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;function2D_vabsNull::getValue2D(): The y function has not been specified&quot;</span>);
  427. <a name="l00340"></a>00340
  428. <a name="l00341"></a>00341 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> retVal=<a class="code" href="classmatrixStatic__Zero.html">matrixStatic_Zero&lt;dataType,3,4&gt;</a>();
  429. <a name="l00342"></a>00342
  430. <a name="l00343"></a>00343 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> x=xFunc-&gt;<a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2);
  431. <a name="l00344"></a>00344 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> y=yFunc-&gt;<a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2);
  432. <a name="l00345"></a>00345
  433. <a name="l00346"></a>00346 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(0,0)=1.0;
  434. <a name="l00347"></a>00347 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(1,1)=1.0;
  435. <a name="l00348"></a>00348 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(2,2)=1.0;
  436. <a name="l00349"></a>00349 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(1,3)=y;
  437. <a name="l00350"></a>00350 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(2,3)=-x;
  438. <a name="l00351"></a>00351
  439. <a name="l00352"></a>00352 <span class="keywordflow">return</span> retVal;
  440. <a name="l00353"></a>00353 }
  441. <a name="l00354"></a>00354 };
  442. <a name="l00355"></a>00355
  443. <a name="l00356"></a>00356 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  444. <a name="l00357"></a><a class="code" href="classfunction2D__matl.html">00357</a> <span class="keyword">class </span><a class="code" href="classfunction2D__matl.html">function2D_matl</a> : <span class="keyword">public</span> <a class="code" href="classfunction2D.html">function2D</a>&lt;matrixRdWtStaticSqr_Data&lt;dataType,6&gt;,dataType&gt;
  445. <a name="l00358"></a>00358 {
  446. <a name="l00359"></a>00359 <span class="keyword">private</span>:
  447. <a name="l00360"></a>00360
  448. <a name="l00361"></a>00361 <a class="code" href="classconstituitive.html">constituitive&lt;dataType&gt;</a>* matl;
  449. <a name="l00362"></a>00362 <a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* hFunc;
  450. <a name="l00363"></a>00363 <a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* angFunc;
  451. <a name="l00364"></a>00364
  452. <a name="l00365"></a>00365 <span class="keyword">public</span>:
  453. <a name="l00366"></a>00366
  454. <a name="l00367"></a><a class="code" href="classfunction2D__matl.html#a2b4db79d3ec18f6890200036285e754c">00367</a> <a class="code" href="classfunction2D__matl.html#a2b4db79d3ec18f6890200036285e754c">function2D_matl</a>(<a class="code" href="classconstituitive.html">constituitive&lt;dataType&gt;</a>* matl_in=NULL,<a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* hFunc_in=NULL,<a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* angFunc_in=NULL) : matl(matl_in) , hFunc(hFunc_in) , angFunc(angFunc_in)
  455. <a name="l00368"></a>00368 {}
  456. <a name="l00369"></a>00369
  457. <a name="l00370"></a><a class="code" href="classfunction2D__matl.html#ac81b5af8a6bc9f8e1f59f2286d7b163e">00370</a> <span class="keyword">virtual</span> <a class="code" href="classfunction2D__matl.html#ac81b5af8a6bc9f8e1f59f2286d7b163e">~function2D_matl</a>()
  458. <a name="l00371"></a>00371 {}
  459. <a name="l00372"></a>00372
  460. <a name="l00373"></a><a class="code" href="classfunction2D__matl.html#ae409771e5bd75a596d5ec2343116e2e4">00373</a> <a class="code" href="classfunction2D__matl.html">function2D_matl</a>&amp; <a class="code" href="classfunction2D__matl.html#ae409771e5bd75a596d5ec2343116e2e4">setMaterial</a>(<a class="code" href="classconstituitive.html">constituitive&lt;dataType&gt;</a>* matl_in)
  461. <a name="l00374"></a>00374 {
  462. <a name="l00375"></a>00375 matl=matl_in;
  463. <a name="l00376"></a>00376 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  464. <a name="l00377"></a>00377 }
  465. <a name="l00378"></a>00378
  466. <a name="l00379"></a><a class="code" href="classfunction2D__matl.html#af3e5d719633e70253a5b624318c7a19c">00379</a> <a class="code" href="classfunction2D__matl.html">function2D_matl</a>&amp; <a class="code" href="classfunction2D__matl.html#af3e5d719633e70253a5b624318c7a19c">setHFunc</a>(<a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* hFunc_in)
  467. <a name="l00380"></a>00380 {
  468. <a name="l00381"></a>00381 hFunc=hFunc_in;
  469. <a name="l00382"></a>00382 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  470. <a name="l00383"></a>00383 }
  471. <a name="l00384"></a>00384
  472. <a name="l00385"></a><a class="code" href="classfunction2D__matl.html#aad1ec0748e2bc534b5a98825f5df2465">00385</a> <a class="code" href="classfunction2D__matl.html">function2D_matl</a>&amp; <a class="code" href="classfunction2D__matl.html#aad1ec0748e2bc534b5a98825f5df2465">setAngleFunc</a>(<a class="code" href="classfunction2D.html">function2D&lt;dataType,dataType&gt;</a>* angFunc_in)
  473. <a name="l00386"></a>00386 {
  474. <a name="l00387"></a>00387 angFunc=angFunc_in;
  475. <a name="l00388"></a>00388 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  476. <a name="l00389"></a>00389 }
  477. <a name="l00390"></a>00390
  478. <a name="l00391"></a><a class="code" href="classfunction2D__matl.html#a958969e2595caddf27c440c20a3eb488">00391</a> <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,6&gt;</a> <a class="code" href="classfunction2D__matl.html#a958969e2595caddf27c440c20a3eb488">getValue2D</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> at1,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> at2)
  479. <a name="l00392"></a>00392 {
  480. <a name="l00393"></a>00393 <span class="keywordflow">if</span>(matl==NULL || hFunc==NULL || angFunc==NULL)
  481. <a name="l00394"></a>00394 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;function2D_matl::getValue2D(): The dependent data has not been set&quot;</span>);
  482. <a name="l00395"></a>00395 <span class="keywordflow">return</span> matl-&gt;matlMatrix(<a class="code" href="classconstituitiveDependent.html">constituitiveDependent&lt;dataType&gt;</a>(angFunc-&gt;<a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2),hFunc-&gt;<a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2)));
  483. <a name="l00396"></a>00396 }
  484. <a name="l00397"></a>00397 };
  485. <a name="l00398"></a>00398
  486. <a name="l00399"></a>00399 <span class="comment">// this class is the post processing interface for the vabs elements</span>
  487. <a name="l00400"></a>00400 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> strainType&gt;
  488. <a name="l00401"></a><a class="code" href="classVABSElementInfo.html">00401</a> <span class="keyword">class </span><a class="code" href="classVABSElementInfo.html">VABSElementInfo</a>
  489. <a name="l00402"></a>00402 {
  490. <a name="l00403"></a>00403 <span class="keyword">public</span>:
  491. <a name="l00404"></a>00404
  492. <a name="l00405"></a><a class="code" href="classVABSElementInfo.html#a579a5baf15ad22905e942a550d5f7b51">00405</a> <a class="code" href="classVABSElementInfo.html#a579a5baf15ad22905e942a550d5f7b51">VABSElementInfo</a>()
  493. <a name="l00406"></a>00406 {}
  494. <a name="l00407"></a>00407
  495. <a name="l00408"></a><a class="code" href="classVABSElementInfo.html#ad9709582a76666a7fddbc70693240333">00408</a> <span class="keyword">virtual</span> <a class="code" href="classVABSElementInfo.html#ad9709582a76666a7fddbc70693240333">~VABSElementInfo</a>()
  496. <a name="l00409"></a>00409 {}
  497. <a name="l00410"></a>00410
  498. <a name="l00411"></a>00411 <span class="keyword">virtual</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABSElementInfo.html#a20130a423f8b19120fbf4be6361283f7">fail</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="namespaceCPPL.html#ab544de2e0cfe3ab6180d91ac5febff72">t</a>,<span class="keyword">const</span> strainType&amp; beamStrain)=0;
  499. <a name="l00412"></a>00412 };
  500. <a name="l00413"></a>00413
  501. <a name="l00414"></a>00414 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> strainType&gt;
  502. <a name="l00415"></a><a class="code" href="classVABSElementInfo__Pntr.html">00415</a> <span class="keyword">class </span><a class="code" href="classVABSElementInfo__Pntr.html">VABSElementInfo_Pntr</a> : <span class="keyword">public</span> <a class="code" href="classVABSElementInfo.html">VABSElementInfo</a>&lt;dataType,strainType&gt;
  503. <a name="l00416"></a>00416 {
  504. <a name="l00417"></a>00417 <span class="keyword">private</span>:
  505. <a name="l00418"></a>00418
  506. <a name="l00419"></a>00419 <a class="code" href="classVABSElementInfo.html">VABSElementInfo&lt;dataType,strainType&gt;</a>* pElm;
  507. <a name="l00420"></a>00420 <span class="keywordtype">bool</span> canDelete;
  508. <a name="l00421"></a>00421
  509. <a name="l00422"></a>00422 <span class="keyword">public</span>:
  510. <a name="l00423"></a>00423
  511. <a name="l00424"></a><a class="code" href="classVABSElementInfo__Pntr.html#a0d23923e82fcdab312ef9e2d6369a65a">00424</a> <a class="code" href="classVABSElementInfo__Pntr.html#a0d23923e82fcdab312ef9e2d6369a65a">VABSElementInfo_Pntr</a>(<a class="code" href="classVABSElementInfo.html">VABSElementInfo&lt;dataType,strainType&gt;</a>* pElm_in=NULL,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : pElm(pElm_in) , canDelete(canDelete_in)
  512. <a name="l00425"></a>00425 {}
  513. <a name="l00426"></a>00426
  514. <a name="l00427"></a><a class="code" href="classVABSElementInfo__Pntr.html#a9e2eaa8090de0c9c0c362dcf8777282c">00427</a> <a class="code" href="classVABSElementInfo__Pntr.html#a0d23923e82fcdab312ef9e2d6369a65a">VABSElementInfo_Pntr</a>(<span class="keyword">const</span> <a class="code" href="classVABSElementInfo__Pntr.html">VABSElementInfo_Pntr&lt;dataType,strainType&gt;</a>&amp; asg) : pElm(asg.pElm) , canDelete(asg.canDelete)
  515. <a name="l00428"></a>00428 {}
  516. <a name="l00429"></a>00429
  517. <a name="l00430"></a><a class="code" href="classVABSElementInfo__Pntr.html#aaa6844d9c5db6d8fa245c35e527ad76e">00430</a> <span class="keyword">virtual</span> <a class="code" href="classVABSElementInfo__Pntr.html#aaa6844d9c5db6d8fa245c35e527ad76e">~VABSElementInfo_Pntr</a>()
  518. <a name="l00431"></a>00431 {
  519. <a name="l00432"></a>00432 <span class="keywordflow">if</span>(canDelete &amp;&amp; pElm!=NULL)
  520. <a name="l00433"></a>00433 <span class="keyword">delete</span> pElm;
  521. <a name="l00434"></a>00434 }
  522. <a name="l00435"></a>00435
  523. <a name="l00436"></a><a class="code" href="classVABSElementInfo__Pntr.html#a35bf0e1211d31585e1bb90e582174638">00436</a> <a class="code" href="classVABSElementInfo__Pntr.html">VABSElementInfo_Pntr&lt;dataType,strainType&gt;</a>&amp; <a class="code" href="classVABSElementInfo__Pntr.html#a35bf0e1211d31585e1bb90e582174638">operator=</a>(<span class="keyword">const</span> <a class="code" href="classVABSElementInfo__Pntr.html">VABSElementInfo_Pntr&lt;dataType,strainType&gt;</a>&amp; asg)
  524. <a name="l00437"></a>00437 {
  525. <a name="l00438"></a>00438 <span class="keywordflow">return</span> this-&gt;<a class="code" href="classVABSElementInfo__Pntr.html#a249372b252360cda83e9f78281a9fe2b">setPointer</a>(asg.pElm);
  526. <a name="l00439"></a>00439 }
  527. <a name="l00440"></a>00440
  528. <a name="l00441"></a><a class="code" href="classVABSElementInfo__Pntr.html#a249372b252360cda83e9f78281a9fe2b">00441</a> <a class="code" href="classVABSElementInfo__Pntr.html">VABSElementInfo_Pntr&lt;dataType,strainType&gt;</a>&amp; <a class="code" href="classVABSElementInfo__Pntr.html#a249372b252360cda83e9f78281a9fe2b">setPointer</a>(<a class="code" href="classVABSElementInfo.html">VABSElementInfo&lt;dataType,strainType&gt;</a>* pElm_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
  529. <a name="l00442"></a>00442 {
  530. <a name="l00443"></a>00443 <span class="keywordflow">if</span>(canDelete &amp;&amp; pElm!=NULL &amp;&amp; pElm_in!=pElm)
  531. <a name="l00444"></a>00444 <span class="keyword">delete</span> pElm;
  532. <a name="l00445"></a>00445
  533. <a name="l00446"></a>00446 pElm=pElm_in;
  534. <a name="l00447"></a>00447 canDelete=canDelete_in;
  535. <a name="l00448"></a>00448
  536. <a name="l00449"></a>00449 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  537. <a name="l00450"></a>00450 }
  538. <a name="l00451"></a>00451
  539. <a name="l00452"></a><a class="code" href="classVABSElementInfo__Pntr.html#a20f6b4b78e501454558902a2fe99acad">00452</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABSElementInfo__Pntr.html#a20f6b4b78e501454558902a2fe99acad">fail</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="namespaceCPPL.html#ab544de2e0cfe3ab6180d91ac5febff72">t</a>,<span class="keyword">const</span> strainType&amp; beamStrain)
  540. <a name="l00453"></a>00453 {
  541. <a name="l00454"></a>00454 <span class="keywordflow">if</span>(pElm==NULL)
  542. <a name="l00455"></a>00455 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABSElementInfo_Pntr::fail(): The pointer has not been set&quot;</span>);
  543. <a name="l00456"></a>00456
  544. <a name="l00457"></a>00457 <span class="keywordflow">return</span> pElm-&gt;fail(s,t,beamStrain);
  545. <a name="l00458"></a>00458 }
  546. <a name="l00459"></a>00459 };
  547. <a name="l00460"></a>00460
  548. <a name="l00461"></a>00461 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  549. <a name="l00462"></a><a class="code" href="classVABS1__MatrixSource__Quad.html">00462</a> <span class="keyword">class </span><a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad</a> : <span class="keyword">public</span> <a class="code" href="classVABS1__MatrixSource.html">VABS1_MatrixSource</a>&lt;dataType&gt; , <span class="keyword">public</span> <a class="code" href="classVABSElementInfo.html">VABSElementInfo</a>&lt;dataType,matrixStaticVectCol&lt;dataType,4&gt; &gt;
  550. <a name="l00463"></a>00463 {
  551. <a name="l00464"></a>00464
  552. <a name="l00465"></a>00465 <span class="comment">// template&lt;class altType&gt; friend class VABS1_Model_Base; // Debug</span>
  553. <a name="l00466"></a>00466
  554. <a name="l00467"></a>00467 <span class="keyword">private</span>:
  555. <a name="l00468"></a>00468
  556. <a name="l00470"></a>00470 <span class="comment">// these are the state data objects</span>
  557. <a name="l00472"></a>00472 <span class="comment"></span>
  558. <a name="l00473"></a>00473 <span class="comment">// these are the only externally supplied objects</span>
  559. <a name="l00474"></a>00474 std::vector&lt;VABSNode&lt;dataType&gt;* &gt; nds;
  560. <a name="l00475"></a>00475 <a class="code" href="classconstituitive.html">constituitive&lt;dataType&gt;</a>* matl;
  561. <a name="l00476"></a>00476 <span class="keywordtype">bool</span> objectsSet;
  562. <a name="l00477"></a>00477
  563. <a name="l00479"></a>00479 <span class="comment">// these are the internally created objects</span>
  564. <a name="l00481"></a>00481 <span class="comment"></span>
  565. <a name="l00482"></a>00482 <span class="comment">// These are the domain objects</span>
  566. <a name="l00483"></a>00483 std::vector&lt;function_Lagrange&lt;dataType&gt; &gt; shp1D;
  567. <a name="l00484"></a>00484 std::vector&lt;function2DD1_product1D&lt;dataType,dataType&gt; &gt; shp2D;
  568. <a name="l00485"></a>00485 std::vector&lt;isoGrad2D&lt;dataType,dataType&gt; &gt; shpGrad;
  569. <a name="l00486"></a>00486 <a class="code" href="classisoFunction2D.html">isoFunction2D&lt;dataType,dataType&gt;</a> xFunc;
  570. <a name="l00487"></a>00487 <a class="code" href="classisoFunction2D.html">isoFunction2D&lt;dataType,dataType&gt;</a> yFunc;
  571. <a name="l00488"></a>00488 <a class="code" href="classfunction2D__jacobian.html">function2D_jacobian&lt;dataType&gt;</a> jac2D;
  572. <a name="l00489"></a>00489 <a class="code" href="classnested2D.html">nested2D&lt;dataType,dataType&gt;</a> innerJac;
  573. <a name="l00490"></a>00490 <a class="code" href="classfunction__constant.html">function_constant&lt;dataType,dataType&gt;</a> outerJac;
  574. <a name="l00491"></a>00491
  575. <a name="l00492"></a>00492 <span class="comment">// These are the material objects</span>
  576. <a name="l00493"></a>00493 <a class="code" href="classisoFunction2D.html">isoFunction2D&lt;dataType,dataType&gt;</a> hFunc;
  577. <a name="l00494"></a>00494 <a class="code" href="classisoFunction2D.html">isoFunction2D&lt;dataType,dataType&gt;</a> angFunc;
  578. <a name="l00495"></a>00495 <a class="code" href="classfunction2D__matl.html">function2D_matl&lt;dataType&gt;</a> matlFunc;
  579. <a name="l00496"></a>00496
  580. <a name="l00497"></a>00497 <span class="comment">// important shape and Gamma matrices</span>
  581. <a name="l00498"></a>00498 <a class="code" href="classfunction2D__Gamma__a.html">function2D_Gamma_a&lt;dataType&gt;</a> Gamma_a;
  582. <a name="l00499"></a>00499 <a class="code" href="classfunction2D__Gamma__e.html">function2D_Gamma_e&lt;dataType&gt;</a> Gamma_e;
  583. <a name="l00500"></a>00500 <a class="code" href="classfunction2D__ShapeDiag.html">function2D_ShapeDiag&lt;dataType&gt;</a> shapeDiag;
  584. <a name="l00501"></a>00501 <span class="comment">// function2D_vabsNull&lt;dataType&gt; vabsNull;</span>
  585. <a name="l00502"></a>00502
  586. <a name="l00503"></a>00503 <span class="comment">// e matrix objects</span>
  587. <a name="l00504"></a>00504 <a class="code" href="classfunction2D__tripleProduct.html">function2D_tripleProduct&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,6&gt;</a> &gt; pointEMatrix;
  588. <a name="l00505"></a>00505 <a class="code" href="classnested2D.html">nested2D&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; innerFuncEMatrix;
  589. <a name="l00506"></a>00506 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; innerEMatrixInt;
  590. <a name="l00507"></a>00507 <a class="code" href="classintegralFunction.html">integralFunction&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; outerFuncEMatrix;
  591. <a name="l00508"></a>00508 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; outerEMatrixInt;
  592. <a name="l00509"></a>00509
  593. <a name="l00510"></a>00510 <span class="comment">// these are the objects for Dae</span>
  594. <a name="l00511"></a>00511 <a class="code" href="classfunction2D__tripleProduct.html">function2D_tripleProduct&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,6&gt;</a>,<a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data&lt;dataType,6,4&gt;</a> &gt; pointDaeMatrix;
  595. <a name="l00512"></a>00512 <a class="code" href="classnested2D.html">nested2D&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; innerFuncDaeMatrix;
  596. <a name="l00513"></a>00513 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; innerDaeMatrixInt;
  597. <a name="l00514"></a>00514 <a class="code" href="classintegralFunction.html">integralFunction&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; outerFuncDaeMatrix;
  598. <a name="l00515"></a>00515 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; outerDaeMatrixInt;
  599. <a name="l00516"></a>00516
  600. <a name="l00517"></a>00517 <span class="comment">// these are the objects for Dee</span>
  601. <a name="l00518"></a>00518 <a class="code" href="classfunction2D__tripleProduct.html">function2D_tripleProduct&lt;matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data&lt;dataType,6,4&gt;</a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,6&gt;</a> &gt; pointDeeMatrix;
  602. <a name="l00519"></a>00519 <a class="code" href="classnested2D.html">nested2D&lt;matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; innerFuncDeeMatrix;
  603. <a name="l00520"></a>00520 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss&lt;matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; innerDeeMatrixInt;
  604. <a name="l00521"></a>00521 <a class="code" href="classintegralFunction.html">integralFunction&lt;matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; outerFuncDeeMatrix;
  605. <a name="l00522"></a>00522 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss&lt;matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; outerDeeMatrixInt;
  606. <a name="l00523"></a>00523
  607. <a name="l00524"></a>00524 <span class="comment">// these are the objects for H</span>
  608. <a name="l00525"></a>00525 <a class="code" href="classfunction2D__doubleProduct.html">function2D_doubleProduct&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> &gt; pointHMatrix;
  609. <a name="l00526"></a>00526 <a class="code" href="classnested2D.html">nested2D&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; innerFuncHMatrix;
  610. <a name="l00527"></a>00527 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; innerHMatrixInt;
  611. <a name="l00528"></a>00528 <a class="code" href="classintegralFunction.html">integralFunction&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; outerFuncHMatrix;
  612. <a name="l00529"></a>00529 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss&lt;matrixRdWtSz_Data&lt;dataType&gt;</a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; outerHMatrixInt;
  613. <a name="l00530"></a>00530
  614. <a name="l00531"></a>00531 <span class="comment">// these are the objects for Psi</span>
  615. <a name="l00532"></a>00532 <span class="comment">// function2D_doubleProduct&lt;matrixRdWtSz_Data&lt;dataType&gt;,dataType,matrixRdWtSz_Data&lt;dataType&gt; &gt; pointPsiMatrix;</span>
  616. <a name="l00533"></a>00533 <span class="comment">// nested2D&lt;matrixRdWtSz_Data&lt;dataType&gt;,dataType&gt; innerFuncPsiMatrix;</span>
  617. <a name="l00534"></a>00534 <span class="comment">// isoIntegral_gauss&lt;matrixRdWtSz_Data&lt;dataType&gt;,dataType&gt; innerPsiMatrixInt;</span>
  618. <a name="l00535"></a>00535 <span class="comment">// integralFunction&lt;matrixRdWtSz_Data&lt;dataType&gt;,dataType&gt; outerFuncPsiMatrix;</span>
  619. <a name="l00536"></a>00536 <span class="comment">// isoIntegral_gauss&lt;matrixRdWtSz_Data&lt;dataType&gt;,dataType&gt; outerPsiMatrixInt;</span>
  620. <a name="l00537"></a>00537
  621. <a name="l00538"></a>00538 <span class="comment">// these are the objects for shape function integral</span>
  622. <a name="l00539"></a>00539 <span class="comment">// nested2D&lt;matrixRdWtSz_Data&lt;dataType&gt;,dataType&gt; innerFuncShape;</span>
  623. <a name="l00540"></a>00540 <span class="comment">// isoIntegral_gauss&lt;matrixRdWtSz_Data&lt;dataType&gt;,dataType&gt; innerShapeInt;</span>
  624. <a name="l00541"></a>00541 <span class="comment">// integralFunction&lt;matrixRdWtSz_Data&lt;dataType&gt;,dataType&gt; outerFuncShape;</span>
  625. <a name="l00542"></a>00542 <span class="comment">// isoIntegral_gauss&lt;matrixRdWtSz_Data&lt;dataType&gt;,dataType&gt; outerShapeInt;</span>
  626. <a name="l00543"></a>00543
  627. <a name="l00545"></a>00545 <span class="comment">// these are the output objects</span>
  628. <a name="l00547"></a>00547 <span class="comment"></span>
  629. <a name="l00548"></a>00548 <a class="code" href="classmatrixRdWt.html">matrixRdWt&lt;dataType&gt;</a>* EMatrix;
  630. <a name="l00549"></a>00549 <a class="code" href="classmatrixRdWt.html">matrixRdWt&lt;dataType&gt;</a>* DaeMatrix;
  631. <a name="l00550"></a>00550 <a class="code" href="classmatrixRdWt.html">matrixRdWt&lt;dataType&gt;</a>* DeeMatrix;
  632. <a name="l00551"></a>00551 <a class="code" href="classmatrixRdWt.html">matrixRdWt&lt;dataType&gt;</a>* HMatrix;
  633. <a name="l00552"></a>00552 <span class="comment">// matrixRdWt&lt;dataType&gt;* PsiMatrix;</span>
  634. <a name="l00553"></a>00553
  635. <a name="l00554"></a>00554 <span class="keywordtype">bool</span> deleteEMatrix;
  636. <a name="l00555"></a>00555 <span class="keywordtype">bool</span> deleteDaeMatrix;
  637. <a name="l00556"></a>00556 <span class="keywordtype">bool</span> deleteDeeMatrix;
  638. <a name="l00557"></a>00557 <span class="keywordtype">bool</span> deleteHMatrix;
  639. <a name="l00558"></a>00558 <span class="comment">// bool deletePsiMatrix;</span>
  640. <a name="l00559"></a>00559
  641. <a name="l00561"></a>00561 <span class="comment">// these are the post-processing objects</span>
  642. <a name="l00563"></a>00563 <span class="comment"></span>
  643. <a name="l00564"></a>00564 <span class="comment">// isoFunction2D&lt;matrixRdWtStatic_Data&lt;dataType,3,4&gt;,dataType,matrixStatic&lt;dataType,3,4&gt; &gt; warpFunc;</span>
  644. <a name="l00565"></a>00565
  645. <a name="l00566"></a>00566 <span class="keywordtype">void</span> buildObjects()
  646. <a name="l00567"></a>00567 {
  647. <a name="l00568"></a>00568 <span class="comment">// set the points for the location function</span>
  648. <a name="l00569"></a>00569 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  649. <a name="l00570"></a>00570 {
  650. <a name="l00571"></a>00571 xFunc.<a class="code" href="classisoFunction2D.html#a8b9cb87d6fb5306d1e0350a243dcf3a1">addPoint</a>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>,&amp;shp2D[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>],&amp;(nds[i]-&gt;x()));
  651. <a name="l00572"></a>00572 yFunc.<a class="code" href="classisoFunction2D.html#a8b9cb87d6fb5306d1e0350a243dcf3a1">addPoint</a>(i,&amp;shp2D[i],&amp;(nds[i]-&gt;y()));
  652. <a name="l00573"></a>00573 hFunc.<a class="code" href="classisoFunction2D.html#a8b9cb87d6fb5306d1e0350a243dcf3a1">addPoint</a>(i,&amp;shp2D[i],&amp;(nds[i]-&gt;h()));
  653. <a name="l00574"></a>00574 angFunc.<a class="code" href="classisoFunction2D.html#a8b9cb87d6fb5306d1e0350a243dcf3a1">addPoint</a>(i,&amp;shp2D[i],&amp;(nds[i]-&gt;plyAngle()));
  654. <a name="l00575"></a>00575 <span class="comment">// warpFunc.addPoint(i,&amp;shp2D[i],&amp;(nds[i]-&gt;warping()));</span>
  655. <a name="l00576"></a>00576 shpGrad[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setSource(&amp;shp2D[i],&amp;xFunc,&amp;yFunc);
  656. <a name="l00577"></a>00577 }
  657. <a name="l00578"></a>00578 objectsSet=<span class="keyword">true</span>;
  658. <a name="l00579"></a>00579 outerFuncEMatrix.<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&amp;innerFuncEMatrix).<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&amp;innerJac);
  659. <a name="l00580"></a>00580 outerFuncDaeMatrix.<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&amp;innerFuncDaeMatrix).<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&amp;innerJac);
  660. <a name="l00581"></a>00581 outerFuncDeeMatrix.<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&amp;innerFuncDeeMatrix).<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&amp;innerJac);
  661. <a name="l00582"></a>00582 outerFuncHMatrix.<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&amp;innerFuncHMatrix).<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&amp;innerJac);
  662. <a name="l00583"></a>00583 <span class="comment">// outerFuncPsiMatrix.addFunction(&amp;innerFuncPsiMatrix).addFunction(&amp;innerJac);</span>
  663. <a name="l00584"></a>00584 <span class="comment">// outerFuncShape.addFunction(&amp;innerFuncShape).addFunction(&amp;innerJac);</span>
  664. <a name="l00585"></a>00585 }
  665. <a name="l00586"></a>00586
  666. <a name="l00587"></a>00587 <span class="keyword">public</span>:
  667. <a name="l00588"></a>00588
  668. <a name="l00589"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#a544cb1af671d2c3b01578c0c77cf1bb2">00589</a> <a class="code" href="classVABS1__MatrixSource__Quad.html#a544cb1af671d2c3b01578c0c77cf1bb2">VABS1_MatrixSource_Quad</a>(<a class="code" href="classconstituitive.html">constituitive&lt;dataType&gt;</a>* matl_in=NULL) :
  669. <a name="l00590"></a>00590 <span class="comment">// state data</span>
  670. <a name="l00591"></a>00591 nds(4,NULL) , matl(matl_in) , objectsSet(false)
  671. <a name="l00592"></a>00592 <span class="comment">// domain objects</span>
  672. <a name="l00593"></a>00593 , shp1D(2) , shp2D(4) , shpGrad(4) , xFunc(4) , yFunc(4) , jac2D(&amp;xFunc,&amp;yFunc) , innerJac(&amp;jac2D) , outerJac(1.0)
  673. <a name="l00594"></a>00594 <span class="comment">// material objects</span>
  674. <a name="l00595"></a>00595 , hFunc(4) , angFunc(4) , matlFunc(matl_in,&amp;hFunc,&amp;angFunc)
  675. <a name="l00596"></a>00596 <span class="comment">// These are the Gamma and Shape matrices</span>
  676. <a name="l00597"></a>00597 , Gamma_a(&amp;shpGrad) , Gamma_e(&amp;xFunc,&amp;yFunc) , shapeDiag(&amp;shpGrad) <span class="comment">// , vabsNull(&amp;xFunc,&amp;yFunc)</span>
  677. <a name="l00598"></a>00598 <span class="comment">// E matrix objects</span>
  678. <a name="l00599"></a>00599 , pointEMatrix(&amp;Gamma_a,&amp;matlFunc,&amp;Gamma_a)
  679. <a name="l00600"></a>00600 , innerFuncEMatrix(&amp;pointEMatrix) , innerEMatrixInt(&amp;innerFuncEMatrix,&amp;innerJac,2)
  680. <a name="l00601"></a>00601 , outerFuncEMatrix(&amp;innerEMatrixInt) , outerEMatrixInt(&amp;outerFuncEMatrix,&amp;outerJac,2)
  681. <a name="l00602"></a>00602 <span class="comment">// Dae matrix objects</span>
  682. <a name="l00603"></a>00603 , pointDaeMatrix(&amp;Gamma_a,&amp;matlFunc,&amp;Gamma_e)
  683. <a name="l00604"></a>00604 , innerFuncDaeMatrix(&amp;pointDaeMatrix) , innerDaeMatrixInt(&amp;innerFuncDaeMatrix,&amp;innerJac,2)
  684. <a name="l00605"></a>00605 , outerFuncDaeMatrix(&amp;innerDaeMatrixInt) , outerDaeMatrixInt(&amp;outerFuncDaeMatrix,&amp;outerJac,2)
  685. <a name="l00606"></a>00606 <span class="comment">// Dee matrix objects</span>
  686. <a name="l00607"></a>00607 , pointDeeMatrix(&amp;Gamma_e,&amp;matlFunc,&amp;Gamma_e)
  687. <a name="l00608"></a>00608 , innerFuncDeeMatrix(&amp;pointDeeMatrix) , innerDeeMatrixInt(&amp;innerFuncDeeMatrix,&amp;innerJac,2)
  688. <a name="l00609"></a>00609 , outerFuncDeeMatrix(&amp;innerDeeMatrixInt) , outerDeeMatrixInt(&amp;outerFuncDeeMatrix,&amp;outerJac,2)
  689. <a name="l00610"></a>00610 <span class="comment">// H matrix objects</span>
  690. <a name="l00611"></a>00611 , pointHMatrix(&amp;shapeDiag,&amp;shapeDiag)
  691. <a name="l00612"></a>00612 , innerFuncHMatrix(&amp;pointHMatrix) , innerHMatrixInt(&amp;innerFuncHMatrix,&amp;innerJac,2)
  692. <a name="l00613"></a>00613 , outerFuncHMatrix(&amp;innerHMatrixInt) , outerHMatrixInt(&amp;outerFuncHMatrix,&amp;outerJac,2)
  693. <a name="l00614"></a>00614 <span class="comment">// // Psi matrix objects</span>
  694. <a name="l00615"></a>00615 <span class="comment">// , pointPsiMatrix(&amp;shapeDiag,&amp;vabsNull)</span>
  695. <a name="l00616"></a>00616 <span class="comment">// , innerFuncPsiMatrix(&amp;pointPsiMatrix) , innerPsiMatrixInt(&amp;innerFuncPsiMatrix,&amp;innerJac,2)</span>
  696. <a name="l00617"></a>00617 <span class="comment">// , outerFuncPsiMatrix(&amp;innerPsiMatrixInt) , outerPsiMatrixInt(&amp;outerFuncPsiMatrix,&amp;outerJac,2)</span>
  697. <a name="l00618"></a>00618 <span class="comment">// These are the output variables</span>
  698. <a name="l00619"></a>00619 , EMatrix(NULL) , DaeMatrix(NULL) , DeeMatrix(NULL) , HMatrix(NULL) <span class="comment">// , PsiMatrix(NULL)</span>
  699. <a name="l00620"></a>00620 , deleteEMatrix(false) , deleteDaeMatrix(false) , deleteDeeMatrix(false) , deleteHMatrix(false) <span class="comment">// , deletePsiMatrix(false)</span>
  700. <a name="l00621"></a>00621 {
  701. <a name="l00622"></a>00622 std::vector&lt;dataType&gt; locs(2,0.0);
  702. <a name="l00623"></a>00623 locs[0]=-1.0;
  703. <a name="l00624"></a>00624 locs[1]=1.0;
  704. <a name="l00625"></a>00625 shp1D[0].setCoeff(0,locs);
  705. <a name="l00626"></a>00626 shp1D[1].setCoeff(1,locs);
  706. <a name="l00627"></a>00627 shp2D[0].setLeft(&amp;shp1D[0]).setRight(&amp;shp1D[0]);
  707. <a name="l00628"></a>00628 shp2D[1].setLeft(&amp;shp1D[1]).setRight(&amp;shp1D[0]);
  708. <a name="l00629"></a>00629 shp2D[2].setLeft(&amp;shp1D[1]).setRight(&amp;shp1D[1]);
  709. <a name="l00630"></a>00630 shp2D[3].setLeft(&amp;shp1D[0]).setRight(&amp;shp1D[1]);
  710. <a name="l00631"></a>00631 }
  711. <a name="l00632"></a>00632
  712. <a name="l00633"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#a7bbae7342d6cc51b6f10a74776f0f997">00633</a> <a class="code" href="classVABS1__MatrixSource__Quad.html#a544cb1af671d2c3b01578c0c77cf1bb2">VABS1_MatrixSource_Quad</a>(<span class="keyword">const</span> <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad</a>&amp; asg) :
  713. <a name="l00634"></a>00634 <span class="comment">// state data</span>
  714. <a name="l00635"></a>00635 nds(4,NULL) , matl(asg.matl) , objectsSet(false)
  715. <a name="l00636"></a>00636 <span class="comment">// domain objects</span>
  716. <a name="l00637"></a>00637 , shp1D(2) , shp2D(4) , shpGrad(4) , xFunc(4) , yFunc(4) , jac2D(&amp;xFunc,&amp;yFunc) , innerJac(&amp;jac2D) , outerJac(1.0)
  717. <a name="l00638"></a>00638 <span class="comment">// material objects</span>
  718. <a name="l00639"></a>00639 , hFunc(4) , angFunc(4) , matlFunc(matl,&amp;hFunc,&amp;angFunc)
  719. <a name="l00640"></a>00640 <span class="comment">// These are the Gamma and Shape matrices</span>
  720. <a name="l00641"></a>00641 , Gamma_a(&amp;shpGrad) , Gamma_e(&amp;xFunc,&amp;yFunc) , shapeDiag(&amp;shpGrad) <span class="comment">// , vabsNull(&amp;xFunc,&amp;yFunc)</span>
  721. <a name="l00642"></a>00642 <span class="comment">// E matrix objects</span>
  722. <a name="l00643"></a>00643 , pointEMatrix(&amp;Gamma_a,&amp;matlFunc,&amp;Gamma_a)
  723. <a name="l00644"></a>00644 , innerFuncEMatrix(&amp;pointEMatrix) , innerEMatrixInt(&amp;innerFuncEMatrix,&amp;innerJac,2)
  724. <a name="l00645"></a>00645 , outerFuncEMatrix(&amp;innerEMatrixInt) , outerEMatrixInt(&amp;outerFuncEMatrix,&amp;outerJac,2)
  725. <a name="l00646"></a>00646 <span class="comment">// Dae matrix objects</span>
  726. <a name="l00647"></a>00647 , pointDaeMatrix(&amp;Gamma_a,&amp;matlFunc,&amp;Gamma_e)
  727. <a name="l00648"></a>00648 , innerFuncDaeMatrix(&amp;pointDaeMatrix) , innerDaeMatrixInt(&amp;innerFuncDaeMatrix,&amp;innerJac,2)
  728. <a name="l00649"></a>00649 , outerFuncDaeMatrix(&amp;innerDaeMatrixInt) , outerDaeMatrixInt(&amp;outerFuncDaeMatrix,&amp;outerJac,2)
  729. <a name="l00650"></a>00650 <span class="comment">// Dee matrix objects</span>
  730. <a name="l00651"></a>00651 , pointDeeMatrix(&amp;Gamma_e,&amp;matlFunc,&amp;Gamma_e)
  731. <a name="l00652"></a>00652 , innerFuncDeeMatrix(&amp;pointDeeMatrix) , innerDeeMatrixInt(&amp;innerFuncDeeMatrix,&amp;innerJac,2)
  732. <a name="l00653"></a>00653 , outerFuncDeeMatrix(&amp;innerDeeMatrixInt) , outerDeeMatrixInt(&amp;outerFuncDeeMatrix,&amp;outerJac,2)
  733. <a name="l00654"></a>00654 <span class="comment">// H matrix objects</span>
  734. <a name="l00655"></a>00655 , pointHMatrix(&amp;shapeDiag,&amp;shapeDiag)
  735. <a name="l00656"></a>00656 , innerFuncHMatrix(&amp;pointHMatrix) , innerHMatrixInt(&amp;innerFuncHMatrix,&amp;innerJac,2)
  736. <a name="l00657"></a>00657 , outerFuncHMatrix(&amp;innerHMatrixInt) , outerHMatrixInt(&amp;outerFuncHMatrix,&amp;outerJac,2)
  737. <a name="l00658"></a>00658 <span class="comment">// // Psi matrix objects</span>
  738. <a name="l00659"></a>00659 <span class="comment">// , pointPsiMatrix(&amp;shapeDiag,&amp;vabsNull)</span>
  739. <a name="l00660"></a>00660 <span class="comment">// , innerFuncPsiMatrix(&amp;pointPsiMatrix) , innerPsiMatrixInt(&amp;innerFuncPsiMatrix,&amp;innerJac,2)</span>
  740. <a name="l00661"></a>00661 <span class="comment">// , outerFuncPsiMatrix(&amp;innerPsiMatrixInt) , outerPsiMatrixInt(&amp;outerFuncPsiMatrix,&amp;outerJac,2)</span>
  741. <a name="l00662"></a>00662 <span class="comment">// These are the output variables</span>
  742. <a name="l00663"></a>00663 , EMatrix(NULL) , DaeMatrix(NULL) , DeeMatrix(NULL) , HMatrix(NULL) <span class="comment">// , PsiMatrix(NULL)</span>
  743. <a name="l00664"></a>00664 , deleteEMatrix(false) , deleteDaeMatrix(false) , deleteDeeMatrix(false) , deleteHMatrix(false) <span class="comment">// , deletePsiMatrix(false)</span>
  744. <a name="l00665"></a>00665 <span class="comment">// now lets initialize the interpolation of the warping</span>
  745. <a name="l00666"></a>00666 <span class="comment">// , warpFunc(4)</span>
  746. <a name="l00667"></a>00667 {
  747. <a name="l00668"></a>00668 std::vector&lt;dataType&gt; locs(2,0.0);
  748. <a name="l00669"></a>00669 locs[0]=-1.0;
  749. <a name="l00670"></a>00670 locs[1]=1.0;
  750. <a name="l00671"></a>00671 shp1D[0].setCoeff(0,locs);
  751. <a name="l00672"></a>00672 shp1D[1].setCoeff(1,locs);
  752. <a name="l00673"></a>00673 shp2D[0].setLeft(&amp;shp1D[0]).setRight(&amp;shp1D[0]);
  753. <a name="l00674"></a>00674 shp2D[1].setLeft(&amp;shp1D[1]).setRight(&amp;shp1D[0]);
  754. <a name="l00675"></a>00675 shp2D[2].setLeft(&amp;shp1D[1]).setRight(&amp;shp1D[1]);
  755. <a name="l00676"></a>00676 shp2D[3].setLeft(&amp;shp1D[0]).setRight(&amp;shp1D[1]);
  756. <a name="l00677"></a>00677 }
  757. <a name="l00678"></a>00678
  758. <a name="l00679"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#a5738e91e021f553e4a6bc46a84f2e55e">00679</a> <span class="keyword">virtual</span> <a class="code" href="classVABS1__MatrixSource__Quad.html#a5738e91e021f553e4a6bc46a84f2e55e">~VABS1_MatrixSource_Quad</a>()
  759. <a name="l00680"></a>00680 {
  760. <a name="l00681"></a>00681 <span class="keywordflow">if</span>(EMatrix!=NULL &amp;&amp; deleteEMatrix)
  761. <a name="l00682"></a>00682 <span class="keyword">delete</span> EMatrix;
  762. <a name="l00683"></a>00683 <span class="keywordflow">if</span>(DaeMatrix!=NULL &amp;&amp; deleteDaeMatrix)
  763. <a name="l00684"></a>00684 <span class="keyword">delete</span> DaeMatrix;
  764. <a name="l00685"></a>00685 <span class="keywordflow">if</span>(DeeMatrix!=NULL &amp;&amp; deleteDeeMatrix)
  765. <a name="l00686"></a>00686 <span class="keyword">delete</span> DeeMatrix;
  766. <a name="l00687"></a>00687 <span class="keywordflow">if</span>(HMatrix!=NULL &amp;&amp; deleteHMatrix)
  767. <a name="l00688"></a>00688 <span class="keyword">delete</span> HMatrix;
  768. <a name="l00689"></a>00689 }
  769. <a name="l00690"></a>00690
  770. <a name="l00691"></a>00691 <span class="comment">// Initialization </span>
  771. <a name="l00692"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#a320316257b0972b60d6c5cb5082c19ff">00692</a> <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad&lt;dataType&gt;</a>&amp; <a class="code" href="classVABS1__MatrixSource__Quad.html#a320316257b0972b60d6c5cb5082c19ff">setNode</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at,<a class="code" href="classVABSNode.html">VABSNode&lt;dataType&gt;</a>* nd_in)
  772. <a name="l00693"></a>00693 {
  773. <a name="l00694"></a>00694 nds[at]=nd_in;
  774. <a name="l00695"></a>00695 objectsSet=<span class="keyword">false</span>;
  775. <a name="l00696"></a>00696 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  776. <a name="l00697"></a>00697 }
  777. <a name="l00698"></a>00698
  778. <a name="l00699"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#a043d5e9c8c948a17bba496acef3e6226">00699</a> <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad&lt;dataType&gt;</a>&amp; <a class="code" href="classVABS1__MatrixSource__Quad.html#a043d5e9c8c948a17bba496acef3e6226">setMatl</a>(<a class="code" href="classconstituitive.html">constituitive&lt;dataType&gt;</a>* matl_in)
  779. <a name="l00700"></a>00700 {
  780. <a name="l00701"></a>00701 matl=matl_in;
  781. <a name="l00702"></a>00702 matlFunc.setMaterial(matl);
  782. <a name="l00703"></a>00703 objectsSet=<span class="keyword">false</span>;
  783. <a name="l00704"></a>00704 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  784. <a name="l00705"></a>00705 }
  785. <a name="l00706"></a>00706
  786. <a name="l00707"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#aeef4a1682902d10018e2b76103edde2b">00707</a> <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad</a>&amp; <a class="code" href="classVABS1__MatrixSource__Quad.html#aeef4a1682902d10018e2b76103edde2b">setEMatrix</a>(<a class="code" href="classmatrixRdWt.html">matrixRdWt&lt;dataType&gt;</a>* EMatrix_in,<span class="keywordtype">bool</span> deleteEMatrix_in=<span class="keyword">false</span>)
  787. <a name="l00708"></a>00708 {
  788. <a name="l00709"></a>00709 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
  789. <a name="l00710"></a>00710 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
  790. <a name="l00711"></a>00711 EMatrix_in-&gt;<a class="code" href="classmatrix.html#a3a26f3543df8cff3e662e949e8b9234d">size</a>(rCnt,cCnt);
  791. <a name="l00712"></a>00712 <span class="keywordflow">if</span>(rCnt!=nds.size()*3 || cCnt!=nds.size()*3)
  792. <a name="l00713"></a>00713 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::setEMatrix(): The output matrix supplied does not have the correct dimensions&quot;</span>);
  793. <a name="l00714"></a>00714 <span class="keywordflow">if</span>(EMatrix!=NULL &amp;&amp; EMatrix!=EMatrix_in &amp;&amp; deleteEMatrix)
  794. <a name="l00715"></a>00715 <span class="keyword">delete</span> EMatrix;
  795. <a name="l00716"></a>00716 EMatrix=EMatrix_in;
  796. <a name="l00717"></a>00717 deleteEMatrix=deleteEMatrix_in;
  797. <a name="l00718"></a>00718 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  798. <a name="l00719"></a>00719 }
  799. <a name="l00720"></a>00720
  800. <a name="l00721"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#a9ed02f112bf1b4f64cd1930c4a09a306">00721</a> <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad</a>&amp; <a class="code" href="classVABS1__MatrixSource__Quad.html#a9ed02f112bf1b4f64cd1930c4a09a306">setDeaMatrix</a>(<a class="code" href="classmatrixRdWt.html">matrixRdWt&lt;dataType&gt;</a>* DaeMatrix_in,<span class="keywordtype">bool</span> deleteDaeMatrix_in=<span class="keyword">false</span>)
  801. <a name="l00722"></a>00722 {
  802. <a name="l00723"></a>00723 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
  803. <a name="l00724"></a>00724 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
  804. <a name="l00725"></a>00725 DaeMatrix_in-&gt;<a class="code" href="classmatrix.html#a3a26f3543df8cff3e662e949e8b9234d">size</a>(rCnt,cCnt);
  805. <a name="l00726"></a>00726 <span class="keywordflow">if</span>(rCnt!=nds.size()*3 || cCnt!=4)
  806. <a name="l00727"></a>00727 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::setDeaMatrix(): The output matrix supplied does not have the correct dimensions&quot;</span>);
  807. <a name="l00728"></a>00728 <span class="keywordflow">if</span>(DaeMatrix!=NULL &amp;&amp; DaeMatrix!=DaeMatrix_in &amp;&amp; deleteDaeMatrix)
  808. <a name="l00729"></a>00729 <span class="keyword">delete</span> DaeMatrix;
  809. <a name="l00730"></a>00730 DaeMatrix=DaeMatrix_in;
  810. <a name="l00731"></a>00731 deleteDaeMatrix=deleteDaeMatrix_in;
  811. <a name="l00732"></a>00732 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  812. <a name="l00733"></a>00733 }
  813. <a name="l00734"></a>00734
  814. <a name="l00735"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#a35d2eaa4a501b4b4f34178282d2272eb">00735</a> <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad</a>&amp; <a class="code" href="classVABS1__MatrixSource__Quad.html#a35d2eaa4a501b4b4f34178282d2272eb">setDeeMatrix</a>(<a class="code" href="classmatrixRdWt.html">matrixRdWt&lt;dataType&gt;</a>* DeeMatrix_in,<span class="keywordtype">bool</span> deleteDeeMatrix_in=<span class="keyword">false</span>)
  815. <a name="l00736"></a>00736 {
  816. <a name="l00737"></a>00737 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
  817. <a name="l00738"></a>00738 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
  818. <a name="l00739"></a>00739 DeeMatrix_in-&gt;<a class="code" href="classmatrix.html#a3a26f3543df8cff3e662e949e8b9234d">size</a>(rCnt,cCnt);
  819. <a name="l00740"></a>00740 <span class="keywordflow">if</span>(rCnt!=4 || cCnt!=4)
  820. <a name="l00741"></a>00741 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::setDeeMatrix(): The output matrix supplied does not have the correct dimensions&quot;</span>);
  821. <a name="l00742"></a>00742 <span class="keywordflow">if</span>(DeeMatrix!=NULL &amp;&amp; DeeMatrix!=DeeMatrix_in &amp;&amp; deleteDeeMatrix)
  822. <a name="l00743"></a>00743 <span class="keyword">delete</span> DeeMatrix;
  823. <a name="l00744"></a>00744 DeeMatrix=DeeMatrix_in;
  824. <a name="l00745"></a>00745 deleteDeeMatrix=deleteDeeMatrix_in;
  825. <a name="l00746"></a>00746 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  826. <a name="l00747"></a>00747 }
  827. <a name="l00748"></a>00748
  828. <a name="l00749"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#a888d3cd82ba39342e6cb06614457abb5">00749</a> <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad</a>&amp; <a class="code" href="classVABS1__MatrixSource__Quad.html#a888d3cd82ba39342e6cb06614457abb5">setHMatrix</a>(<a class="code" href="classmatrixRdWt.html">matrixRdWt&lt;dataType&gt;</a>* HMatrix_in,<span class="keywordtype">bool</span> deleteHMatrix_in=<span class="keyword">false</span>)
  829. <a name="l00750"></a>00750 {
  830. <a name="l00751"></a>00751 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
  831. <a name="l00752"></a>00752 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
  832. <a name="l00753"></a>00753 HMatrix_in-&gt;<a class="code" href="classmatrix.html#a3a26f3543df8cff3e662e949e8b9234d">size</a>(rCnt,cCnt);
  833. <a name="l00754"></a>00754 <span class="keywordflow">if</span>(rCnt!=nds.size()*3 || cCnt!=nds.size()*3)
  834. <a name="l00755"></a>00755 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::setHMatrix(): The output matrix supplied does not have the correct dimensions&quot;</span>);
  835. <a name="l00756"></a>00756 <span class="keywordflow">if</span>(HMatrix!=NULL &amp;&amp; HMatrix!=HMatrix_in &amp;&amp; deleteHMatrix)
  836. <a name="l00757"></a>00757 <span class="keyword">delete</span> HMatrix;
  837. <a name="l00758"></a>00758 HMatrix=HMatrix_in;
  838. <a name="l00759"></a>00759 deleteHMatrix=deleteHMatrix_in;
  839. <a name="l00760"></a>00760 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  840. <a name="l00761"></a>00761 }
  841. <a name="l00762"></a>00762
  842. <a name="l00763"></a>00763 <span class="comment">// VABS1_MatrixSource_Quad&amp; setPsiMatrix(matrixRdWt&lt;dataType&gt;* PsiMatrix_in,bool deletePsiMatrix_in=false)</span>
  843. <a name="l00764"></a>00764 <span class="comment">// {</span>
  844. <a name="l00765"></a>00765 <span class="comment">// unsigned long rCnt;</span>
  845. <a name="l00766"></a>00766 <span class="comment">// unsigned long cCnt;</span>
  846. <a name="l00767"></a>00767 <span class="comment">// PsiMatrix_in-&gt;size(rCnt,cCnt);</span>
  847. <a name="l00768"></a>00768 <span class="comment">// if(rCnt!=nds.size()*3 || cCnt!=4)</span>
  848. <a name="l00769"></a>00769 <span class="comment">// throw eMsg(&quot;VABS1_MatrixSource_Quad::setPsiMatrix(): The output matrix supplied does not have the correct dimensions&quot;);</span>
  849. <a name="l00770"></a>00770 <span class="comment">// if(PsiMatrix!=NULL &amp;&amp; PsiMatrix!=PsiMatrix_in &amp;&amp; deletePsiMatrix)</span>
  850. <a name="l00771"></a>00771 <span class="comment">// delete PsiMatrix;</span>
  851. <a name="l00772"></a>00772 <span class="comment">// PsiMatrix=PsiMatrix_in;</span>
  852. <a name="l00773"></a>00773 <span class="comment">// deletePsiMatrix=deletePsiMatrix_in;</span>
  853. <a name="l00774"></a>00774 <span class="comment">// return *this;</span>
  854. <a name="l00775"></a>00775 <span class="comment">// }</span>
  855. <a name="l00776"></a>00776
  856. <a name="l00777"></a>00777 <span class="comment">// output functions:</span>
  857. <a name="l00778"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#a9f0ac960d526ae0c8b6361c780fb40ff">00778</a> <span class="keywordtype">void</span> <a class="code" href="classVABS1__MatrixSource__Quad.html#a9f0ac960d526ae0c8b6361c780fb40ff">addE</a>()
  858. <a name="l00779"></a>00779 {
  859. <a name="l00780"></a>00780 <span class="keywordflow">if</span>(!objectsSet)
  860. <a name="l00781"></a>00781 buildObjects();
  861. <a name="l00782"></a>00782 <span class="keywordflow">if</span>(EMatrix==NULL)
  862. <a name="l00783"></a>00783 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::addE(): The E matrix has not been set&quot;</span>);
  863. <a name="l00784"></a>00784 *EMatrix+=outerEMatrixInt.<a class="code" href="classisoIntegral__gauss.html#a74c899ddc289b4b134cc3cca69213621">getValue</a>();
  864. <a name="l00785"></a>00785 }
  865. <a name="l00786"></a>00786
  866. <a name="l00787"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#ae2f7561474829ae05be95cafc9185861">00787</a> <span class="keywordtype">void</span> <a class="code" href="classVABS1__MatrixSource__Quad.html#ae2f7561474829ae05be95cafc9185861">addDee</a>()
  867. <a name="l00788"></a>00788 {
  868. <a name="l00789"></a>00789 <span class="keywordflow">if</span>(!objectsSet)
  869. <a name="l00790"></a>00790 buildObjects();
  870. <a name="l00791"></a>00791 <span class="keywordflow">if</span>(DaeMatrix==NULL)
  871. <a name="l00792"></a>00792 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::addDee(): The Dee matrix has not been set&quot;</span>);
  872. <a name="l00793"></a>00793 *DaeMatrix+=outerDaeMatrixInt.<a class="code" href="classisoIntegral__gauss.html#a74c899ddc289b4b134cc3cca69213621">getValue</a>();
  873. <a name="l00794"></a>00794 }
  874. <a name="l00795"></a>00795
  875. <a name="l00796"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#ad6ab3f5761962158bbb83d6d7402f831">00796</a> <span class="keywordtype">void</span> <a class="code" href="classVABS1__MatrixSource__Quad.html#ad6ab3f5761962158bbb83d6d7402f831">addDae</a>()
  876. <a name="l00797"></a>00797 {
  877. <a name="l00798"></a>00798 <span class="keywordflow">if</span>(!objectsSet)
  878. <a name="l00799"></a>00799 buildObjects();
  879. <a name="l00800"></a>00800 <span class="keywordflow">if</span>(DeeMatrix==NULL)
  880. <a name="l00801"></a>00801 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::addDae(): The Dae matrix has not been set&quot;</span>);
  881. <a name="l00802"></a>00802 *DeeMatrix+=outerDeeMatrixInt.<a class="code" href="classisoIntegral__gauss.html#a74c899ddc289b4b134cc3cca69213621">getValue</a>();
  882. <a name="l00803"></a>00803 }
  883. <a name="l00804"></a>00804
  884. <a name="l00805"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#aa874d74ee39683992eab3382e7b894f9">00805</a> <span class="keywordtype">void</span> <a class="code" href="classVABS1__MatrixSource__Quad.html#aa874d74ee39683992eab3382e7b894f9">addH</a>()
  885. <a name="l00806"></a>00806 {
  886. <a name="l00807"></a>00807 <span class="keywordflow">if</span>(!objectsSet)
  887. <a name="l00808"></a>00808 buildObjects();
  888. <a name="l00809"></a>00809 <span class="keywordflow">if</span>(HMatrix==NULL)
  889. <a name="l00810"></a>00810 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::addH(): The H matrix has not been set&quot;</span>);
  890. <a name="l00811"></a>00811 *HMatrix+=outerHMatrixInt.<a class="code" href="classisoIntegral__gauss.html#a74c899ddc289b4b134cc3cca69213621">getValue</a>();
  891. <a name="l00812"></a>00812 }
  892. <a name="l00813"></a>00813
  893. <a name="l00814"></a>00814 <span class="comment">// void addPsi()</span>
  894. <a name="l00815"></a>00815 <span class="comment">// {</span>
  895. <a name="l00816"></a>00816 <span class="comment">// if(!objectsSet)</span>
  896. <a name="l00817"></a>00817 <span class="comment">// buildObjects();</span>
  897. <a name="l00818"></a>00818 <span class="comment">// if(PsiMatrix==NULL)</span>
  898. <a name="l00819"></a>00819 <span class="comment">// throw eMsg(&quot;VABS1_MatrixSource_Quad::addPsi(): The H matrix has not been set&quot;);</span>
  899. <a name="l00820"></a>00820 <span class="comment">// *PsiMatrix+=outerPsiMatrixInt.getValue();</span>
  900. <a name="l00821"></a>00821 <span class="comment">// }</span>
  901. <a name="l00822"></a>00822
  902. <a name="l00823"></a>00823 <span class="preprocessor">#ifdef SAVE_INTERMEDIATES</span>
  903. <a name="l00824"></a>00824 <span class="preprocessor"></span>
  904. <a name="l00825"></a>00825 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> Gamma_aVal;
  905. <a name="l00826"></a>00826 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> Gamma_eVal;
  906. <a name="l00827"></a>00827 <a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data&lt;dataType,12,4&gt;</a> warpingValues;
  907. <a name="l00828"></a>00828 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data&lt;dataType,6&gt;</a> strain;
  908. <a name="l00829"></a>00829 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data&lt;dataType,4&gt;</a> beamStrainValues;
  909. <a name="l00830"></a>00830 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> myFail;
  910. <a name="l00831"></a>00831
  911. <a name="l00832"></a>00832 <span class="comment">// retrieves the stress and an arbitrary s and t location. In general s and t are bounded by -1 and 1</span>
  912. <a name="l00833"></a>00833 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABS1__MatrixSource__Quad.html#a1981d1f007330b8bf9525f78922a51d2">fail</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="namespaceCPPL.html#ab544de2e0cfe3ab6180d91ac5febff72">t</a>,<span class="keyword">const</span> <a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol&lt;dataType,4&gt;</a>&amp; beamStrain)
  913. <a name="l00834"></a>00834 {
  914. <a name="l00835"></a>00835 <span class="keywordflow">if</span>(matl==NULL)
  915. <a name="l00836"></a>00836 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::fail(): The material has not been defined&quot;</span>);
  916. <a name="l00837"></a>00837 <span class="keywordflow">if</span>(s&lt;-1.0 || s&gt;1.0 || t&lt;-1.0 || t&gt;1.0)
  917. <a name="l00838"></a>00838 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::fail(): The element is not defined at the specified location&quot;</span>);
  918. <a name="l00839"></a>00839
  919. <a name="l00840"></a>00840 <span class="comment">// build a vector based on the nodal values</span>
  920. <a name="l00841"></a>00841 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  921. <a name="l00842"></a>00842 {
  922. <a name="l00843"></a>00843 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> r=0;r&lt;3;r++)
  923. <a name="l00844"></a>00844 {
  924. <a name="l00845"></a>00845 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> c=0;c&lt;4;c++)
  925. <a name="l00846"></a>00846 {
  926. <a name="l00847"></a>00847 warpingValues.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+r,c)=nds[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;warping().data().entry(r,c);
  927. <a name="l00848"></a>00848 }
  928. <a name="l00849"></a>00849 }
  929. <a name="l00850"></a>00850 }
  930. <a name="l00851"></a>00851
  931. <a name="l00852"></a>00852 Gamma_aVal=Gamma_a.getValue2D(s,t);
  932. <a name="l00853"></a>00853 Gamma_eVal=Gamma_e.getValue2D(s,t);
  933. <a name="l00854"></a>00854 beamStrainValues=beamStrain;
  934. <a name="l00855"></a>00855 strain=(Gamma_aVal*warpingValues+Gamma_eVal)*beamStrainValues;
  935. <a name="l00856"></a>00856
  936. <a name="l00857"></a>00857 <span class="comment">// if(printStrain)</span>
  937. <a name="l00858"></a>00858 <span class="comment">// {</span>
  938. <a name="l00859"></a>00859 <span class="comment">// std::cout &lt;&lt; &quot;This is the 3-D strain&quot; &lt;&lt; std::endl;</span>
  939. <a name="l00860"></a>00860 <span class="comment">// printMatrix(strain);</span>
  940. <a name="l00861"></a>00861 <span class="comment">// }</span>
  941. <a name="l00862"></a>00862 myFail=matl-&gt;failure(strain,<a class="code" href="classconstituitiveDependent.html">constituitiveDependent&lt;double&gt;</a>(angFunc.<a class="code" href="classisoFunction2D.html#a2e143a4f0b6c806632b90f38e08d09bc">getValue2D</a>(s,t),hFunc.<a class="code" href="classisoFunction2D.html#a2e143a4f0b6c806632b90f38e08d09bc">getValue2D</a>(s,t)));
  942. <a name="l00863"></a>00863
  943. <a name="l00864"></a>00864 <span class="keywordflow">return</span> myFail;
  944. <a name="l00865"></a>00865 }
  945. <a name="l00866"></a>00866
  946. <a name="l00867"></a>00867 <span class="preprocessor">#else</span>
  947. <a name="l00868"></a>00868 <span class="preprocessor"></span>
  948. <a name="l00869"></a>00869 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
  949. <a name="l00870"></a>00870 <span class="preprocessor"></span> <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data&lt;dataType,4&gt;</a> beamStrainValues;
  950. <a name="l00871"></a>00871 <span class="preprocessor">#endif</span>
  951. <a name="l00872"></a>00872 <span class="preprocessor"></span>
  952. <a name="l00873"></a>00873 <span class="comment">// retrieves the stress and an arbitrary s and t location. In general s and t are bounded by -1 and 1</span>
  953. <a name="l00874"></a><a class="code" href="classVABS1__MatrixSource__Quad.html#a1981d1f007330b8bf9525f78922a51d2">00874</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABS1__MatrixSource__Quad.html#a1981d1f007330b8bf9525f78922a51d2">fail</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> t,<span class="keyword">const</span> <a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol&lt;dataType,4&gt;</a>&amp; beamStrain)
  954. <a name="l00875"></a>00875 {
  955. <a name="l00876"></a>00876 <span class="keywordflow">if</span>(matl==NULL)
  956. <a name="l00877"></a>00877 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::fail(): The material has not been defined&quot;</span>);
  957. <a name="l00878"></a>00878 <span class="keywordflow">if</span>(s&lt;-1.0 || s&gt;1.0 || t&lt;-1.0 || t&gt;1.0)
  958. <a name="l00879"></a>00879 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::fail(): The element is not defined at the specified location&quot;</span>);
  959. <a name="l00880"></a>00880
  960. <a name="l00881"></a>00881 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
  961. <a name="l00882"></a>00882 <span class="preprocessor"></span> beamStrainValues=beamStrain;
  962. <a name="l00883"></a>00883 <span class="preprocessor">#endif</span>
  963. <a name="l00884"></a>00884 <span class="preprocessor"></span>
  964. <a name="l00885"></a>00885 <span class="comment">// build a vector based on the nodal values</span>
  965. <a name="l00886"></a>00886 <a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data&lt;dataType,12,4&gt;</a> warpingValues;
  966. <a name="l00887"></a>00887 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  967. <a name="l00888"></a>00888 {
  968. <a name="l00889"></a>00889 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> r=0;r&lt;3;r++)
  969. <a name="l00890"></a>00890 {
  970. <a name="l00891"></a>00891 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> c=0;c&lt;4;c++)
  971. <a name="l00892"></a>00892 {
  972. <a name="l00893"></a>00893 warpingValues.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+r,c)=nds[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;warping().data().entry(r,c);
  973. <a name="l00894"></a>00894 }
  974. <a name="l00895"></a>00895 }
  975. <a name="l00896"></a>00896 }
  976. <a name="l00897"></a>00897
  977. <a name="l00898"></a>00898 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data&lt;dataType,6&gt;</a> strain=((Gamma_a.getValue2D(s,t))*warpingValues+Gamma_e.getValue2D(s,t))*beamStrain;
  978. <a name="l00899"></a>00899
  979. <a name="l00900"></a>00900 <span class="comment">// if(printStrain)</span>
  980. <a name="l00901"></a>00901 <span class="comment">// {</span>
  981. <a name="l00902"></a>00902 <span class="comment">// std::cout &lt;&lt; &quot;This is the 3-D strain&quot; &lt;&lt; std::endl;</span>
  982. <a name="l00903"></a>00903 <span class="comment">// printMatrix(strain);</span>
  983. <a name="l00904"></a>00904 <span class="comment">// }</span>
  984. <a name="l00905"></a>00905
  985. <a name="l00906"></a>00906 <span class="keywordflow">return</span> matl-&gt;failure(strain,<a class="code" href="classconstituitiveDependent.html">constituitiveDependent&lt;double&gt;</a>(angFunc.<a class="code" href="classisoFunction2D.html#a2e143a4f0b6c806632b90f38e08d09bc">getValue2D</a>(s,t),hFunc.<a class="code" href="classisoFunction2D.html#a2e143a4f0b6c806632b90f38e08d09bc">getValue2D</a>(s,t)));
  986. <a name="l00907"></a>00907 }
  987. <a name="l00908"></a>00908
  988. <a name="l00909"></a>00909 <span class="preprocessor">#endif</span>
  989. <a name="l00910"></a>00910 <span class="preprocessor"></span>
  990. <a name="l00911"></a>00911 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
  991. <a name="l00912"></a>00912 <span class="preprocessor"></span>
  992. <a name="l00913"></a>00913 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> getGamma_a(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> t)
  993. <a name="l00914"></a>00914 {
  994. <a name="l00915"></a>00915 <span class="keywordflow">return</span> Gamma_a.getValue2D(s,t);
  995. <a name="l00916"></a>00916 }
  996. <a name="l00917"></a>00917
  997. <a name="l00918"></a>00918 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> getGamma_e(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> t)
  998. <a name="l00919"></a>00919 {
  999. <a name="l00920"></a>00920 <span class="keywordflow">return</span> Gamma_e.getValue2D(s,t);
  1000. <a name="l00921"></a>00921 }
  1001. <a name="l00922"></a>00922
  1002. <a name="l00923"></a>00923 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data&lt;dataType,6&gt;</a> baseStrain(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> t,<span class="keyword">const</span> <a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol&lt;dataType,4&gt;</a>&amp; beamStrain)
  1003. <a name="l00924"></a>00924 {
  1004. <a name="l00925"></a>00925 <span class="keywordflow">if</span>(matl==NULL)
  1005. <a name="l00926"></a>00926 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::fail(): The material has not been defined&quot;</span>);
  1006. <a name="l00927"></a>00927 <span class="keywordflow">if</span>(s&lt;-1.0 || s&gt;1.0 || t&lt;-1.0 || t&gt;1.0)
  1007. <a name="l00928"></a>00928 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_MatrixSource_Quad::fail(): The element is not defined at the specified location&quot;</span>);
  1008. <a name="l00929"></a>00929
  1009. <a name="l00930"></a>00930 <span class="comment">// build a vector based on the nodal values</span>
  1010. <a name="l00931"></a>00931 <a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data&lt;dataType,12,4&gt;</a> warpingValues;
  1011. <a name="l00932"></a>00932 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1012. <a name="l00933"></a>00933 {
  1013. <a name="l00934"></a>00934 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> r=0;r&lt;3;r++)
  1014. <a name="l00935"></a>00935 {
  1015. <a name="l00936"></a>00936 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> c=0;c&lt;4;c++)
  1016. <a name="l00937"></a>00937 {
  1017. <a name="l00938"></a>00938 warpingValues.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+r,c)=nds[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;warping().data().entry(r,c);
  1018. <a name="l00939"></a>00939 }
  1019. <a name="l00940"></a>00940 }
  1020. <a name="l00941"></a>00941 }
  1021. <a name="l00942"></a>00942
  1022. <a name="l00943"></a>00943 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data&lt;dataType,6&gt;</a> strain=((Gamma_a.getValue2D(s,t))*warpingValues+Gamma_e.getValue2D(s,t))*beamStrain;
  1023. <a name="l00944"></a>00944
  1024. <a name="l00945"></a>00945 <span class="keywordflow">return</span> strain;
  1025. <a name="l00946"></a>00946 }
  1026. <a name="l00947"></a>00947
  1027. <a name="l00948"></a>00948 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> matlFail(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> t,<a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data&lt;dataType,6&gt;</a> strain)
  1028. <a name="l00949"></a>00949 {
  1029. <a name="l00950"></a>00950 <span class="keywordflow">return</span> matl-&gt;failure(strain,<a class="code" href="classconstituitiveDependent.html">constituitiveDependent&lt;double&gt;</a>(angFunc.<a class="code" href="classisoFunction2D.html#a2e143a4f0b6c806632b90f38e08d09bc">getValue2D</a>(s,t),hFunc.<a class="code" href="classisoFunction2D.html#a2e143a4f0b6c806632b90f38e08d09bc">getValue2D</a>(s,t)));
  1030. <a name="l00951"></a>00951 }
  1031. <a name="l00952"></a>00952
  1032. <a name="l00953"></a>00953 <span class="preprocessor">#endif</span>
  1033. <a name="l00954"></a>00954 <span class="preprocessor"></span>
  1034. <a name="l00955"></a>00955 };
  1035. <a name="l00956"></a>00956
  1036. <a name="l00957"></a>00957 <span class="comment">// this is a class for collecting failure information...</span>
  1037. <a name="l00958"></a>00958 <span class="comment">// a list is generated that contains all the failure results...</span>
  1038. <a name="l00959"></a>00959 <span class="comment">// template&lt;class dataType&gt;</span>
  1039. <a name="l00960"></a>00960 <span class="comment">// class failPoint</span>
  1040. <a name="l00961"></a>00961 <span class="comment">// {</span>
  1041. <a name="l00962"></a>00962 <span class="comment">// public:</span>
  1042. <a name="l00963"></a>00963 <span class="comment">// </span>
  1043. <a name="l00964"></a>00964 <span class="comment">// dataType fail; // 1 and greater indacates failer</span>
  1044. <a name="l00965"></a>00965 <span class="comment">// dataType s; // this is the element coordiate system... eventually should be extended to give x,y though but later</span>
  1045. <a name="l00966"></a>00966 <span class="comment">// dataType t;</span>
  1046. <a name="l00967"></a>00967 <span class="comment">// unsigned long elmID; // this is the element</span>
  1047. <a name="l00968"></a>00968 <span class="comment">// unsigned long meshID; // this default 0, but in the outer layer should be set to the real number</span>
  1048. <a name="l00969"></a>00969 <span class="comment">// bool meshIDSet; // this is a flag the tells whether the mesh ID has been set</span>
  1049. <a name="l00970"></a>00970 <span class="comment">// </span>
  1050. <a name="l00971"></a>00971 <span class="comment">// failPoint(dataType fail_in=0.0,dataType s_in=0.0,dataType t_in=0.0,unsigned long elmID_in,unsigned long meshID_in=0,bool meshIDSet=false)</span>
  1051. <a name="l00972"></a>00972 <span class="comment">// : fail(fail_in) , s(s_in) , t(t_in) , elmID(elmID_in) , meshID(meshID_in) , meshIDSet(false)</span>
  1052. <a name="l00973"></a>00973 <span class="comment">// {}</span>
  1053. <a name="l00974"></a>00974 <span class="comment">// </span>
  1054. <a name="l00975"></a>00975 <span class="comment">// failPoint(const failPoint&lt;dataType&gt;&amp; asg) : fail(asg.fail) , s(asg.s) , t(asg.t) , elmID(asg.elmID) , meshID(asg.meshID) , meshIDSet(asg.meshIDSet)</span>
  1055. <a name="l00976"></a>00976 <span class="comment">// {}</span>
  1056. <a name="l00977"></a>00977 <span class="comment">// </span>
  1057. <a name="l00978"></a>00978 <span class="comment">// virtual ~failPoint()</span>
  1058. <a name="l00979"></a>00979 <span class="comment">// {}</span>
  1059. <a name="l00980"></a>00980 <span class="comment">// </span>
  1060. <a name="l00981"></a>00981 <span class="comment">// failPoint&lt;dataType&gt;&amp; operator=(const failPoint&lt;dataType&gt;&amp; asg)</span>
  1061. <a name="l00982"></a>00982 <span class="comment">// {</span>
  1062. <a name="l00983"></a>00983 <span class="comment">// this-&gt;fail=asg.fail;</span>
  1063. <a name="l00984"></a>00984 <span class="comment">// this-&gt;s=asg.s;</span>
  1064. <a name="l00985"></a>00985 <span class="comment">// this-&gt;t=asg.t;</span>
  1065. <a name="l00986"></a>00986 <span class="comment">// this-&gt;elmID=asg.elmID;</span>
  1066. <a name="l00987"></a>00987 <span class="comment">// this-&gt;meshID=asg.meshID;</span>
  1067. <a name="l00988"></a>00988 <span class="comment">// this-&gt;meshIDSet=asg.meshIDSet;</span>
  1068. <a name="l00989"></a>00989 <span class="comment">// </span>
  1069. <a name="l00990"></a>00990 <span class="comment">// return *this;</span>
  1070. <a name="l00991"></a>00991 <span class="comment">// }</span>
  1071. <a name="l00992"></a>00992 <span class="comment">// };</span>
  1072. <a name="l00993"></a>00993
  1073. <a name="l00994"></a>00994 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  1074. <a name="l00995"></a><a class="code" href="classVABSModelInput.html">00995</a> <span class="keyword">class </span><a class="code" href="classVABSModelInput.html">VABSModelInput</a>
  1075. <a name="l00996"></a>00996 {
  1076. <a name="l00997"></a>00997 <span class="keyword">public</span>:
  1077. <a name="l00998"></a>00998
  1078. <a name="l00999"></a><a class="code" href="classVABSModelInput.html#afcae6babe46baa259b50efa164b32fdb">00999</a> <a class="code" href="classVABSModelInput.html#afcae6babe46baa259b50efa164b32fdb">VABSModelInput</a>()
  1079. <a name="l01000"></a>01000 {}
  1080. <a name="l01001"></a>01001
  1081. <a name="l01002"></a><a class="code" href="classVABSModelInput.html#ae3e8959d26507387d97dd5a160c72713">01002</a> <span class="keyword">virtual</span> <a class="code" href="classVABSModelInput.html#ae3e8959d26507387d97dd5a160c72713">~VABSModelInput</a>()
  1082. <a name="l01003"></a>01003 {}
  1083. <a name="l01004"></a>01004
  1084. <a name="l01005"></a>01005 <span class="comment">// This is a function that provides the mesh to the vabs model</span>
  1085. <a name="l01006"></a>01006 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classVABSModelInput.html#a34bb1d411f8b8303d932e0a1503fba25">setMesh</a>(<a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>* cxMesh_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)=0;
  1086. <a name="l01007"></a>01007 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classVABSModelInput.html#a14f9d151b0d089a8a140418264b1ff15">solve</a>()=0;
  1087. <a name="l01008"></a>01008 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classVABSModelInput.html#ae9e0c54fac2464d9f13a599c5af1784a">buildSVD</a>()=0;
  1088. <a name="l01009"></a>01009 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classVABSModelInput.html#aa964d19fe486ffc21a58e341a34ab2d8">solveSVD</a>()=0;
  1089. <a name="l01010"></a>01010 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classVABSModelInput.html#aa1e92195b3ac2661ec4e001d4b2f6c47">processSVD</a>()=0;
  1090. <a name="l01011"></a>01011 };
  1091. <a name="l01012"></a>01012
  1092. <a name="l01013"></a>01013 <span class="comment">// beamMtxType is matrixRdWtStaticSqr_Data&lt;dataType,4&gt; for Bernoulli type</span>
  1093. <a name="l01014"></a>01014 <span class="comment">// is matrixRdWtStaticSqr_Data&lt;dataType,6&gt; for Timoshenko type</span>
  1094. <a name="l01015"></a>01015 <span class="keyword">template</span>&lt;<span class="keyword">class</span> beamMtxType&gt;
  1095. <a name="l01016"></a><a class="code" href="classVABSModelBeamMatrix.html">01016</a> <span class="keyword">class </span><a class="code" href="classVABSModelBeamMatrix.html">VABSModelBeamMatrix</a>
  1096. <a name="l01017"></a>01017 {
  1097. <a name="l01018"></a>01018 <span class="keyword">public</span>:
  1098. <a name="l01019"></a>01019
  1099. <a name="l01020"></a><a class="code" href="classVABSModelBeamMatrix.html#aebe1a6aee7fd6588a6df182a942eb305">01020</a> <a class="code" href="classVABSModelBeamMatrix.html#aebe1a6aee7fd6588a6df182a942eb305">VABSModelBeamMatrix</a>()
  1100. <a name="l01021"></a>01021 {}
  1101. <a name="l01022"></a>01022
  1102. <a name="l01023"></a><a class="code" href="classVABSModelBeamMatrix.html#a3de263e4ba300733064638194d7a0128">01023</a> <span class="keyword">virtual</span> <a class="code" href="classVABSModelBeamMatrix.html#a3de263e4ba300733064638194d7a0128">~VABSModelBeamMatrix</a>()
  1103. <a name="l01024"></a>01024 {}
  1104. <a name="l01025"></a>01025
  1105. <a name="l01026"></a>01026 <span class="comment">//This retrieve the beam matrix</span>
  1106. <a name="l01027"></a>01027 <span class="keyword">virtual</span> beamMtxType <a class="code" href="classVABSModelBeamMatrix.html#ad74f2717ec4415b3603ba49f42403b0c">beamMatrix</a>()=0;
  1107. <a name="l01028"></a>01028 };
  1108. <a name="l01029"></a>01029
  1109. <a name="l01030"></a>01030 <span class="keyword">template</span>&lt;<span class="keyword">class</span> elmPostType&gt;
  1110. <a name="l01031"></a><a class="code" href="classVABSModelPost.html">01031</a> <span class="keyword">class </span><a class="code" href="classVABSModelPost.html">VABSModelPost</a>
  1111. <a name="l01032"></a>01032 {
  1112. <a name="l01033"></a>01033 <span class="keyword">public</span>:
  1113. <a name="l01034"></a>01034
  1114. <a name="l01035"></a><a class="code" href="classVABSModelPost.html#ab1bd45cfe293a9e588f7e0491ae2717a">01035</a> <a class="code" href="classVABSModelPost.html#ab1bd45cfe293a9e588f7e0491ae2717a">VABSModelPost</a>()
  1115. <a name="l01036"></a>01036 {}
  1116. <a name="l01037"></a>01037
  1117. <a name="l01038"></a><a class="code" href="classVABSModelPost.html#a77daf7639e01f16c9039cc64468dda4a">01038</a> <span class="keyword">virtual</span> <a class="code" href="classVABSModelPost.html#a77daf7639e01f16c9039cc64468dda4a">~VABSModelPost</a>()
  1118. <a name="l01039"></a>01039 {}
  1119. <a name="l01040"></a>01040
  1120. <a name="l01041"></a>01041 <span class="comment">// A method that informs the post process module about the number of elements</span>
  1121. <a name="l01042"></a>01042 <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classVABSModelPost.html#a476038f832b9ef6181ac62f3874fd0ec">size</a>()=0;
  1122. <a name="l01043"></a>01043 <span class="comment">// This is an access method to perform post processing</span>
  1123. <a name="l01044"></a>01044 <span class="keyword">virtual</span> <a class="code" href="classautoPntr.html">autoPntr&lt;elmPostType&gt;</a> <a class="code" href="classVABSModelPost.html#ab22c953c94473d150d7b45b30833969d">getElement</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)=0;
  1124. <a name="l01045"></a>01045 };
  1125. <a name="l01046"></a>01046
  1126. <a name="l01047"></a>01047 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> beamMtxType,<span class="keyword">class</span> elmPostType&gt;
  1127. <a name="l01048"></a><a class="code" href="classVABSModel.html">01048</a> <span class="keyword">class </span><a class="code" href="classVABSModel.html">VABSModel</a> : <span class="keyword">public</span> <a class="code" href="classVABSModelInput.html">VABSModelInput</a>&lt;dataType&gt; , <span class="keyword">public</span> <a class="code" href="classVABSModelBeamMatrix.html">VABSModelBeamMatrix</a>&lt;beamMtxType&gt; , <span class="keyword">public</span> <a class="code" href="classVABSModelPost.html">VABSModelPost</a>&lt;elmPostType&gt;
  1128. <a name="l01049"></a>01049 {
  1129. <a name="l01050"></a>01050 <span class="keyword">public</span>:
  1130. <a name="l01051"></a>01051
  1131. <a name="l01052"></a><a class="code" href="classVABSModel.html#a49f45824951a0a80eb6fc0190c7c5cd5">01052</a> <a class="code" href="classVABSModel.html#a49f45824951a0a80eb6fc0190c7c5cd5">VABSModel</a>()
  1132. <a name="l01053"></a>01053 {}
  1133. <a name="l01054"></a>01054
  1134. <a name="l01055"></a><a class="code" href="classVABSModel.html#a6fdc27da8ef32ea4f32c63880f747845">01055</a> <span class="keyword">virtual</span> <a class="code" href="classVABSModel.html#a6fdc27da8ef32ea4f32c63880f747845">~VABSModel</a>()
  1135. <a name="l01056"></a>01056 {}
  1136. <a name="l01057"></a>01057 };
  1137. <a name="l01058"></a>01058
  1138. <a name="l01059"></a>01059 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  1139. <a name="l01060"></a><a class="code" href="classVABS1Model__Base.html">01060</a> <span class="keyword">class </span><a class="code" href="classVABS1Model__Base.html">VABS1Model_Base</a> : <span class="keyword">public</span> <a class="code" href="classVABSModel.html">VABSModel</a>&lt;dataType,matrixRdWtStaticSqr_Data&lt;dataType,4&gt;,VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,4&gt; &gt; &gt;
  1140. <a name="l01061"></a>01061 {
  1141. <a name="l01062"></a>01062 <span class="keyword">private</span>:
  1142. <a name="l01063"></a>01063
  1143. <a name="l01064"></a>01064 <span class="comment">// Input data used to build the constituitive matrix</span>
  1144. <a name="l01065"></a>01065 <a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>* cxMesh;
  1145. <a name="l01066"></a>01066 <span class="keywordtype">bool</span> matrixBuilt;
  1146. <a name="l01067"></a>01067
  1147. <a name="l01068"></a>01068 <span class="comment">// These are the fem objects </span>
  1148. <a name="l01069"></a>01069 std::vector&lt;VABSNode_common&lt;dataType&gt; &gt; commonNodes;
  1149. <a name="l01070"></a>01070 std::vector&lt;std::vector&lt;VABSNode_element&lt;dataType&gt; &gt; &gt; elementNodes;
  1150. <a name="l01071"></a>01071 std::vector&lt;VABS1_MatrixSource_Quad&lt;dataType&gt; &gt; elements;
  1151. <a name="l01072"></a>01072
  1152. <a name="l01073"></a>01073 <span class="comment">// these are the matrices</span>
  1153. <a name="l01074"></a>01074
  1154. <a name="l01075"></a>01075 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; Psi;</span>
  1155. <a name="l01076"></a>01076 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; E; // delete me</span>
  1156. <a name="l01077"></a>01077
  1157. <a name="l01078"></a>01078 <span class="comment">// this is the solver</span>
  1158. <a name="l01079"></a>01079 <span class="preprocessor">#ifdef SVD_BASED_VABS_SOLUTION</span>
  1159. <a name="l01080"></a>01080 <span class="preprocessor"></span> <a class="code" href="classvabsSvdSolver.html">vabsSvdSolver</a> solver;
  1160. <a name="l01081"></a>01081 <span class="preprocessor">#else</span>
  1161. <a name="l01082"></a>01082 <span class="preprocessor"></span> <a class="code" href="classmatrixMatrixSolver.html">matrixMatrixSolver</a> solver;
  1162. <a name="l01083"></a>01083 <span class="preprocessor">#endif</span>
  1163. <a name="l01084"></a>01084 <span class="preprocessor"></span>
  1164. <a name="l01085"></a>01085 <span class="comment">// This is the matrix that is returned as a result</span>
  1165. <a name="l01086"></a>01086 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> result;
  1166. <a name="l01087"></a>01087
  1167. <a name="l01088"></a>01088 <span class="comment">// state data on the model</span>
  1168. <a name="l01089"></a>01089 <span class="keywordtype">bool</span> isBuilt;
  1169. <a name="l01090"></a>01090 <span class="keywordtype">bool</span> isSolved;
  1170. <a name="l01091"></a>01091 <span class="keywordtype">bool</span> canDelete;
  1171. <a name="l01092"></a>01092
  1172. <a name="l01093"></a>01093 <span class="preprocessor">#if defined(SAVE_INTERMEDIATES) || defined(ADJOINT_VABS)</span>
  1173. <a name="l01094"></a>01094 <span class="preprocessor"></span> <span class="keyword">public</span>:
  1174. <a name="l01095"></a>01095 <span class="comment">// matrixRdWtSzSqr_Data&lt;dataType&gt; ET;</span>
  1175. <a name="l01096"></a>01096 <a class="code" href="classmatrixRdWtSzSqr__Data.html">matrixRdWtSzSqr_Data&lt;dataType&gt;</a> ETDyad;
  1176. <a name="l01097"></a>01097 <span class="preprocessor">#endif</span>
  1177. <a name="l01098"></a>01098 <span class="preprocessor"></span> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> Dae;
  1178. <a name="l01099"></a>01099 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> Dee;
  1179. <a name="l01100"></a>01100 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> H;
  1180. <a name="l01101"></a>01101 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> v;
  1181. <a name="l01102"></a>01102 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  1182. <a name="l01103"></a>01103 <span class="preprocessor"></span> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> Psi;
  1183. <a name="l01104"></a>01104 <span class="preprocessor">#endif</span>
  1184. <a name="l01105"></a>01105 <span class="preprocessor"></span><span class="preprocessor">#if defined(SAVE_INTERMEDIATES) || defined(ADJOINT_VABS)</span>
  1185. <a name="l01106"></a>01106 <span class="preprocessor"></span> <span class="keyword">private</span>:
  1186. <a name="l01107"></a>01107 <span class="preprocessor">#endif</span>
  1187. <a name="l01108"></a>01108 <span class="preprocessor"></span>
  1188. <a name="l01109"></a>01109 <span class="preprocessor">#if defined(SAVE_INTERMEDIATES) || defined(ADJOINT_VABS)</span>
  1189. <a name="l01110"></a>01110 <span class="preprocessor"></span>
  1190. <a name="l01111"></a>01111 <span class="keyword">public</span>:
  1191. <a name="l01112"></a>01112
  1192. <a name="l01113"></a>01113 <span class="keyword">static</span> <span class="keywordtype">bool</span> gradientMode;
  1193. <a name="l01114"></a>01114 <span class="keyword">static</span> <span class="keywordtype">bool</span> highCalc;
  1194. <a name="l01115"></a>01115 <span class="keyword">static</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> step;
  1195. <a name="l01116"></a>01116 <span class="keyword">static</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> atS;
  1196. <a name="l01117"></a>01117 <span class="keyword">static</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> atT;
  1197. <a name="l01118"></a>01118 <span class="keyword">static</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> beamLocation;
  1198. <a name="l01119"></a>01119 <span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> maxElm;
  1199. <a name="l01120"></a>01120 <span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> maxCX;
  1200. <a name="l01121"></a>01121
  1201. <a name="l01122"></a>01122 <span class="keyword">static</span> std::vector&lt;VABS1Model_Base*&gt; vabsList;
  1202. <a name="l01123"></a>01123
  1203. <a name="l01124"></a>01124 <span class="keyword">private</span>:
  1204. <a name="l01125"></a>01125
  1205. <a name="l01126"></a>01126 <span class="preprocessor">#endif</span>
  1206. <a name="l01127"></a>01127 <span class="preprocessor"></span>
  1207. <a name="l01128"></a>01128 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
  1208. <a name="l01129"></a>01129 <span class="preprocessor"></span>
  1209. <a name="l01130"></a>01130 <span class="keyword">private</span>:
  1210. <a name="l01131"></a>01131
  1211. <a name="l01132"></a>01132 <span class="comment">// this is the meshes</span>
  1212. <a name="l01133"></a>01133 <a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>* cxMeshHigh;
  1213. <a name="l01134"></a>01134 <a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>* cxMeshLow;
  1214. <a name="l01135"></a>01135
  1215. <a name="l01136"></a>01136 <span class="comment">// These are the fem objects </span>
  1216. <a name="l01137"></a>01137 std::vector&lt;VABSNode_common&lt;dataType&gt; &gt; commonNodesHigh;
  1217. <a name="l01138"></a>01138 std::vector&lt;std::vector&lt;VABSNode_element&lt;dataType&gt; &gt; &gt; elementNodesHigh;
  1218. <a name="l01139"></a>01139 std::vector&lt;VABS1_MatrixSource_Quad&lt;dataType&gt; &gt; elementsHigh;
  1219. <a name="l01140"></a>01140
  1220. <a name="l01141"></a>01141 <span class="comment">// These are the fem objects </span>
  1221. <a name="l01142"></a>01142 std::vector&lt;VABSNode_common&lt;dataType&gt; &gt; commonNodesLow;
  1222. <a name="l01143"></a>01143 std::vector&lt;std::vector&lt;VABSNode_element&lt;dataType&gt; &gt; &gt; elementNodesLow;
  1223. <a name="l01144"></a>01144 std::vector&lt;VABS1_MatrixSource_Quad&lt;dataType&gt; &gt; elementsLow;
  1224. <a name="l01145"></a>01145
  1225. <a name="l01146"></a>01146 <span class="keyword">public</span>:
  1226. <a name="l01147"></a>01147
  1227. <a name="l01148"></a>01148 <a class="code" href="classmatrixRdWtSzSqr__Data.html">matrixRdWtSzSqr_Data&lt;dataType&gt;</a> N;
  1228. <a name="l01149"></a>01149 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> vStar_adjoint;
  1229. <a name="l01150"></a>01150 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; vStar_adjointLow;</span>
  1230. <a name="l01151"></a>01151 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; vStar_adjointHigh;</span>
  1231. <a name="l01152"></a>01152
  1232. <a name="l01153"></a>01153 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> dDae_dy;
  1233. <a name="l01154"></a>01154 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> dN_dy;
  1234. <a name="l01155"></a>01155 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; dH_dy;</span>
  1235. <a name="l01156"></a>01156 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; dPsi_dy;</span>
  1236. <a name="l01157"></a>01157 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> dDee_dy;
  1237. <a name="l01158"></a>01158 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> dE_dy;
  1238. <a name="l01159"></a>01159
  1239. <a name="l01160"></a>01160 <span class="comment">// these are the low matrices</span>
  1240. <a name="l01161"></a>01161 <a class="code" href="classmatrixRdWtSzSqr__Data.html">matrixRdWtSzSqr_Data&lt;dataType&gt;</a> ELow;
  1241. <a name="l01162"></a>01162 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> DaeLow;
  1242. <a name="l01163"></a>01163 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> DeeLow;
  1243. <a name="l01164"></a>01164 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> NLow;
  1244. <a name="l01165"></a>01165 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> HLow;
  1245. <a name="l01166"></a>01166 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  1246. <a name="l01167"></a>01167 <span class="preprocessor"></span> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> PsiLow;
  1247. <a name="l01168"></a>01168 <span class="preprocessor">#endif</span>
  1248. <a name="l01169"></a>01169 <span class="preprocessor"></span>
  1249. <a name="l01170"></a>01170 <span class="comment">// these are the high matrices</span>
  1250. <a name="l01171"></a>01171 <a class="code" href="classmatrixRdWtSzSqr__Data.html">matrixRdWtSzSqr_Data&lt;dataType&gt;</a> EHigh;
  1251. <a name="l01172"></a>01172 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> DaeHigh;
  1252. <a name="l01173"></a>01173 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> DeeHigh;
  1253. <a name="l01174"></a>01174 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> NHigh;
  1254. <a name="l01175"></a>01175 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> HHigh;
  1255. <a name="l01176"></a>01176 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  1256. <a name="l01177"></a>01177 <span class="preprocessor"></span> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> PsiHigh;
  1257. <a name="l01178"></a>01178 <span class="preprocessor">#endif</span>
  1258. <a name="l01179"></a>01179 <span class="preprocessor"></span>
  1259. <a name="l01180"></a>01180 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> dC_dy;
  1260. <a name="l01181"></a>01181
  1261. <a name="l01182"></a>01182 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> adjointFail;
  1262. <a name="l01183"></a>01183
  1263. <a name="l01184"></a>01184 <span class="keywordtype">void</span> buildHighMatrix(<a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>* cxMeshHigh_in)
  1264. <a name="l01185"></a>01185 {
  1265. <a name="l01186"></a>01186
  1266. <a name="l01187"></a>01187 cxMeshHigh=cxMeshHigh_in;
  1267. <a name="l01188"></a>01188
  1268. <a name="l01189"></a>01189 <span class="keywordflow">if</span>(cxMeshHigh==NULL)
  1269. <a name="l01190"></a>01190 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::buildHighLowMatrix(): The mesh has not been specified&quot;</span>);
  1270. <a name="l01191"></a>01191
  1271. <a name="l01192"></a>01192 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  1272. <a name="l01193"></a>01193 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a4a19abf94aa1abd08eb8b6fdd2f4662e">TIMEALG::vabsMeshLinkStart</a>();
  1273. <a name="l01194"></a>01194 <span class="preprocessor">#endif</span>
  1274. <a name="l01195"></a>01195 <span class="preprocessor"></span>
  1275. <a name="l01196"></a>01196 <span class="comment">// retrieve the size</span>
  1276. <a name="l01197"></a>01197 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> ndCnt;
  1277. <a name="l01198"></a>01198 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> elmCnt;
  1278. <a name="l01199"></a>01199 cxMeshHigh-&gt;size(ndCnt,elmCnt);
  1279. <a name="l01200"></a>01200
  1280. <a name="l01201"></a>01201 <span class="comment">// size all the matrices</span>
  1281. <a name="l01202"></a>01202 EHigh.resize(ndCnt*3);
  1282. <a name="l01203"></a>01203 DaeHigh.resize(ndCnt*3,4);
  1283. <a name="l01204"></a>01204 HHigh.resize(ndCnt*3,ndCnt*3);
  1284. <a name="l01205"></a>01205 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  1285. <a name="l01206"></a>01206 <span class="preprocessor"></span> PsiHigh.resize(ndCnt*3,4);
  1286. <a name="l01207"></a>01207 <span class="preprocessor">#endif</span>
  1287. <a name="l01208"></a>01208 <span class="preprocessor"></span>
  1288. <a name="l01209"></a>01209 <span class="comment">// create all the nodes and elements</span>
  1289. <a name="l01210"></a>01210 commonNodesHigh.resize(ndCnt);
  1290. <a name="l01211"></a>01211 elementNodesHigh.resize(ndCnt);
  1291. <a name="l01212"></a>01212 elementsHigh.resize(elmCnt);
  1292. <a name="l01213"></a>01213 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;ndCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1293. <a name="l01214"></a>01214 {
  1294. <a name="l01215"></a>01215 commonNodesHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setX(cxMeshHigh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).x);
  1295. <a name="l01216"></a>01216 commonNodesHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setY(cxMeshHigh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).y);
  1296. <a name="l01217"></a>01217 <span class="comment">// for(unsigned long j=0;j&lt;3;j++)</span>
  1297. <a name="l01218"></a>01218 <span class="comment">// {</span>
  1298. <a name="l01219"></a>01219 <span class="comment">// for(unsigned long k=0;k&lt;4;k++)</span>
  1299. <a name="l01220"></a>01220 <span class="comment">// commonNodesHigh[i].setWarping(j,k,&amp;(vHigh.entry(i*3+j,k)));</span>
  1300. <a name="l01221"></a>01221 <span class="comment">// }</span>
  1301. <a name="l01222"></a>01222 elementNodesHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].resize(cxMeshHigh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData.size());
  1302. <a name="l01223"></a>01223 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;elementNodesHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].size();j++)
  1303. <a name="l01224"></a>01224 elementNodesHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>][j].setH(cxMeshHigh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData[j].h_over_H).setAng(cxMeshHigh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData[j].angle).setCommon(&amp;(commonNodesHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]));
  1304. <a name="l01225"></a>01225 }
  1305. <a name="l01226"></a>01226 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;elmCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1306. <a name="l01227"></a>01227 {
  1307. <a name="l01228"></a>01228 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();j++)
  1308. <a name="l01229"></a>01229 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setNode(j,&amp;(elementNodesHigh[cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID][cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].dataID]));
  1309. <a name="l01230"></a>01230 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setMatl(cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).material);
  1310. <a name="l01231"></a>01231 }
  1311. <a name="l01232"></a>01232
  1312. <a name="l01233"></a>01233 <span class="comment">// set all the matrices in the elements</span>
  1313. <a name="l01234"></a>01234 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;elmCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1314. <a name="l01235"></a>01235 {
  1315. <a name="l01236"></a>01236 <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData&lt;dataType&gt;</a>* EMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData&lt;dataType&gt;</a>(cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3);
  1316. <a name="l01237"></a>01237 <span class="keywordflow">if</span>(EMatrix==NULL)
  1317. <a name="l01238"></a>01238 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::buildMatrix(): Failed to allocate memory for EMatrix&quot;</span>);
  1318. <a name="l01239"></a>01239 <a class="code" href="classmatrixRdWt__pData.html">matrixRdWt_pData&lt;dataType&gt;</a>* DaeMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWt__pData.html">matrixRdWt_pData&lt;dataType&gt;</a>(cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3,4);
  1319. <a name="l01240"></a>01240 <span class="keywordflow">if</span>(DaeMatrix==NULL)
  1320. <a name="l01241"></a>01241 {
  1321. <a name="l01242"></a>01242 <span class="keyword">delete</span> EMatrix;
  1322. <a name="l01243"></a>01243 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::buildMatrix(): Failed to allocate memory for DaeMatrix&quot;</span>);
  1323. <a name="l01244"></a>01244 }
  1324. <a name="l01245"></a>01245 <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData&lt;dataType&gt;</a>* HMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData&lt;dataType&gt;</a>(cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3);
  1325. <a name="l01246"></a>01246 <span class="keywordflow">if</span>(HMatrix==NULL)
  1326. <a name="l01247"></a>01247 {
  1327. <a name="l01248"></a>01248 <span class="keyword">delete</span> EMatrix;
  1328. <a name="l01249"></a>01249 <span class="keyword">delete</span> DaeMatrix;
  1329. <a name="l01250"></a>01250 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::buildMatrix(): Failed to allocate memory for HMatrix&quot;</span>);
  1330. <a name="l01251"></a>01251 }
  1331. <a name="l01252"></a>01252 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();j++)
  1332. <a name="l01253"></a>01253 {
  1333. <a name="l01254"></a>01254 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k&lt;cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();k++)
  1334. <a name="l01255"></a>01255 {
  1335. <a name="l01256"></a>01256 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> m=0;m&lt;3;m++)
  1336. <a name="l01257"></a>01257 {
  1337. <a name="l01258"></a>01258 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> n=0;n&lt;3;n++)
  1338. <a name="l01259"></a>01259 {
  1339. <a name="l01260"></a>01260 EMatrix-&gt;<a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,k*3+n,&amp;(EHigh.entry(cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[k].nodeID*3+n)),<span class="keyword">false</span>); <span class="comment">// delete</span>
  1340. <a name="l01261"></a>01261 HMatrix-&gt;<a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,k*3+n,&amp;(HHigh.entry(cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[k].nodeID*3+n)),<span class="keyword">false</span>);
  1341. <a name="l01262"></a>01262 }
  1342. <a name="l01263"></a>01263 }
  1343. <a name="l01264"></a>01264 }
  1344. <a name="l01265"></a>01265 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> m=0;m&lt;3;m++)
  1345. <a name="l01266"></a>01266 {
  1346. <a name="l01267"></a>01267 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> n=0;n&lt;4;n++)
  1347. <a name="l01268"></a>01268 {
  1348. <a name="l01269"></a>01269 DaeMatrix-&gt;<a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,n,&amp;(DaeHigh.entry(cxMeshHigh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,n)),<span class="keyword">false</span>);
  1349. <a name="l01270"></a>01270 <span class="comment">// PsiMatrix-&gt;setPointer(j*3+m,n,&amp;(Psi.entry(cxMesh-&gt;getElement(i).nodeHndl[j].nodeID*3+m,n)),false);</span>
  1350. <a name="l01271"></a>01271 }
  1351. <a name="l01272"></a>01272 }
  1352. <a name="l01273"></a>01273 }
  1353. <a name="l01274"></a>01274 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setEMatrix(EMatrix,<span class="keyword">true</span>);
  1354. <a name="l01275"></a>01275 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setDeaMatrix(DaeMatrix,<span class="keyword">true</span>);
  1355. <a name="l01276"></a>01276 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setHMatrix(HMatrix,<span class="keyword">true</span>);
  1356. <a name="l01277"></a>01277 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setDeeMatrix(&amp;DeeHigh);
  1357. <a name="l01278"></a>01278 <span class="comment">// elements[i].setPsiMatrix(PsiMatrix);</span>
  1358. <a name="l01279"></a>01279 }
  1359. <a name="l01280"></a>01280
  1360. <a name="l01281"></a>01281 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  1361. <a name="l01282"></a>01282 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a19a22177645e1866a8cb9217ad98b726">TIMEALG::vabsMeshLinkStop</a>();
  1362. <a name="l01283"></a>01283 <a class="code" href="namespaceTIMEALG.html#a47cb7df0449fa5c03c285d3e92d3aa2d">TIMEALG::vabsMtxCalcStart</a>();
  1363. <a name="l01284"></a>01284 <span class="preprocessor">#endif</span>
  1364. <a name="l01285"></a>01285 <span class="preprocessor"></span>
  1365. <a name="l01286"></a>01286 <span class="comment">// initialize the matrices</span>
  1366. <a name="l01287"></a>01287 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
  1367. <a name="l01288"></a>01288 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
  1368. <a name="l01289"></a>01289 HHigh.size(rCnt,cCnt);
  1369. <a name="l01290"></a>01290 HHigh=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  1370. <a name="l01291"></a>01291 DaeHigh.size(rCnt,cCnt);
  1371. <a name="l01292"></a>01292 DaeHigh=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  1372. <a name="l01293"></a>01293 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  1373. <a name="l01294"></a>01294 <span class="preprocessor"></span> PsiHigh.size(rCnt,cCnt);
  1374. <a name="l01295"></a>01295 PsiHigh=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  1375. <a name="l01296"></a>01296 <span class="preprocessor">#endif</span>
  1376. <a name="l01297"></a>01297 <span class="preprocessor"></span> cCnt=rCnt=DeeHigh.size();
  1377. <a name="l01298"></a>01298 DeeHigh=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  1378. <a name="l01299"></a>01299 cCnt=rCnt=EHigh.size();
  1379. <a name="l01300"></a>01300 EHigh=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  1380. <a name="l01301"></a>01301
  1381. <a name="l01302"></a>01302 <span class="comment">// Create the matrices</span>
  1382. <a name="l01303"></a>01303 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;elementsHigh.size();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1383. <a name="l01304"></a>01304 {
  1384. <a name="l01305"></a>01305 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addE();
  1385. <a name="l01306"></a>01306 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addDee();
  1386. <a name="l01307"></a>01307 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addDae();
  1387. <a name="l01308"></a>01308 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addH();
  1388. <a name="l01309"></a>01309 }
  1389. <a name="l01310"></a>01310
  1390. <a name="l01311"></a>01311 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  1391. <a name="l01312"></a>01312 <span class="preprocessor"></span> <span class="comment">// create the Psi matrix</span>
  1392. <a name="l01313"></a>01313 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> one=1.0/sqrt(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>(ndCnt*3));
  1393. <a name="l01314"></a>01314 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;ndCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1394. <a name="l01315"></a>01315 {
  1395. <a name="l01316"></a>01316 PsiHigh.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3,0)=one;
  1396. <a name="l01317"></a>01317 PsiHigh.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1,1)=one;
  1397. <a name="l01318"></a>01318 PsiHigh.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2,2)=one;
  1398. <a name="l01319"></a>01319 PsiHigh.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1,3)=cxMeshHigh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).y;
  1399. <a name="l01320"></a>01320 PsiHigh.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2,3)=-cxMeshHigh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).x;
  1400. <a name="l01321"></a>01321 }
  1401. <a name="l01322"></a>01322 <span class="preprocessor">#endif</span>
  1402. <a name="l01323"></a>01323 <span class="preprocessor"></span>
  1403. <a name="l01324"></a>01324 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  1404. <a name="l01325"></a>01325 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#abb3dfe1409ead9ab389b11970c1ed9bb">TIMEALG::vabsMtxCalcStop</a>();
  1405. <a name="l01326"></a>01326 <a class="code" href="namespaceTIMEALG.html#a64fad33a25509725cf641d6f6d9c6f63">TIMEALG::vabsNCalcStart</a>();
  1406. <a name="l01327"></a>01327 <span class="preprocessor">#endif</span>
  1407. <a name="l01328"></a>01328 <span class="preprocessor"></span>
  1408. <a name="l01329"></a>01329 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> PsiTHPsi=PsiHigh.<a class="code" href="classmatrixRdWtStaticSqr__Data.html#a3db65c97e3f5de1fe52b5f0831e11176">T</a>()*HHigh*PsiHigh;
  1409. <a name="l01330"></a>01330 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> PsiTHPsi_Inverse=PsiTHPsi.<a class="code" href="classmatrixSqr.html#a991ebad568b11587f75c85cc3b8da408">inverse</a>();
  1410. <a name="l01331"></a>01331 NHigh=(<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::identityMatrix</a>(rCnt)-HHigh*PsiHigh*PsiTHPsi_Inverse*PsiHigh.<a class="code" href="classmatrixRdWtStaticSqr__Data.html#a3db65c97e3f5de1fe52b5f0831e11176">T</a>()).<a class="code" href="rotationMath_8cpp.html#a77ad922cc714adc5ebf10e36b2dd58f8">T</a>();
  1411. <a name="l01332"></a>01332
  1412. <a name="l01333"></a>01333 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  1413. <a name="l01334"></a>01334 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a294dfa8c6f83f364d880655b35f8531f">TIMEALG::vabsNCalcStop</a>();
  1414. <a name="l01335"></a>01335 <span class="preprocessor">#endif</span>
  1415. <a name="l01336"></a>01336 <span class="preprocessor"></span>
  1416. <a name="l01337"></a>01337 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; vStarSource=-NHigh.T()*DaeHigh;</span>
  1417. <a name="l01338"></a>01338 <span class="comment">// solver.A()=EHigh;</span>
  1418. <a name="l01339"></a>01339 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; PsiDyad=PsiHigh*PsiHigh.T();</span>
  1419. <a name="l01340"></a>01340 <span class="comment">// dataType tracePsi=0.0;</span>
  1420. <a name="l01341"></a>01341 <span class="comment">// dataType traceE=0.0;</span>
  1421. <a name="l01342"></a>01342 <span class="comment">// for(unsigned long i=0;i&lt;rCnt;i++)</span>
  1422. <a name="l01343"></a>01343 <span class="comment">// {</span>
  1423. <a name="l01344"></a>01344 <span class="comment">// tracePsi+=PsiDyad.entry(i,i);</span>
  1424. <a name="l01345"></a>01345 <span class="comment">// traceE+=solver.A().entry(i,i);</span>
  1425. <a name="l01346"></a>01346 <span class="comment">// }</span>
  1426. <a name="l01347"></a>01347 <span class="comment">// solver.A()+=(traceE/tracePsi)*PsiDyad;</span>
  1427. <a name="l01348"></a>01348 <span class="comment">// solver.B()=vStarSource;</span>
  1428. <a name="l01349"></a>01349 <span class="comment">// solver.solve();</span>
  1429. <a name="l01350"></a>01350 <span class="comment">// </span>
  1430. <a name="l01351"></a>01351 <span class="comment">// vStar_adjointHigh=solver.B();</span>
  1431. <a name="l01352"></a>01352
  1432. <a name="l01353"></a>01353 }
  1433. <a name="l01354"></a>01354
  1434. <a name="l01355"></a>01355 <span class="keywordtype">void</span> buildLowMatrix(<a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>* cxMeshLow_in)
  1435. <a name="l01356"></a>01356 {
  1436. <a name="l01357"></a>01357
  1437. <a name="l01358"></a>01358 cxMeshLow=cxMeshLow_in;
  1438. <a name="l01359"></a>01359
  1439. <a name="l01360"></a>01360 <span class="keywordflow">if</span>(cxMeshLow==NULL)
  1440. <a name="l01361"></a>01361 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::buildHighLowMatrix(): The mesh has not been specified&quot;</span>);
  1441. <a name="l01362"></a>01362
  1442. <a name="l01363"></a>01363 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  1443. <a name="l01364"></a>01364 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a4a19abf94aa1abd08eb8b6fdd2f4662e">TIMEALG::vabsMeshLinkStart</a>();
  1444. <a name="l01365"></a>01365 <span class="preprocessor">#endif</span>
  1445. <a name="l01366"></a>01366 <span class="preprocessor"></span>
  1446. <a name="l01367"></a>01367 <span class="comment">// retrieve the size</span>
  1447. <a name="l01368"></a>01368 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> ndCnt;
  1448. <a name="l01369"></a>01369 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> elmCnt;
  1449. <a name="l01370"></a>01370 cxMeshLow-&gt;size(ndCnt,elmCnt);
  1450. <a name="l01371"></a>01371
  1451. <a name="l01372"></a>01372 <span class="comment">// size all the matrices</span>
  1452. <a name="l01373"></a>01373 ELow.resize(ndCnt*3);
  1453. <a name="l01374"></a>01374 DaeLow.resize(ndCnt*3,4);
  1454. <a name="l01375"></a>01375 HLow.resize(ndCnt*3,ndCnt*3);
  1455. <a name="l01376"></a>01376 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  1456. <a name="l01377"></a>01377 <span class="preprocessor"></span> PsiLow.resize(ndCnt*3,4);
  1457. <a name="l01378"></a>01378 <span class="preprocessor">#endif</span>
  1458. <a name="l01379"></a>01379 <span class="preprocessor"></span>
  1459. <a name="l01380"></a>01380 <span class="comment">// create all the nodes and elements</span>
  1460. <a name="l01381"></a>01381 commonNodesLow.resize(ndCnt);
  1461. <a name="l01382"></a>01382 elementNodesLow.resize(ndCnt);
  1462. <a name="l01383"></a>01383 elementsLow.resize(elmCnt);
  1463. <a name="l01384"></a>01384 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;ndCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1464. <a name="l01385"></a>01385 {
  1465. <a name="l01386"></a>01386 commonNodesLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setX(cxMeshLow-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).x);
  1466. <a name="l01387"></a>01387 commonNodesLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setY(cxMeshLow-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).y);
  1467. <a name="l01388"></a>01388 <span class="comment">// for(unsigned long j=0;j&lt;3;j++)</span>
  1468. <a name="l01389"></a>01389 <span class="comment">// {</span>
  1469. <a name="l01390"></a>01390 <span class="comment">// for(unsigned long k=0;k&lt;4;k++)</span>
  1470. <a name="l01391"></a>01391 <span class="comment">// commonNodesLow[i].setWarping(j,k,&amp;(vLow.entry(i*3+j,k)));</span>
  1471. <a name="l01392"></a>01392 <span class="comment">// }</span>
  1472. <a name="l01393"></a>01393 elementNodesLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].resize(cxMeshLow-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData.size());
  1473. <a name="l01394"></a>01394 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;elementNodesLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].size();j++)
  1474. <a name="l01395"></a>01395 elementNodesLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>][j].setH(cxMeshLow-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData[j].h_over_H).setAng(cxMeshLow-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData[j].angle).setCommon(&amp;(commonNodesLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]));
  1475. <a name="l01396"></a>01396 }
  1476. <a name="l01397"></a>01397 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;elmCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1477. <a name="l01398"></a>01398 {
  1478. <a name="l01399"></a>01399 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();j++)
  1479. <a name="l01400"></a>01400 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setNode(j,&amp;(elementNodesLow[cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID][cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].dataID]));
  1480. <a name="l01401"></a>01401 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setMatl(cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).material);
  1481. <a name="l01402"></a>01402 }
  1482. <a name="l01403"></a>01403
  1483. <a name="l01404"></a>01404 <span class="comment">// set all the matrices in the elements</span>
  1484. <a name="l01405"></a>01405 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;elmCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1485. <a name="l01406"></a>01406 {
  1486. <a name="l01407"></a>01407 <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData&lt;dataType&gt;</a>* EMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData&lt;dataType&gt;</a>(cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3);
  1487. <a name="l01408"></a>01408 <span class="keywordflow">if</span>(EMatrix==NULL)
  1488. <a name="l01409"></a>01409 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::buildMatrix(): Failed to allocate memory for EMatrix&quot;</span>);
  1489. <a name="l01410"></a>01410 <a class="code" href="classmatrixRdWt__pData.html">matrixRdWt_pData&lt;dataType&gt;</a>* DaeMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWt__pData.html">matrixRdWt_pData&lt;dataType&gt;</a>(cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3,4);
  1490. <a name="l01411"></a>01411 <span class="keywordflow">if</span>(DaeMatrix==NULL)
  1491. <a name="l01412"></a>01412 {
  1492. <a name="l01413"></a>01413 <span class="keyword">delete</span> EMatrix;
  1493. <a name="l01414"></a>01414 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::buildMatrix(): Failed to allocate memory for DaeMatrix&quot;</span>);
  1494. <a name="l01415"></a>01415 }
  1495. <a name="l01416"></a>01416 <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData&lt;dataType&gt;</a>* HMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData&lt;dataType&gt;</a>(cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3);
  1496. <a name="l01417"></a>01417 <span class="keywordflow">if</span>(HMatrix==NULL)
  1497. <a name="l01418"></a>01418 {
  1498. <a name="l01419"></a>01419 <span class="keyword">delete</span> EMatrix;
  1499. <a name="l01420"></a>01420 <span class="keyword">delete</span> DaeMatrix;
  1500. <a name="l01421"></a>01421 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::buildMatrix(): Failed to allocate memory for HMatrix&quot;</span>);
  1501. <a name="l01422"></a>01422 }
  1502. <a name="l01423"></a>01423 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();j++)
  1503. <a name="l01424"></a>01424 {
  1504. <a name="l01425"></a>01425 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k&lt;cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();k++)
  1505. <a name="l01426"></a>01426 {
  1506. <a name="l01427"></a>01427 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> m=0;m&lt;3;m++)
  1507. <a name="l01428"></a>01428 {
  1508. <a name="l01429"></a>01429 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> n=0;n&lt;3;n++)
  1509. <a name="l01430"></a>01430 {
  1510. <a name="l01431"></a>01431 EMatrix-&gt;<a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,k*3+n,&amp;(ELow.entry(cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[k].nodeID*3+n)),<span class="keyword">false</span>); <span class="comment">// delete</span>
  1511. <a name="l01432"></a>01432 HMatrix-&gt;<a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,k*3+n,&amp;(HLow.entry(cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[k].nodeID*3+n)),<span class="keyword">false</span>);
  1512. <a name="l01433"></a>01433 }
  1513. <a name="l01434"></a>01434 }
  1514. <a name="l01435"></a>01435 }
  1515. <a name="l01436"></a>01436 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> m=0;m&lt;3;m++)
  1516. <a name="l01437"></a>01437 {
  1517. <a name="l01438"></a>01438 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> n=0;n&lt;4;n++)
  1518. <a name="l01439"></a>01439 {
  1519. <a name="l01440"></a>01440 DaeMatrix-&gt;<a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,n,&amp;(DaeLow.entry(cxMeshLow-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,n)),<span class="keyword">false</span>);
  1520. <a name="l01441"></a>01441 <span class="comment">// PsiMatrix-&gt;setPointer(j*3+m,n,&amp;(Psi.entry(cxMesh-&gt;getElement(i).nodeHndl[j].nodeID*3+m,n)),false);</span>
  1521. <a name="l01442"></a>01442 }
  1522. <a name="l01443"></a>01443 }
  1523. <a name="l01444"></a>01444 }
  1524. <a name="l01445"></a>01445 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setEMatrix(EMatrix,<span class="keyword">true</span>);
  1525. <a name="l01446"></a>01446 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setDeaMatrix(DaeMatrix,<span class="keyword">true</span>);
  1526. <a name="l01447"></a>01447 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setHMatrix(HMatrix,<span class="keyword">true</span>);
  1527. <a name="l01448"></a>01448 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setDeeMatrix(&amp;DeeLow);
  1528. <a name="l01449"></a>01449 <span class="comment">// elements[i].setPsiMatrix(PsiMatrix);</span>
  1529. <a name="l01450"></a>01450 }
  1530. <a name="l01451"></a>01451
  1531. <a name="l01452"></a>01452 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  1532. <a name="l01453"></a>01453 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a19a22177645e1866a8cb9217ad98b726">TIMEALG::vabsMeshLinkStop</a>();
  1533. <a name="l01454"></a>01454 <a class="code" href="namespaceTIMEALG.html#a47cb7df0449fa5c03c285d3e92d3aa2d">TIMEALG::vabsMtxCalcStart</a>();
  1534. <a name="l01455"></a>01455 <span class="preprocessor">#endif</span>
  1535. <a name="l01456"></a>01456 <span class="preprocessor"></span>
  1536. <a name="l01457"></a>01457 <span class="comment">// initialize the matrices</span>
  1537. <a name="l01458"></a>01458 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
  1538. <a name="l01459"></a>01459 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
  1539. <a name="l01460"></a>01460 HLow.size(rCnt,cCnt);
  1540. <a name="l01461"></a>01461 HLow=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  1541. <a name="l01462"></a>01462 DaeLow.size(rCnt,cCnt);
  1542. <a name="l01463"></a>01463 DaeLow=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  1543. <a name="l01464"></a>01464 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  1544. <a name="l01465"></a>01465 <span class="preprocessor"></span> PsiLow.size(rCnt,cCnt);
  1545. <a name="l01466"></a>01466 PsiLow=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  1546. <a name="l01467"></a>01467 <span class="preprocessor">#endif</span>
  1547. <a name="l01468"></a>01468 <span class="preprocessor"></span> cCnt=rCnt=DeeLow.size();
  1548. <a name="l01469"></a>01469 DeeLow=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  1549. <a name="l01470"></a>01470 cCnt=rCnt=ELow.size();
  1550. <a name="l01471"></a>01471 ELow=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  1551. <a name="l01472"></a>01472
  1552. <a name="l01473"></a>01473 <span class="comment">// Create the matrices</span>
  1553. <a name="l01474"></a>01474 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;elementsLow.size();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1554. <a name="l01475"></a>01475 {
  1555. <a name="l01476"></a>01476 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addE();
  1556. <a name="l01477"></a>01477 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addDee();
  1557. <a name="l01478"></a>01478 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addDae();
  1558. <a name="l01479"></a>01479 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addH();
  1559. <a name="l01480"></a>01480 }
  1560. <a name="l01481"></a>01481
  1561. <a name="l01482"></a>01482 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  1562. <a name="l01483"></a>01483 <span class="preprocessor"></span><span class="comment">// // create the Psi matrix</span>
  1563. <a name="l01484"></a>01484 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> one=1.0/sqrt(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>(ndCnt*3));
  1564. <a name="l01485"></a>01485 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;ndCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1565. <a name="l01486"></a>01486 {
  1566. <a name="l01487"></a>01487 PsiLow.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3,0)=one;
  1567. <a name="l01488"></a>01488 PsiLow.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1,1)=one;
  1568. <a name="l01489"></a>01489 PsiLow.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2,2)=one;
  1569. <a name="l01490"></a>01490 PsiLow.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1,3)=cxMeshLow-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).y;
  1570. <a name="l01491"></a>01491 PsiLow.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2,3)=-cxMeshLow-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).x;
  1571. <a name="l01492"></a>01492 }
  1572. <a name="l01493"></a>01493 <span class="preprocessor">#endif</span>
  1573. <a name="l01494"></a>01494 <span class="preprocessor"></span>
  1574. <a name="l01495"></a>01495 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  1575. <a name="l01496"></a>01496 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#abb3dfe1409ead9ab389b11970c1ed9bb">TIMEALG::vabsMtxCalcStop</a>();
  1576. <a name="l01497"></a>01497 <a class="code" href="namespaceTIMEALG.html#a64fad33a25509725cf641d6f6d9c6f63">TIMEALG::vabsNCalcStart</a>();
  1577. <a name="l01498"></a>01498 <span class="preprocessor">#endif</span>
  1578. <a name="l01499"></a>01499 <span class="preprocessor"></span>
  1579. <a name="l01500"></a>01500 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> PsiTHPsi=PsiLow.<a class="code" href="classmatrixRdWtStaticSqr__Data.html#a3db65c97e3f5de1fe52b5f0831e11176">T</a>()*HLow*PsiLow;
  1580. <a name="l01501"></a>01501 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> PsiTHPsi_Inverse=PsiTHPsi.<a class="code" href="classmatrixSqr.html#a991ebad568b11587f75c85cc3b8da408">inverse</a>();
  1581. <a name="l01502"></a>01502 NLow=(<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::identityMatrix</a>(rCnt)-HLow*PsiLow*PsiTHPsi_Inverse*PsiLow.<a class="code" href="classmatrixRdWtStaticSqr__Data.html#a3db65c97e3f5de1fe52b5f0831e11176">T</a>()).<a class="code" href="rotationMath_8cpp.html#a77ad922cc714adc5ebf10e36b2dd58f8">T</a>();
  1582. <a name="l01503"></a>01503
  1583. <a name="l01504"></a>01504 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  1584. <a name="l01505"></a>01505 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a294dfa8c6f83f364d880655b35f8531f">TIMEALG::vabsNCalcStop</a>();
  1585. <a name="l01506"></a>01506 <span class="preprocessor">#endif</span>
  1586. <a name="l01507"></a>01507 <span class="preprocessor"></span>
  1587. <a name="l01508"></a>01508 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; vStarSource=-NLow.T()*DaeLow;</span>
  1588. <a name="l01509"></a>01509 <span class="comment">// solver.A()=ELow;</span>
  1589. <a name="l01510"></a>01510 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; PsiDyad=PsiLow*PsiLow.T();</span>
  1590. <a name="l01511"></a>01511 <span class="comment">// dataType tracePsi=0.0;</span>
  1591. <a name="l01512"></a>01512 <span class="comment">// dataType traceE=0.0;</span>
  1592. <a name="l01513"></a>01513 <span class="comment">// for(unsigned long i=0;i&lt;rCnt;i++)</span>
  1593. <a name="l01514"></a>01514 <span class="comment">// {</span>
  1594. <a name="l01515"></a>01515 <span class="comment">// tracePsi+=PsiDyad.entry(i,i);</span>
  1595. <a name="l01516"></a>01516 <span class="comment">// traceE+=solver.A().entry(i,i);</span>
  1596. <a name="l01517"></a>01517 <span class="comment">// }</span>
  1597. <a name="l01518"></a>01518 <span class="comment">// solver.A()+=(traceE/tracePsi)*PsiDyad;</span>
  1598. <a name="l01519"></a>01519 <span class="comment">// solver.B()=vStarSource;</span>
  1599. <a name="l01520"></a>01520 <span class="comment">// solver.solve();</span>
  1600. <a name="l01521"></a>01521 <span class="comment">// </span>
  1601. <a name="l01522"></a>01522 <span class="comment">// vStar_adjointLow=solver.B();</span>
  1602. <a name="l01523"></a>01523
  1603. <a name="l01524"></a>01524
  1604. <a name="l01525"></a>01525 }
  1605. <a name="l01526"></a>01526
  1606. <a name="l01527"></a>01527 <span class="keywordtype">void</span> matrixGradients(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> step)
  1607. <a name="l01528"></a>01528 {
  1608. <a name="l01529"></a>01529 <span class="preprocessor">#ifdef TIME_ADJOINT_CALCULATION</span>
  1609. <a name="l01530"></a>01530 <span class="preprocessor"></span>
  1610. <a name="l01531"></a>01531 <a class="code" href="classTIMER_1_1timer.html">TIMER::timer</a> tmp;
  1611. <a name="l01532"></a>01532
  1612. <a name="l01533"></a>01533 tmp.<a class="code" href="classTIMER_1_1timer.html#ae4e539468242134aee07316d713d1200">start</a>();
  1613. <a name="l01534"></a>01534
  1614. <a name="l01535"></a>01535 <span class="preprocessor">#endif</span>
  1615. <a name="l01536"></a>01536 <span class="preprocessor"></span>
  1616. <a name="l01537"></a>01537 dDae_dy=(DaeHigh-DaeLow)*(1.0/(2.0*step));
  1617. <a name="l01538"></a>01538 <span class="comment">// dH_dy=(HHigh-HLow)*(1.0/(2.0*step));</span>
  1618. <a name="l01539"></a>01539 <span class="comment">// dPsi_dy=(PsiHigh-PsiLow)*(1.0/(2.0*step));</span>
  1619. <a name="l01540"></a>01540 dDee_dy=(DeeHigh-DeeLow)*(1.0/(2.0*step));
  1620. <a name="l01541"></a>01541 dE_dy=(EHigh-ELow)*(1.0/(2.0*step));
  1621. <a name="l01542"></a>01542 dN_dy=(NHigh-NLow)*(1.0/(2.0*step));
  1622. <a name="l01543"></a>01543
  1623. <a name="l01544"></a>01544 <span class="preprocessor">#ifdef TIME_ADJOINT_CALCULATION</span>
  1624. <a name="l01545"></a>01545 <span class="preprocessor"></span>
  1625. <a name="l01546"></a>01546 tmp.<a class="code" href="classTIMER_1_1timer.html#afc79eeb3c824bcffc5f4d351407dd32f">stop</a>();
  1626. <a name="l01547"></a>01547 std::cout &lt;&lt; <span class="stringliteral">&quot;Time for matrix gradients: &quot;</span> &lt;&lt; tmp.<a class="code" href="classTIMER_1_1timer.html#a438889a9c3d0ad0e730a3b54452a964c">microSeconds</a>() &lt;&lt; std::endl;
  1627. <a name="l01548"></a>01548
  1628. <a name="l01549"></a>01549 <span class="preprocessor">#endif</span>
  1629. <a name="l01550"></a>01550 <span class="preprocessor"></span>
  1630. <a name="l01551"></a>01551 }
  1631. <a name="l01552"></a>01552
  1632. <a name="l01553"></a>01553
  1633. <a name="l01554"></a>01554
  1634. <a name="l01555"></a>01555
  1635. <a name="l01556"></a>01556
  1636. <a name="l01557"></a>01557
  1637. <a name="l01558"></a>01558
  1638. <a name="l01559"></a>01559
  1639. <a name="l01560"></a>01560
  1640. <a name="l01561"></a>01561
  1641. <a name="l01562"></a>01562
  1642. <a name="l01563"></a>01563
  1643. <a name="l01564"></a>01564
  1644. <a name="l01565"></a>01565
  1645. <a name="l01566"></a>01566
  1646. <a name="l01567"></a>01567
  1647. <a name="l01568"></a>01568 <span class="keywordtype">void</span> calcGradient()
  1648. <a name="l01569"></a>01569 {
  1649. <a name="l01570"></a>01570
  1650. <a name="l01571"></a>01571 <span class="preprocessor">#ifdef TIME_ADJOINT_CALCULATION</span>
  1651. <a name="l01572"></a>01572 <span class="preprocessor"></span>
  1652. <a name="l01573"></a>01573 <a class="code" href="classTIMER_1_1timer.html">TIMER::timer</a> tmp;
  1653. <a name="l01574"></a>01574
  1654. <a name="l01575"></a>01575 tmp.<a class="code" href="classTIMER_1_1timer.html#ae4e539468242134aee07316d713d1200">start</a>();
  1655. <a name="l01576"></a>01576
  1656. <a name="l01577"></a>01577 <span class="preprocessor">#endif</span>
  1657. <a name="l01578"></a>01578 <span class="preprocessor"></span>
  1658. <a name="l01579"></a>01579 <span class="comment">// unsigned long rCnt;</span>
  1659. <a name="l01580"></a>01580 <span class="comment">// unsigned long cCnt;</span>
  1660. <a name="l01581"></a>01581 <span class="comment">// </span>
  1661. <a name="l01582"></a>01582 <span class="comment">// H.size(rCnt,cCnt);</span>
  1662. <a name="l01583"></a>01583
  1663. <a name="l01584"></a>01584 <span class="comment">// matrixRdWtStaticSqr_Data&lt;dataType,4&gt; inv=Psi.T()*H*Psi;</span>
  1664. <a name="l01585"></a>01585 <span class="comment">// inv=inv.inverse();</span>
  1665. <a name="l01586"></a>01586 <span class="comment">// </span>
  1666. <a name="l01587"></a>01587 <span class="comment">// tmp.stop();</span>
  1667. <a name="l01588"></a>01588 <span class="comment">// std::cout &lt;&lt; &quot;Time for inverse: &quot; &lt;&lt; tmp.microSeconds() &lt;&lt; std::endl;</span>
  1668. <a name="l01589"></a>01589 <span class="comment">// tmp.reset();</span>
  1669. <a name="l01590"></a>01590 <span class="comment">// tmp.start();</span>
  1670. <a name="l01591"></a>01591 <span class="comment">// </span>
  1671. <a name="l01592"></a>01592 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; outerProduct=Psi*inv*Psi.T();</span>
  1672. <a name="l01593"></a>01593 <span class="comment">// </span>
  1673. <a name="l01594"></a>01594 <span class="comment">// tmp.stop();</span>
  1674. <a name="l01595"></a>01595 <span class="comment">// std::cout &lt;&lt; &quot;Time for outer product: &quot; &lt;&lt; tmp.microSeconds() &lt;&lt; std::endl;</span>
  1675. <a name="l01596"></a>01596 <span class="comment">// tmp.reset();</span>
  1676. <a name="l01597"></a>01597 <span class="comment">// tmp.start();</span>
  1677. <a name="l01598"></a>01598 <span class="comment">// </span>
  1678. <a name="l01599"></a>01599 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; N=-outerProduct*H;</span>
  1679. <a name="l01600"></a>01600 <span class="comment">// </span>
  1680. <a name="l01601"></a>01601 <span class="comment">// tmp.stop();</span>
  1681. <a name="l01602"></a>01602 <span class="comment">// std::cout &lt;&lt; &quot;Time for N=-outerProduct*H: &quot; &lt;&lt; tmp.microSeconds() &lt;&lt; std::endl;</span>
  1682. <a name="l01603"></a>01603 <span class="comment">// tmp.reset();</span>
  1683. <a name="l01604"></a>01604 <span class="comment">// tmp.start();</span>
  1684. <a name="l01605"></a>01605 <span class="comment">// </span>
  1685. <a name="l01606"></a>01606 <span class="comment">// for(unsigned long i=0;i&lt;rCnt;i++)</span>
  1686. <a name="l01607"></a>01607 <span class="comment">// N.entry(i,i)+=1.0;</span>
  1687. <a name="l01608"></a>01608 <span class="comment">// // matrixRdWtSz_Data&lt;dataType&gt; N=matrix&lt;dataType&gt;::identityMatrix(rCnt)-outerProduct*H;</span>
  1688. <a name="l01609"></a>01609 <span class="comment">// </span>
  1689. <a name="l01610"></a>01610 <span class="comment">// tmp.stop();</span>
  1690. <a name="l01611"></a>01611 <span class="comment">// std::cout &lt;&lt; &quot;Time for N+I: &quot; &lt;&lt; tmp.microSeconds() &lt;&lt; std::endl;</span>
  1691. <a name="l01612"></a>01612 <span class="comment">// tmp.reset();</span>
  1692. <a name="l01613"></a>01613 <span class="comment">// tmp.start();</span>
  1693. <a name="l01614"></a>01614 <span class="comment">// </span>
  1694. <a name="l01615"></a>01615 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; innerPrime=dPsi_dy.T()*H*Psi;</span>
  1695. <a name="l01616"></a>01616 <span class="comment">// innerPrime=innerPrime+innerPrime.T();</span>
  1696. <a name="l01617"></a>01617 <span class="comment">// </span>
  1697. <a name="l01618"></a>01618 <span class="comment">// tmp.stop();</span>
  1698. <a name="l01619"></a>01619 <span class="comment">// std::cout &lt;&lt; &quot;Time for innerPrime: &quot; &lt;&lt; tmp.microSeconds() &lt;&lt; std::endl;</span>
  1699. <a name="l01620"></a>01620 <span class="comment">// tmp.reset();</span>
  1700. <a name="l01621"></a>01621 <span class="comment">// tmp.start();</span>
  1701. <a name="l01622"></a>01622 <span class="comment">// </span>
  1702. <a name="l01623"></a>01623 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; outerPrime=dPsi_dy*inv*Psi.T();</span>
  1703. <a name="l01624"></a>01624 <span class="comment">// outerPrime=outerPrime+outerPrime.T();</span>
  1704. <a name="l01625"></a>01625 <span class="comment">// </span>
  1705. <a name="l01626"></a>01626 <span class="comment">// tmp.stop();</span>
  1706. <a name="l01627"></a>01627 <span class="comment">// std::cout &lt;&lt; &quot;Time for outerPrime: &quot; &lt;&lt; tmp.microSeconds() &lt;&lt; std::endl;</span>
  1707. <a name="l01628"></a>01628 <span class="comment">// tmp.reset();</span>
  1708. <a name="l01629"></a>01629 <span class="comment">// tmp.start();</span>
  1709. <a name="l01630"></a>01630 <span class="comment">// </span>
  1710. <a name="l01631"></a>01631 <span class="comment">// dN_dy.T()=</span>
  1711. <a name="l01632"></a>01632 <span class="comment">// H*(Psi*inv*(innerPrime+Psi.T()*dH_dy*Psi)*inv*Psi.T()-outerPrime)-dH_dy*outerProduct;</span>
  1712. <a name="l01633"></a>01633 <span class="comment">// </span>
  1713. <a name="l01634"></a>01634 <span class="comment">// // dN_dy=</span>
  1714. <a name="l01635"></a>01635 <span class="comment">// // Psi*inv*(dPsi_dy.T()*H*Psi+Psi.T()*dH_dy*Psi+Psi.T()*H*dPsi_dy)*inv*Psi.T()*H</span>
  1715. <a name="l01636"></a>01636 <span class="comment">// // -(dPsi_dy*inv*Psi.T()*H+Psi*inv*dPsi_dy.T()*H+Psi*inv*Psi.T()*dH_dy);</span>
  1716. <a name="l01637"></a>01637 <span class="comment">// </span>
  1717. <a name="l01638"></a>01638 <span class="comment">// tmp.stop();</span>
  1718. <a name="l01639"></a>01639 <span class="comment">// std::cout &lt;&lt; &quot;Time for dN_dy: &quot; &lt;&lt; tmp.microSeconds() &lt;&lt; std::endl;</span>
  1719. <a name="l01640"></a>01640 <span class="comment">// tmp.reset();</span>
  1720. <a name="l01641"></a>01641 <span class="comment">// tmp.start();</span>
  1721. <a name="l01642"></a>01642
  1722. <a name="l01643"></a>01643 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> crossTerm=Dae.T()*dN_dy*vStar_adjoint+dDae_dy.T()*N*vStar_adjoint;
  1723. <a name="l01644"></a>01644 crossTerm=crossTerm+crossTerm.<a class="code" href="classmatrixRdWtSz__Data.html#ae1c7af296930751d1ceaf95429e9bb57">T</a>();
  1724. <a name="l01645"></a>01645
  1725. <a name="l01646"></a>01646 <span class="preprocessor">#ifdef TIME_ADJOINT_CALCULATION</span>
  1726. <a name="l01647"></a>01647 <span class="preprocessor"></span>
  1727. <a name="l01648"></a>01648 tmp.<a class="code" href="classTIMER_1_1timer.html#afc79eeb3c824bcffc5f4d351407dd32f">stop</a>();
  1728. <a name="l01649"></a>01649 std::cout &lt;&lt; <span class="stringliteral">&quot;Time for cross-term: &quot;</span> &lt;&lt; tmp.<a class="code" href="classTIMER_1_1timer.html#a438889a9c3d0ad0e730a3b54452a964c">microSeconds</a>() &lt;&lt; std::endl;
  1729. <a name="l01650"></a>01650 tmp.<a class="code" href="classTIMER_1_1timer.html#aa557185a3e966e14014b76e40727784f">reset</a>();
  1730. <a name="l01651"></a>01651 tmp.<a class="code" href="classTIMER_1_1timer.html#ae4e539468242134aee07316d713d1200">start</a>();
  1731. <a name="l01652"></a>01652
  1732. <a name="l01653"></a>01653 <span class="preprocessor">#endif</span>
  1733. <a name="l01654"></a>01654 <span class="preprocessor"></span> dC_dy=vStar_adjoint.T()*dE_dy*vStar_adjoint+dDee_dy+crossTerm;
  1734. <a name="l01655"></a>01655
  1735. <a name="l01656"></a>01656 <span class="comment">// dC_dy=</span>
  1736. <a name="l01657"></a>01657 <span class="comment">// (Dae.T()*dN_dy*vStar_adjoint+dDae_dy.T()*N*vStar_adjoint+dDee_dy) // this is dC/dy</span>
  1737. <a name="l01658"></a>01658 <span class="comment">// + vStar_adjoint.T()*(dE_dy*vStar_adjoint+dN_dy.T()*Dae+N.T()*dDae_dy); // this is psi * dR/dy</span>
  1738. <a name="l01659"></a>01659
  1739. <a name="l01660"></a>01660 <span class="preprocessor">#ifdef TIME_ADJOINT_CALCULATION</span>
  1740. <a name="l01661"></a>01661 <span class="preprocessor"></span>
  1741. <a name="l01662"></a>01662 tmp.<a class="code" href="classTIMER_1_1timer.html#afc79eeb3c824bcffc5f4d351407dd32f">stop</a>();
  1742. <a name="l01663"></a>01663 std::cout &lt;&lt; <span class="stringliteral">&quot;Time for dC_dy: &quot;</span> &lt;&lt; tmp.<a class="code" href="classTIMER_1_1timer.html#a438889a9c3d0ad0e730a3b54452a964c">microSeconds</a>() &lt;&lt; std::endl;
  1743. <a name="l01664"></a>01664 tmp.<a class="code" href="classTIMER_1_1timer.html#aa557185a3e966e14014b76e40727784f">reset</a>();
  1744. <a name="l01665"></a>01665 tmp.<a class="code" href="classTIMER_1_1timer.html#ae4e539468242134aee07316d713d1200">start</a>();
  1745. <a name="l01666"></a>01666
  1746. <a name="l01667"></a>01667 <span class="preprocessor">#endif</span>
  1747. <a name="l01668"></a>01668 <span class="preprocessor"></span>
  1748. <a name="l01669"></a>01669 }
  1749. <a name="l01670"></a>01670
  1750. <a name="l01671"></a>01671 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; getFailAdjointSource(matrix&lt;dataType&gt;&amp; Gamma_a)</span>
  1751. <a name="l01672"></a>01672 <span class="comment">// {</span>
  1752. <a name="l01673"></a>01673 <span class="comment">// unsigned long rCnt;</span>
  1753. <a name="l01674"></a>01674 <span class="comment">// unsigned long cCnt;</span>
  1754. <a name="l01675"></a>01675 <span class="comment">// </span>
  1755. <a name="l01676"></a>01676 <span class="comment">// H.size(rCnt,cCnt);</span>
  1756. <a name="l01677"></a>01677 <span class="comment">// cCnt=6;</span>
  1757. <a name="l01678"></a>01678 <span class="comment">// </span>
  1758. <a name="l01679"></a>01679 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; mtx(rCnt,cCnt);</span>
  1759. <a name="l01680"></a>01680 <span class="comment">// </span>
  1760. <a name="l01681"></a>01681 <span class="comment">// for(unsigned long i=0;i&lt;rCnt;i++)</span>
  1761. <a name="l01682"></a>01682 <span class="comment">// {</span>
  1762. <a name="l01683"></a>01683 <span class="comment">// for(unsigned long j=0;j&lt;cCnt;j++)</span>
  1763. <a name="l01684"></a>01684 <span class="comment">// {</span>
  1764. <a name="l01685"></a>01685 <span class="comment">// mtx.entry(i,j)=0.0;</span>
  1765. <a name="l01686"></a>01686 <span class="comment">// }</span>
  1766. <a name="l01687"></a>01687 <span class="comment">// }</span>
  1767. <a name="l01688"></a>01688 <span class="comment">// </span>
  1768. <a name="l01689"></a>01689 <span class="comment">// for(unsigned long i=0;i&lt;4;i++)</span>
  1769. <a name="l01690"></a>01690 <span class="comment">// {</span>
  1770. <a name="l01691"></a>01691 <span class="comment">// for(unsigned long j=0;j&lt;3;j++)</span>
  1771. <a name="l01692"></a>01692 <span class="comment">// {</span>
  1772. <a name="l01693"></a>01693 <span class="comment">// unsigned long col=i*3+j;</span>
  1773. <a name="l01694"></a>01694 <span class="comment">// unsigned long row=cxMesh-&gt;getElement(maxElm).nodeHndl[i].nodeID*3+j;</span>
  1774. <a name="l01695"></a>01695 <span class="comment">// for(unsigned long k=0;k&lt;cCnt;k++)</span>
  1775. <a name="l01696"></a>01696 <span class="comment">// mtx.entry(row,k)=Gamma_a.entry(k,col);</span>
  1776. <a name="l01697"></a>01697 <span class="comment">// }</span>
  1777. <a name="l01698"></a>01698 <span class="comment">// }</span>
  1778. <a name="l01699"></a>01699 <span class="comment">// </span>
  1779. <a name="l01700"></a>01700 <span class="comment">// mtx=N.T()*mtx;</span>
  1780. <a name="l01701"></a>01701 <span class="comment">// </span>
  1781. <a name="l01702"></a>01702 <span class="comment">// return mtx;</span>
  1782. <a name="l01703"></a>01703 <span class="comment">// }</span>
  1783. <a name="l01704"></a>01704
  1784. <a name="l01705"></a>01705 <span class="keywordtype">void</span> getFailAdjoint(<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;</a>&amp; Gamma_a)
  1785. <a name="l01706"></a>01706 {
  1786. <a name="l01707"></a>01707 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
  1787. <a name="l01708"></a>01708 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
  1788. <a name="l01709"></a>01709
  1789. <a name="l01710"></a>01710 H.size(rCnt,cCnt);
  1790. <a name="l01711"></a>01711 cCnt=6;
  1791. <a name="l01712"></a>01712
  1792. <a name="l01713"></a>01713 <a class="code" href="classmatrixMatrixSolver.html">matrixMatrixSolver</a> slvr(rCnt,cCnt);
  1793. <a name="l01714"></a>01714 slvr.<a class="code" href="classmatrixMatrixSolver.html#a06093225d93b903dc93612fb23ddadf2">A</a>()=ETDyad;
  1794. <a name="l01715"></a>01715
  1795. <a name="l01716"></a>01716 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;rCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1796. <a name="l01717"></a>01717 {
  1797. <a name="l01718"></a>01718 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;cCnt;j++)
  1798. <a name="l01719"></a>01719 {
  1799. <a name="l01720"></a>01720 slvr.<a class="code" href="classmatrixMatrixSolver.html#a3d4eb5a5c9b8a11961f29cf94c0c64d7">B</a>().<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>,j)=0.0;
  1800. <a name="l01721"></a>01721 }
  1801. <a name="l01722"></a>01722 }
  1802. <a name="l01723"></a>01723
  1803. <a name="l01724"></a>01724 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1804. <a name="l01725"></a>01725 {
  1805. <a name="l01726"></a>01726 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;3;j++)
  1806. <a name="l01727"></a>01727 {
  1807. <a name="l01728"></a>01728 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> col=<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+j;
  1808. <a name="l01729"></a>01729 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> row=cxMesh-&gt;getElement(maxElm).nodeHndl[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].nodeID*3+j;
  1809. <a name="l01730"></a>01730 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k&lt;cCnt;k++)
  1810. <a name="l01731"></a>01731 slvr.<a class="code" href="classmatrixMatrixSolver.html#a3d4eb5a5c9b8a11961f29cf94c0c64d7">B</a>().<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(row,k)=Gamma_a.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(k,col);
  1811. <a name="l01732"></a>01732 }
  1812. <a name="l01733"></a>01733 }
  1813. <a name="l01734"></a>01734
  1814. <a name="l01735"></a>01735 <span class="comment">// matrixRdWtStaticSqr_Data&lt;dataType,4&gt; PsiTHPsi=Psi.T()*H*Psi;</span>
  1815. <a name="l01736"></a>01736 <span class="comment">// matrixRdWtStaticSqr_Data&lt;dataType,4&gt; PsiTHPsi_Inverse=PsiTHPsi.inverse();</span>
  1816. <a name="l01737"></a>01737 <span class="comment">// matrixRdWtSzSqr_Data&lt;dataType&gt; prePostMatrix=matrix&lt;dataType&gt;::identityMatrix(rCnt)-H*Psi*PsiTHPsi_Inverse*Psi.T();</span>
  1817. <a name="l01738"></a>01738 <span class="comment">// N=prePostMatrix.T();</span>
  1818. <a name="l01739"></a>01739
  1819. <a name="l01740"></a>01740 <span class="comment">// std::cout &lt;&lt; &quot;This is N&quot; &lt;&lt; std::endl;</span>
  1820. <a name="l01741"></a>01741 <span class="comment">// printMatrix(N);</span>
  1821. <a name="l01742"></a>01742
  1822. <a name="l01743"></a>01743 <span class="comment">// std::cout &lt;&lt; &quot;This is ET&quot; &lt;&lt; std::endl;</span>
  1823. <a name="l01744"></a>01744 <span class="comment">// printMatrix(ET);</span>
  1824. <a name="l01745"></a>01745
  1825. <a name="l01746"></a>01746 <span class="comment">// std::cout &lt;&lt; &quot;This is gamma&quot; &lt;&lt; std::endl;</span>
  1826. <a name="l01747"></a>01747 <span class="comment">// printMatrix(Gamma_a);</span>
  1827. <a name="l01748"></a>01748
  1828. <a name="l01749"></a>01749 <span class="comment">// std::cout &lt;&lt; &quot;This is nulled source&quot; &lt;&lt; std::endl;</span>
  1829. <a name="l01750"></a>01750 <span class="comment">// printMatrix(slvr.B());</span>
  1830. <a name="l01751"></a>01751
  1831. <a name="l01752"></a>01752 <span class="comment">// std::cout &lt;&lt; &quot;This is N.T()*B&quot; &lt;&lt; std::endl;</span>
  1832. <a name="l01753"></a>01753 <span class="comment">// printMatrix(N.T()*slvr.B());</span>
  1833. <a name="l01754"></a>01754
  1834. <a name="l01755"></a>01755
  1835. <a name="l01756"></a>01756 <span class="comment">// vabsSvdSolver svdSolve(rCnt,rCnt);</span>
  1836. <a name="l01757"></a>01757
  1837. <a name="l01758"></a>01758 <span class="comment">// unsigned long a,b;</span>
  1838. <a name="l01759"></a>01759 <span class="comment">// </span>
  1839. <a name="l01760"></a>01760 <span class="comment">// std::cout &lt;&lt; &quot;Hey 1&quot; &lt;&lt; std::endl;</span>
  1840. <a name="l01761"></a>01761 <span class="comment">// std::cout &lt;&lt; rCnt &lt;&lt; &quot; &quot; &lt;&lt; cCnt &lt;&lt; std::endl;</span>
  1841. <a name="l01762"></a>01762 <span class="comment">// svdSolve.A().size(a,b);</span>
  1842. <a name="l01763"></a>01763 <span class="comment">// std::cout &lt;&lt; a &lt;&lt; &quot; &quot; &lt;&lt; b &lt;&lt; std::endl;</span>
  1843. <a name="l01764"></a>01764 <span class="comment">// a=b=ET.size();</span>
  1844. <a name="l01765"></a>01765 <span class="comment">// std::cout &lt;&lt; a &lt;&lt; &quot; &quot; &lt;&lt; b &lt;&lt; std::endl;</span>
  1845. <a name="l01766"></a>01766 <span class="comment">// svdSolve.A()=ET;</span>
  1846. <a name="l01767"></a>01767 <span class="comment">// std::cout &lt;&lt; &quot;Hey 2&quot; &lt;&lt; std::endl;</span>
  1847. <a name="l01768"></a>01768 <span class="comment">// svdSolve.solve();</span>
  1848. <a name="l01769"></a>01769 <span class="comment">// </span>
  1849. <a name="l01770"></a>01770 <span class="comment">// std::cout &lt;&lt; &quot;Hey 3&quot; &lt;&lt; std::endl;</span>
  1850. <a name="l01771"></a>01771
  1851. <a name="l01772"></a>01772 slvr.<a class="code" href="classmatrixMatrixSolver.html#a3d4eb5a5c9b8a11961f29cf94c0c64d7">B</a>()=N.<a class="code" href="classmatrixRdWt.html#a14bd0b98175a58111154220b59f89bdb">T</a>()*slvr.<a class="code" href="classmatrixMatrixSolver.html#a3d4eb5a5c9b8a11961f29cf94c0c64d7">B</a>();
  1852. <a name="l01773"></a>01773
  1853. <a name="l01774"></a>01774 <span class="comment">// std::cout &lt;&lt; &quot;Hey 4&quot; &lt;&lt; std::endl;</span>
  1854. <a name="l01775"></a>01775 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; src=slvr.B();</span>
  1855. <a name="l01776"></a>01776 <span class="comment">// std::cout &lt;&lt; &quot;Hey 4&quot; &lt;&lt; std::endl;</span>
  1856. <a name="l01777"></a>01777
  1857. <a name="l01778"></a>01778 <span class="comment">// matrixRdWtSz_Data&lt;double&gt; src=slvr.B();</span>
  1858. <a name="l01779"></a>01779
  1859. <a name="l01780"></a>01780 <span class="comment">// std::cout &lt;&lt; &quot;Here is the ET projection&quot; &lt;&lt; std::endl;</span>
  1860. <a name="l01781"></a>01781 <span class="comment">// printMatrix(Psi.T()*ET);</span>
  1861. <a name="l01782"></a>01782
  1862. <a name="l01783"></a>01783 <span class="comment">// std::cout &lt;&lt; &quot;Here is the source projection&quot; &lt;&lt; std::endl;</span>
  1863. <a name="l01784"></a>01784 <span class="comment">// printMatrix(Psi.T()*slvr.B());</span>
  1864. <a name="l01785"></a>01785
  1865. <a name="l01786"></a>01786 <span class="comment">// std::cout &lt;&lt; &quot;Here is the source&quot; &lt;&lt; std::endl;</span>
  1866. <a name="l01787"></a>01787 <span class="comment">// printMatrix(slvr.B());</span>
  1867. <a name="l01788"></a>01788
  1868. <a name="l01789"></a>01789 slvr.<a class="code" href="classmatrixMatrixSolver.html#a91ec4089eb228ec89bbe390eeeb899f4">solve</a>();
  1869. <a name="l01790"></a>01790
  1870. <a name="l01791"></a>01791 <span class="comment">// std::cout &lt;&lt; &quot;Hey 5&quot; &lt;&lt; std::endl;</span>
  1871. <a name="l01792"></a>01792 <span class="comment">// </span>
  1872. <a name="l01793"></a>01793 <span class="comment">// std::cout &lt;&lt; &quot;Here is the difference between the svd and the solve&quot; &lt;&lt; std::endl;</span>
  1873. <a name="l01794"></a>01794 <span class="comment">// printMatrix(svdSolve.inverse()*src-slvr.B());</span>
  1874. <a name="l01795"></a>01795 <span class="comment">// </span>
  1875. <a name="l01796"></a>01796 <span class="comment">// std::cout &lt;&lt; &quot;Hey 6&quot; &lt;&lt; std::endl;</span>
  1876. <a name="l01797"></a>01797 <span class="comment">// </span>
  1877. <a name="l01798"></a>01798 <span class="comment">// std::cout &lt;&lt; &quot;Here is the dyad solution&quot; &lt;&lt; std::endl;</span>
  1878. <a name="l01799"></a>01799 <span class="comment">// printMatrix(slvr.B());</span>
  1879. <a name="l01800"></a>01800 <span class="comment">// </span>
  1880. <a name="l01801"></a>01801 <span class="comment">// std::cout &lt;&lt; &quot;Hey 7&quot; &lt;&lt; std::endl;</span>
  1881. <a name="l01802"></a>01802 <span class="comment">// </span>
  1882. <a name="l01803"></a>01803 <span class="comment">// std::cout &lt;&lt; &quot;Here is the svd solution&quot; &lt;&lt; std::endl;</span>
  1883. <a name="l01804"></a>01804 <span class="comment">// printMatrix(svdSolve.inverse()*src);</span>
  1884. <a name="l01805"></a>01805 <span class="comment">// </span>
  1885. <a name="l01806"></a>01806 <span class="comment">// std::cout &lt;&lt; &quot;Hey 8&quot; &lt;&lt; std::endl;</span>
  1886. <a name="l01807"></a>01807
  1887. <a name="l01808"></a>01808 <span class="comment">// std::cout &lt;&lt; &quot;Here is the accuracy&quot; &lt;&lt; std::endl;</span>
  1888. <a name="l01809"></a>01809 <span class="comment">// printMatrix(ET*slvr.B()-src);</span>
  1889. <a name="l01810"></a>01810
  1890. <a name="l01811"></a>01811 <span class="comment">// std::cout &lt;&lt; &quot;Here is the solution&quot; &lt;&lt; std::endl;</span>
  1891. <a name="l01812"></a>01812 <span class="comment">// printMatrix(slvr.B());</span>
  1892. <a name="l01813"></a>01813
  1893. <a name="l01814"></a>01814 adjointFail=N*slvr.<a class="code" href="classmatrixMatrixSolver.html#a3d4eb5a5c9b8a11961f29cf94c0c64d7">B</a>();
  1894. <a name="l01815"></a>01815
  1895. <a name="l01816"></a>01816 <span class="comment">// std::cout &lt;&lt; &quot;Here is the adjointFail projection&quot; &lt;&lt; std::endl;</span>
  1896. <a name="l01817"></a>01817 <span class="comment">// printMatrix(Psi.T()*adjointFail);</span>
  1897. <a name="l01818"></a>01818
  1898. <a name="l01819"></a>01819 <span class="comment">// std::cout &lt;&lt; &quot;Here is the adjointFail&quot; &lt;&lt; std::endl;</span>
  1899. <a name="l01820"></a>01820 <span class="comment">// printMatrix(adjointFail);</span>
  1900. <a name="l01821"></a>01821 }
  1901. <a name="l01822"></a>01822
  1902. <a name="l01823"></a>01823 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> elementPermuation(<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;</a>&amp; mtx)
  1903. <a name="l01824"></a>01824 {
  1904. <a name="l01825"></a>01825 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt, cCnt;
  1905. <a name="l01826"></a>01826 mtx.<a class="code" href="classmatrix.html#a3a26f3543df8cff3e662e949e8b9234d">size</a>(rCnt,cCnt);
  1906. <a name="l01827"></a>01827
  1907. <a name="l01828"></a>01828 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> retVal(12,cCnt);
  1908. <a name="l01829"></a>01829
  1909. <a name="l01830"></a>01830 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1910. <a name="l01831"></a>01831 {
  1911. <a name="l01832"></a>01832 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;3;j++)
  1912. <a name="l01833"></a>01833 {
  1913. <a name="l01834"></a>01834 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> outRow=<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+j;
  1914. <a name="l01835"></a>01835 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> inRow=cxMesh-&gt;getElement(maxElm).nodeHndl[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].nodeID*3+j;
  1915. <a name="l01836"></a>01836 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k&lt;cCnt;k++)
  1916. <a name="l01837"></a>01837 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(outRow,k)=mtx.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(inRow,k);
  1917. <a name="l01838"></a>01838 }
  1918. <a name="l01839"></a>01839 }
  1919. <a name="l01840"></a>01840 <span class="keywordflow">return</span> retVal;
  1920. <a name="l01841"></a>01841 }
  1921. <a name="l01842"></a>01842
  1922. <a name="l01843"></a>01843 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; r()</span>
  1923. <a name="l01844"></a>01844 <span class="comment">// {</span>
  1924. <a name="l01845"></a>01845 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; retVal;</span>
  1925. <a name="l01846"></a>01846 <span class="comment">// retVal=ET.T()*vStar_adjoint+N.T()*Dae;</span>
  1926. <a name="l01847"></a>01847 <span class="comment">// return retVal;</span>
  1927. <a name="l01848"></a>01848 <span class="comment">// }</span>
  1928. <a name="l01849"></a>01849 <span class="comment">// </span>
  1929. <a name="l01850"></a>01850 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; rHigh()</span>
  1930. <a name="l01851"></a>01851 <span class="comment">// {</span>
  1931. <a name="l01852"></a>01852 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; retVal;</span>
  1932. <a name="l01853"></a>01853 <span class="comment">// retVal=EHigh*vStar_adjoint+NHigh.T()*DaeHigh;</span>
  1933. <a name="l01854"></a>01854 <span class="comment">// return retVal;</span>
  1934. <a name="l01855"></a>01855 <span class="comment">// }</span>
  1935. <a name="l01856"></a>01856 <span class="comment">// </span>
  1936. <a name="l01857"></a>01857 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; rLow()</span>
  1937. <a name="l01858"></a>01858 <span class="comment">// {</span>
  1938. <a name="l01859"></a>01859 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; retVal;</span>
  1939. <a name="l01860"></a>01860 <span class="comment">// retVal=ELow*vStar_adjoint+NLow.T()*DaeLow;</span>
  1940. <a name="l01861"></a>01861 <span class="comment">// return retVal;</span>
  1941. <a name="l01862"></a>01862 <span class="comment">// }</span>
  1942. <a name="l01863"></a>01863
  1943. <a name="l01864"></a>01864
  1944. <a name="l01865"></a>01865
  1945. <a name="l01866"></a>01866
  1946. <a name="l01867"></a>01867
  1947. <a name="l01868"></a>01868
  1948. <a name="l01869"></a>01869
  1949. <a name="l01870"></a>01870
  1950. <a name="l01871"></a>01871
  1951. <a name="l01872"></a>01872
  1952. <a name="l01873"></a>01873
  1953. <a name="l01874"></a>01874
  1954. <a name="l01875"></a>01875
  1955. <a name="l01876"></a>01876
  1956. <a name="l01877"></a>01877
  1957. <a name="l01878"></a>01878
  1958. <a name="l01879"></a>01879
  1959. <a name="l01880"></a>01880
  1960. <a name="l01881"></a>01881
  1961. <a name="l01882"></a>01882
  1962. <a name="l01883"></a>01883
  1963. <a name="l01884"></a>01884 <span class="keyword">private</span>:
  1964. <a name="l01885"></a>01885
  1965. <a name="l01886"></a>01886 <span class="preprocessor">#endif</span>
  1966. <a name="l01887"></a>01887 <span class="preprocessor"></span>
  1967. <a name="l01888"></a>01888 <span class="keywordtype">void</span> buildMatrix()
  1968. <a name="l01889"></a>01889 {
  1969. <a name="l01890"></a>01890 <span class="keywordflow">if</span>(cxMesh==NULL)
  1970. <a name="l01891"></a>01891 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::buildMatrix(): The mesh has not been specified&quot;</span>);
  1971. <a name="l01892"></a>01892
  1972. <a name="l01893"></a>01893 <span class="comment">// retrieve the size</span>
  1973. <a name="l01894"></a>01894 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> ndCnt;
  1974. <a name="l01895"></a>01895 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> elmCnt;
  1975. <a name="l01896"></a>01896 cxMesh-&gt;size(ndCnt,elmCnt);
  1976. <a name="l01897"></a>01897
  1977. <a name="l01898"></a>01898 <span class="comment">// size all the matrices</span>
  1978. <a name="l01899"></a>01899 <span class="preprocessor">#ifdef SVD_BASED_VABS_SOLUTION</span>
  1979. <a name="l01900"></a>01900 <span class="preprocessor"></span> solver.<a class="code" href="classmatrixMatrixSolver.html#ae0588f3a74c5876048a02226fc49c9af">resize</a>(ndCnt*3,ndCnt*3);
  1980. <a name="l01901"></a>01901 <span class="preprocessor">#else</span>
  1981. <a name="l01902"></a>01902 <span class="preprocessor"></span> solver.<a class="code" href="classmatrixMatrixSolver.html#ae0588f3a74c5876048a02226fc49c9af">resize</a>(ndCnt*3,4);
  1982. <a name="l01903"></a>01903 <span class="preprocessor">#endif</span>
  1983. <a name="l01904"></a>01904 <span class="preprocessor"></span> Dae.resize(ndCnt*3,4);
  1984. <a name="l01905"></a>01905 H.resize(ndCnt*3,ndCnt*3);
  1985. <a name="l01906"></a>01906 v.resize(ndCnt*3,4);
  1986. <a name="l01907"></a>01907 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  1987. <a name="l01908"></a>01908 <span class="preprocessor"></span> Psi.resize(ndCnt*3,4);
  1988. <a name="l01909"></a>01909 <span class="preprocessor">#endif</span>
  1989. <a name="l01910"></a>01910 <span class="preprocessor"></span>
  1990. <a name="l01911"></a>01911 <span class="comment">// create all the nodes and elements</span>
  1991. <a name="l01912"></a>01912 commonNodes.resize(ndCnt);
  1992. <a name="l01913"></a>01913 elementNodes.resize(ndCnt);
  1993. <a name="l01914"></a>01914 elements.resize(elmCnt);
  1994. <a name="l01915"></a>01915 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;ndCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  1995. <a name="l01916"></a>01916 {
  1996. <a name="l01917"></a>01917 commonNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setX(cxMesh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).x);
  1997. <a name="l01918"></a>01918 commonNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setY(cxMesh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).y);
  1998. <a name="l01919"></a>01919 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;3;j++)
  1999. <a name="l01920"></a>01920 {
  2000. <a name="l01921"></a>01921 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k&lt;4;k++)
  2001. <a name="l01922"></a>01922 commonNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setWarping(j,k,&amp;(v.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+j,k)));
  2002. <a name="l01923"></a>01923 }
  2003. <a name="l01924"></a>01924 elementNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].resize(cxMesh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData.size());
  2004. <a name="l01925"></a>01925 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;elementNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].size();j++)
  2005. <a name="l01926"></a>01926 elementNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>][j].setH(cxMesh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData[j].h_over_H).setAng(cxMesh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData[j].angle).setCommon(&amp;(commonNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]));
  2006. <a name="l01927"></a>01927 }
  2007. <a name="l01928"></a>01928 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;elmCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  2008. <a name="l01929"></a>01929 {
  2009. <a name="l01930"></a>01930 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();j++)
  2010. <a name="l01931"></a>01931 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setNode(j,&amp;(elementNodes[cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID][cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].dataID]));
  2011. <a name="l01932"></a>01932 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setMatl(cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).material);
  2012. <a name="l01933"></a>01933 }
  2013. <a name="l01934"></a>01934
  2014. <a name="l01935"></a>01935 <span class="comment">// set all the matrices in the elements</span>
  2015. <a name="l01936"></a>01936 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;elmCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  2016. <a name="l01937"></a>01937 {
  2017. <a name="l01938"></a>01938 <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData&lt;dataType&gt;</a>* EMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData&lt;dataType&gt;</a>(cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3);
  2018. <a name="l01939"></a>01939 <span class="keywordflow">if</span>(EMatrix==NULL)
  2019. <a name="l01940"></a>01940 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::buildMatrix(): Failed to allocate memory for EMatrix&quot;</span>);
  2020. <a name="l01941"></a>01941 <a class="code" href="classmatrixRdWt__pData.html">matrixRdWt_pData&lt;dataType&gt;</a>* DaeMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWt__pData.html">matrixRdWt_pData&lt;dataType&gt;</a>(cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3,4);
  2021. <a name="l01942"></a>01942 <span class="keywordflow">if</span>(DaeMatrix==NULL)
  2022. <a name="l01943"></a>01943 {
  2023. <a name="l01944"></a>01944 <span class="keyword">delete</span> EMatrix;
  2024. <a name="l01945"></a>01945 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::buildMatrix(): Failed to allocate memory for DaeMatrix&quot;</span>);
  2025. <a name="l01946"></a>01946 }
  2026. <a name="l01947"></a>01947 <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData&lt;dataType&gt;</a>* HMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData&lt;dataType&gt;</a>(cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3);
  2027. <a name="l01948"></a>01948 <span class="keywordflow">if</span>(HMatrix==NULL)
  2028. <a name="l01949"></a>01949 {
  2029. <a name="l01950"></a>01950 <span class="keyword">delete</span> EMatrix;
  2030. <a name="l01951"></a>01951 <span class="keyword">delete</span> DaeMatrix;
  2031. <a name="l01952"></a>01952 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::buildMatrix(): Failed to allocate memory for HMatrix&quot;</span>);
  2032. <a name="l01953"></a>01953 }
  2033. <a name="l01954"></a>01954 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();j++)
  2034. <a name="l01955"></a>01955 {
  2035. <a name="l01956"></a>01956 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k&lt;cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();k++)
  2036. <a name="l01957"></a>01957 {
  2037. <a name="l01958"></a>01958 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> m=0;m&lt;3;m++)
  2038. <a name="l01959"></a>01959 {
  2039. <a name="l01960"></a>01960 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> n=0;n&lt;3;n++)
  2040. <a name="l01961"></a>01961 {
  2041. <a name="l01962"></a>01962 EMatrix-&gt;<a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,k*3+n,&amp;(solver.<a class="code" href="classmatrixMatrixSolver.html#a06093225d93b903dc93612fb23ddadf2">A</a>().<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[k].nodeID*3+n)),<span class="keyword">false</span>); <span class="comment">// delete</span>
  2042. <a name="l01963"></a>01963 HMatrix-&gt;<a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,k*3+n,&amp;(H.entry(cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[k].nodeID*3+n)),<span class="keyword">false</span>);
  2043. <a name="l01964"></a>01964 }
  2044. <a name="l01965"></a>01965 }
  2045. <a name="l01966"></a>01966 }
  2046. <a name="l01967"></a>01967 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> m=0;m&lt;3;m++)
  2047. <a name="l01968"></a>01968 {
  2048. <a name="l01969"></a>01969 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> n=0;n&lt;4;n++)
  2049. <a name="l01970"></a>01970 {
  2050. <a name="l01971"></a>01971 DaeMatrix-&gt;<a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,n,&amp;(Dae.entry(cxMesh-&gt;getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,n)),<span class="keyword">false</span>);
  2051. <a name="l01972"></a>01972 <span class="comment">// PsiMatrix-&gt;setPointer(j*3+m,n,&amp;(Psi.entry(cxMesh-&gt;getElement(i).nodeHndl[j].nodeID*3+m,n)),false);</span>
  2052. <a name="l01973"></a>01973 }
  2053. <a name="l01974"></a>01974 }
  2054. <a name="l01975"></a>01975 }
  2055. <a name="l01976"></a>01976 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setEMatrix(EMatrix,<span class="keyword">true</span>);
  2056. <a name="l01977"></a>01977 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setDeaMatrix(DaeMatrix,<span class="keyword">true</span>);
  2057. <a name="l01978"></a>01978 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setHMatrix(HMatrix,<span class="keyword">true</span>);
  2058. <a name="l01979"></a>01979 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setDeeMatrix(&amp;Dee);
  2059. <a name="l01980"></a>01980 <span class="comment">// elements[i].setPsiMatrix(PsiMatrix);</span>
  2060. <a name="l01981"></a>01981 }
  2061. <a name="l01982"></a>01982 isBuilt=<span class="keyword">true</span>;
  2062. <a name="l01983"></a>01983 }
  2063. <a name="l01984"></a>01984
  2064. <a name="l01985"></a>01985 <span class="keywordtype">void</span> initSVDMatrix()
  2065. <a name="l01986"></a>01986 {
  2066. <a name="l01987"></a>01987 <span class="keywordflow">if</span>(!isBuilt)
  2067. <a name="l01988"></a>01988 {
  2068. <a name="l01989"></a>01989 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  2069. <a name="l01990"></a>01990 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a4a19abf94aa1abd08eb8b6fdd2f4662e">TIMEALG::vabsMeshLinkStart</a>();
  2070. <a name="l01991"></a>01991 <span class="preprocessor">#endif</span>
  2071. <a name="l01992"></a>01992 <span class="preprocessor"></span>
  2072. <a name="l01993"></a>01993 buildMatrix();
  2073. <a name="l01994"></a>01994
  2074. <a name="l01995"></a>01995 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  2075. <a name="l01996"></a>01996 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a19a22177645e1866a8cb9217ad98b726">TIMEALG::vabsMeshLinkStop</a>();
  2076. <a name="l01997"></a>01997 <span class="preprocessor">#endif</span>
  2077. <a name="l01998"></a>01998 <span class="preprocessor"></span> }
  2078. <a name="l01999"></a>01999
  2079. <a name="l02000"></a>02000 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  2080. <a name="l02001"></a>02001 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a47cb7df0449fa5c03c285d3e92d3aa2d">TIMEALG::vabsMtxCalcStart</a>();
  2081. <a name="l02002"></a>02002 <span class="preprocessor">#endif</span>
  2082. <a name="l02003"></a>02003 <span class="preprocessor"></span>
  2083. <a name="l02004"></a>02004 <span class="comment">// initialize the matrices</span>
  2084. <a name="l02005"></a>02005 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
  2085. <a name="l02006"></a>02006 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
  2086. <a name="l02007"></a>02007 H.size(rCnt,cCnt);
  2087. <a name="l02008"></a>02008 H=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  2088. <a name="l02009"></a>02009 Dae.size(rCnt,cCnt);
  2089. <a name="l02010"></a>02010 Dae=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  2090. <a name="l02011"></a>02011 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  2091. <a name="l02012"></a>02012 <span class="preprocessor"></span> Psi.size(rCnt,cCnt);
  2092. <a name="l02013"></a>02013 Psi=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  2093. <a name="l02014"></a>02014 <span class="preprocessor">#endif</span>
  2094. <a name="l02015"></a>02015 <span class="preprocessor"></span> cCnt=rCnt=Dee.<a class="code" href="classmatrixSqr.html#a5149ddb5fb5dfb239bf782472bda2793">size</a>();
  2095. <a name="l02016"></a>02016 Dee=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::zeroMatrix</a>(rCnt,cCnt);
  2096. <a name="l02017"></a>02017 <span class="preprocessor">#ifdef SVD_BASED_VABS_SOLUTION</span>
  2097. <a name="l02018"></a>02018 <span class="preprocessor"></span> solver.<a class="code" href="classmatrixMatrixSolver.html#a06093225d93b903dc93612fb23ddadf2">A</a>().<a class="code" href="classmatrixSqr.html#a5149ddb5fb5dfb239bf782472bda2793">size</a>(rCnt,cCnt);
  2098. <a name="l02019"></a>02019 <span class="preprocessor">#else</span>
  2099. <a name="l02020"></a>02020 <span class="preprocessor"></span> rCnt=cCnt=solver.<a class="code" href="classmatrixMatrixSolver.html#a06093225d93b903dc93612fb23ddadf2">A</a>().<a class="code" href="classmatrixSqr.html#a5149ddb5fb5dfb239bf782472bda2793">size</a>();
  2100. <a name="l02021"></a>02021 <span class="preprocessor">#endif</span>
  2101. <a name="l02022"></a>02022 <span class="preprocessor"></span> solver.<a class="code" href="classmatrixMatrixSolver.html#a06093225d93b903dc93612fb23ddadf2">A</a>()=<a class="code" href="classmatrix.html">matrix&lt;double&gt;::zeroMatrix</a>(rCnt,cCnt);
  2102. <a name="l02023"></a>02023
  2103. <a name="l02024"></a>02024 <span class="comment">// Create the matrices</span>
  2104. <a name="l02025"></a>02025 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;elements.size();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  2105. <a name="l02026"></a>02026 {
  2106. <a name="l02027"></a>02027 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addE();
  2107. <a name="l02028"></a>02028 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addDee();
  2108. <a name="l02029"></a>02029 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addDae();
  2109. <a name="l02030"></a>02030 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addH();
  2110. <a name="l02031"></a>02031 <span class="comment">// elements[i].addPsi();</span>
  2111. <a name="l02032"></a>02032 }
  2112. <a name="l02033"></a>02033
  2113. <a name="l02034"></a>02034 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  2114. <a name="l02035"></a>02035 <span class="preprocessor"></span><span class="comment">// // create the Psi matrix</span>
  2115. <a name="l02036"></a>02036 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> one=1.0/sqrt(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>(rCnt));
  2116. <a name="l02037"></a>02037 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;rCnt/3;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  2117. <a name="l02038"></a>02038 {
  2118. <a name="l02039"></a>02039 Psi.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3,0)=one;
  2119. <a name="l02040"></a>02040 Psi.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1,1)=one;
  2120. <a name="l02041"></a>02041 Psi.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2,2)=one;
  2121. <a name="l02042"></a>02042 Psi.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1,3)=cxMesh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).y;
  2122. <a name="l02043"></a>02043 Psi.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2,3)=-cxMesh-&gt;getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).x;
  2123. <a name="l02044"></a>02044 }
  2124. <a name="l02045"></a>02045 <span class="comment">// dataType L=0.0;</span>
  2125. <a name="l02046"></a>02046 <span class="comment">// for(unsigned long i=0;i&lt;rCnt*3;i++)</span>
  2126. <a name="l02047"></a>02047 <span class="comment">// {</span>
  2127. <a name="l02048"></a>02048 <span class="comment">// // mtxSlvr.B().entry(i*3+1,3)=mtxSlvr.B().entry(i*3+1,3)+dot1*one;</span>
  2128. <a name="l02049"></a>02049 <span class="comment">// // mtxSlvr.B().entry(i*3+2,3)=mtxSlvr.B().entry(i*3+2,3)+dot2*one;</span>
  2129. <a name="l02050"></a>02050 <span class="comment">// L+=Psi.entry(i*3+1,3)*Psi.entry(i*3+1,3)+Psi.entry(i*3+2,3)*Psi.entry(i*3+2,3);</span>
  2130. <a name="l02051"></a>02051 <span class="comment">// }</span>
  2131. <a name="l02052"></a>02052 <span class="comment">// L=sqrt(L);</span>
  2132. <a name="l02053"></a>02053 <span class="comment">// for(unsigned long i=0;i&lt;rCnt*3;i++)</span>
  2133. <a name="l02054"></a>02054 <span class="comment">// {</span>
  2134. <a name="l02055"></a>02055 <span class="comment">// mtxSlvr.B().entry(i*3+1,3)/=L;</span>
  2135. <a name="l02056"></a>02056 <span class="comment">// mtxSlvr.B().entry(i*3+2,3)/=L;</span>
  2136. <a name="l02057"></a>02057 <span class="comment">// }</span>
  2137. <a name="l02058"></a>02058 <span class="comment">// // mtxSlvr.solve();</span>
  2138. <a name="l02059"></a>02059 <span class="comment">// Psi=mtxSlvr.B();</span>
  2139. <a name="l02060"></a>02060 <span class="preprocessor">#endif</span>
  2140. <a name="l02061"></a>02061 <span class="preprocessor"></span>
  2141. <a name="l02062"></a>02062 <span class="comment">// Psi.size(rCnt,cCnt);</span>
  2142. <a name="l02063"></a>02063 <span class="comment">// matrixMatrixSolver mtxSlvr(rCnt,cCnt);</span>
  2143. <a name="l02064"></a>02064 <span class="comment">// mtxSlvr.A()=H;</span>
  2144. <a name="l02065"></a>02065 <span class="comment">// mtxSlvr.B()=matrix&lt;double&gt;::zeroMatrix(rCnt,cCnt);</span>
  2145. <a name="l02066"></a>02066 <span class="comment">// double dot1=0.0;</span>
  2146. <a name="l02067"></a>02067 <span class="comment">// double dot2=0.0;</span>
  2147. <a name="l02068"></a>02068 <span class="comment">// double one=1.0/sqrt(double(rCnt));</span>
  2148. <a name="l02069"></a>02069 <span class="comment">// for(unsigned long i=0;i&lt;rCnt/3;i++)</span>
  2149. <a name="l02070"></a>02070 <span class="comment">// {</span>
  2150. <a name="l02071"></a>02071 <span class="comment">// mtxSlvr.B().entry(i*3,0)=one;</span>
  2151. <a name="l02072"></a>02072 <span class="comment">// mtxSlvr.B().entry(i*3+1,1)=one;</span>
  2152. <a name="l02073"></a>02073 <span class="comment">// mtxSlvr.B().entry(i*3+2,2)=one;</span>
  2153. <a name="l02074"></a>02074 <span class="comment">// mtxSlvr.B().entry(i*3+1,3)=cxMesh-&gt;getNode(i).y;</span>
  2154. <a name="l02075"></a>02075 <span class="comment">// mtxSlvr.B().entry(i*3+2,3)=-cxMesh-&gt;getNode(i).x;</span>
  2155. <a name="l02076"></a>02076 <span class="comment">// dot1-=cxMesh-&gt;getNode(i).y*one;</span>
  2156. <a name="l02077"></a>02077 <span class="comment">// dot2+=cxMesh-&gt;getNode(i).x*one;</span>
  2157. <a name="l02078"></a>02078 <span class="comment">// }</span>
  2158. <a name="l02079"></a>02079 <span class="comment">// double L=0.0;</span>
  2159. <a name="l02080"></a>02080 <span class="comment">// for(unsigned long i=0;i&lt;rCnt/3;i++)</span>
  2160. <a name="l02081"></a>02081 <span class="comment">// {</span>
  2161. <a name="l02082"></a>02082 <span class="comment">// // mtxSlvr.B().entry(i*3+1,3)=mtxSlvr.B().entry(i*3+1,3)+dot1*one;</span>
  2162. <a name="l02083"></a>02083 <span class="comment">// // mtxSlvr.B().entry(i*3+2,3)=mtxSlvr.B().entry(i*3+2,3)+dot2*one;</span>
  2163. <a name="l02084"></a>02084 <span class="comment">// L+=mtxSlvr.B().entry(i*3+1,3)*mtxSlvr.B().entry(i*3+1,3)+mtxSlvr.B().entry(i*3+2,3)*mtxSlvr.B().entry(i*3+2,3);</span>
  2164. <a name="l02085"></a>02085 <span class="comment">// }</span>
  2165. <a name="l02086"></a>02086 <span class="comment">// L=sqrt(L);</span>
  2166. <a name="l02087"></a>02087 <span class="comment">// for(unsigned long i=0;i&lt;rCnt/3;i++)</span>
  2167. <a name="l02088"></a>02088 <span class="comment">// {</span>
  2168. <a name="l02089"></a>02089 <span class="comment">// mtxSlvr.B().entry(i*3+1,3)/=L;</span>
  2169. <a name="l02090"></a>02090 <span class="comment">// mtxSlvr.B().entry(i*3+2,3)/=L;</span>
  2170. <a name="l02091"></a>02091 <span class="comment">// }</span>
  2171. <a name="l02092"></a>02092 <span class="comment">// mtxSlvr.solve();</span>
  2172. <a name="l02093"></a>02093 <span class="comment">// Psi=mtxSlvr.B();</span>
  2173. <a name="l02094"></a>02094
  2174. <a name="l02095"></a>02095 <span class="comment">// E=solver.A();</span>
  2175. <a name="l02096"></a>02096 <span class="comment">// std::cout &lt;&lt; &quot;This is Psi&quot; &lt;&lt; std::endl;</span>
  2176. <a name="l02097"></a>02097 <span class="comment">// printMatrix(Psi);</span>
  2177. <a name="l02098"></a>02098 <span class="comment">// for(unsigned long i=0;i&lt;(rCnt/3);i++)</span>
  2178. <a name="l02099"></a>02099 <span class="comment">// {</span>
  2179. <a name="l02100"></a>02100 <span class="comment">// dataType div=Psi.entry(i*3,0);</span>
  2180. <a name="l02101"></a>02101 <span class="comment">// std::cout &lt;&lt; div &lt;&lt; std::endl;</span>
  2181. <a name="l02102"></a>02102 <span class="comment">// for(unsigned long j=0;j&lt;3;j++)</span>
  2182. <a name="l02103"></a>02103 <span class="comment">// {</span>
  2183. <a name="l02104"></a>02104 <span class="comment">// for(unsigned long k=0;k&lt;4;k++)</span>
  2184. <a name="l02105"></a>02105 <span class="comment">// {</span>
  2185. <a name="l02106"></a>02106 <span class="comment">// Psi.entry(i*3+j,k)/=div;</span>
  2186. <a name="l02107"></a>02107 <span class="comment">// }</span>
  2187. <a name="l02108"></a>02108 <span class="comment">// }</span>
  2188. <a name="l02109"></a>02109 <span class="comment">// }</span>
  2189. <a name="l02110"></a>02110 <span class="comment">// std::cout &lt;&lt; &quot;This is Psi&quot; &lt;&lt; std::endl;</span>
  2190. <a name="l02111"></a>02111 <span class="comment">// printMatrix(Psi);</span>
  2191. <a name="l02112"></a>02112 <span class="comment">// std::cout &lt;&lt; &quot;This is E*Psi&quot; &lt;&lt; std::endl;</span>
  2192. <a name="l02113"></a>02113 <span class="comment">// printMatrix(solver.A()*Psi);</span>
  2193. <a name="l02114"></a>02114
  2194. <a name="l02115"></a>02115 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  2195. <a name="l02116"></a>02116 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#abb3dfe1409ead9ab389b11970c1ed9bb">TIMEALG::vabsMtxCalcStop</a>();
  2196. <a name="l02117"></a>02117 <span class="preprocessor">#endif</span>
  2197. <a name="l02118"></a>02118 <span class="preprocessor"></span>
  2198. <a name="l02119"></a>02119 }
  2199. <a name="l02120"></a>02120
  2200. <a name="l02121"></a>02121 <span class="keywordtype">void</span> solveSVDMatrix()
  2201. <a name="l02122"></a>02122 {
  2202. <a name="l02123"></a>02123 <span class="preprocessor">#ifdef SVD_BASED_VABS_SOLUTION</span>
  2203. <a name="l02124"></a>02124 <span class="preprocessor"></span>
  2204. <a name="l02125"></a>02125 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  2205. <a name="l02126"></a>02126 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a3ceb53d2150ae4680275daf80a03cab2">TIMEALG::vabsSolveStart</a>();
  2206. <a name="l02127"></a>02127 <span class="preprocessor">#endif</span>
  2207. <a name="l02128"></a>02128 <span class="preprocessor"></span>
  2208. <a name="l02129"></a>02129 <span class="comment">// perform the SVD</span>
  2209. <a name="l02130"></a>02130 <span class="keywordflow">if</span>(!solver.<a class="code" href="classmatrixMatrixSolver.html#a91ec4089eb228ec89bbe390eeeb899f4">solve</a>())
  2210. <a name="l02131"></a>02131 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1_Model_Base::solveMatrix(): Failed to perform the SVD&quot;</span>);
  2211. <a name="l02132"></a>02132
  2212. <a name="l02133"></a>02133 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  2213. <a name="l02134"></a>02134 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#aa949ffb65130aaa897589e2cb68b2bee">TIMEALG::vabsSolveStop</a>();
  2214. <a name="l02135"></a>02135 <span class="preprocessor">#endif</span>
  2215. <a name="l02136"></a>02136 <span class="preprocessor"></span>
  2216. <a name="l02137"></a>02137 <span class="preprocessor">#endif</span>
  2217. <a name="l02138"></a>02138 <span class="preprocessor"></span> }
  2218. <a name="l02139"></a>02139
  2219. <a name="l02140"></a>02140 <span class="keywordtype">void</span> finalizeSVDSolution()
  2220. <a name="l02141"></a>02141 {
  2221. <a name="l02142"></a>02142
  2222. <a name="l02143"></a>02143
  2223. <a name="l02144"></a>02144
  2224. <a name="l02145"></a>02145 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
  2225. <a name="l02146"></a>02146 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
  2226. <a name="l02147"></a>02147 H.size(rCnt,cCnt);
  2227. <a name="l02148"></a>02148
  2228. <a name="l02149"></a>02149 <span class="preprocessor">#ifdef SVD_BASED_VABS_SOLUTION</span>
  2229. <a name="l02150"></a>02150 <span class="preprocessor"></span>
  2230. <a name="l02151"></a>02151 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  2231. <a name="l02152"></a>02152 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a64fad33a25509725cf641d6f6d9c6f63">TIMEALG::vabsNCalcStart</a>();
  2232. <a name="l02153"></a>02153 <span class="preprocessor">#endif</span>
  2233. <a name="l02154"></a>02154 <span class="preprocessor"></span>
  2234. <a name="l02155"></a>02155 <span class="comment">// perform all the algebra for the solution</span>
  2235. <a name="l02156"></a>02156 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> PsiTHPsi=solver.Psi().T()*H*solver.Psi();
  2236. <a name="l02157"></a>02157 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> PsiTHPsi_Inverse=PsiTHPsi.<a class="code" href="classmatrixSqr.html#a991ebad568b11587f75c85cc3b8da408">inverse</a>();
  2237. <a name="l02158"></a>02158 <a class="code" href="classmatrixRdWtSzSqr__Data.html">matrixRdWtSzSqr_Data&lt;dataType&gt;</a> prePostMatrix=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::identityMatrix</a>(rCnt)-H*solver.Psi()*PsiTHPsi_Inverse*solver.Psi().T();
  2238. <a name="l02159"></a>02159
  2239. <a name="l02160"></a>02160 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
  2240. <a name="l02161"></a>02161 <span class="preprocessor"></span> N=prePostMatrix.<a class="code" href="classmatrixRdWtSzSqr__Data.html#a0aaafd5034f44c778cd2a793c992e5e9">T</a>();
  2241. <a name="l02162"></a>02162 <span class="preprocessor">#endif</span>
  2242. <a name="l02163"></a>02163 <span class="preprocessor"></span>
  2243. <a name="l02164"></a>02164 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  2244. <a name="l02165"></a>02165 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a294dfa8c6f83f364d880655b35f8531f">TIMEALG::vabsNCalcStop</a>();
  2245. <a name="l02166"></a>02166 <a class="code" href="namespaceTIMEALG.html#a3ceb53d2150ae4680275daf80a03cab2">TIMEALG::vabsSolveStart</a>();
  2246. <a name="l02167"></a>02167 <span class="preprocessor">#endif</span>
  2247. <a name="l02168"></a>02168 <span class="preprocessor"></span>
  2248. <a name="l02169"></a>02169 <span class="comment">// Now lets build the matrix expression that will be used to solve V*</span>
  2249. <a name="l02170"></a>02170 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> vStarSource=-prePostMatrix*Dae;
  2250. <a name="l02171"></a>02171 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> vStar=solver.inverse()*vStarSource;
  2251. <a name="l02172"></a>02172 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
  2252. <a name="l02173"></a>02173 <span class="preprocessor"></span> vStar_adjoint=vStar;
  2253. <a name="l02174"></a>02174 <span class="preprocessor">#endif</span>
  2254. <a name="l02175"></a>02175 <span class="preprocessor"></span>
  2255. <a name="l02176"></a>02176 <span class="comment">// now lets solve the actual v</span>
  2256. <a name="l02177"></a>02177 v=prePostMatrix.<a class="code" href="classmatrixRdWtSzSqr__Data.html#a0aaafd5034f44c778cd2a793c992e5e9">T</a>()*vStar;
  2257. <a name="l02178"></a>02178
  2258. <a name="l02179"></a>02179 <span class="comment">// now we can solve the actual matrix</span>
  2259. <a name="l02180"></a>02180 result=v.T()*Dae+Dee;
  2260. <a name="l02181"></a>02181
  2261. <a name="l02182"></a>02182 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  2262. <a name="l02183"></a>02183 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#aa949ffb65130aaa897589e2cb68b2bee">TIMEALG::vabsSolveStop</a>();
  2263. <a name="l02184"></a>02184 <span class="preprocessor">#endif</span>
  2264. <a name="l02185"></a>02185 <span class="preprocessor"></span>
  2265. <a name="l02186"></a>02186 <span class="preprocessor">#endif</span>
  2266. <a name="l02187"></a>02187 <span class="preprocessor"></span>
  2267. <a name="l02188"></a>02188 <span class="comment">// ##################################################</span>
  2268. <a name="l02189"></a>02189 <span class="comment">// this is the test version based on Psi</span>
  2269. <a name="l02190"></a>02190 <span class="comment">// ##################################################</span>
  2270. <a name="l02191"></a>02191
  2271. <a name="l02192"></a>02192 <span class="comment">// // This is just a test version</span>
  2272. <a name="l02193"></a>02193 <span class="comment">// matrixRdWtStaticSqr_Data&lt;dataType,4&gt; PsiTHPsi_tmp=Psi.T()*H*Psi;</span>
  2273. <a name="l02194"></a>02194 <span class="comment">// matrixRdWtStaticSqr_Data&lt;dataType,4&gt; PsiTHPsi_Inverse_tmp=PsiTHPsi_tmp.inverse();</span>
  2274. <a name="l02195"></a>02195 <span class="comment">// matrixRdWtSzSqr_Data&lt;dataType&gt; prePostMatrix_tmp=matrix&lt;dataType&gt;::identityMatrix(rCnt)-H*Psi*PsiTHPsi_Inverse_tmp*Psi.T();</span>
  2275. <a name="l02196"></a>02196 <span class="comment">// </span>
  2276. <a name="l02197"></a>02197 <span class="comment">// // Now lets build the matrix expression that will be used to solve V*</span>
  2277. <a name="l02198"></a>02198 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; vStarSource_tmp=-prePostMatrix_tmp*Dae;</span>
  2278. <a name="l02199"></a>02199 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; vStar_tmp=solver.inverse()*vStarSource_tmp;</span>
  2279. <a name="l02200"></a>02200 <span class="comment">// </span>
  2280. <a name="l02201"></a>02201 <span class="comment">// // now lets solve the actual v</span>
  2281. <a name="l02202"></a>02202 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; v_tmp=prePostMatrix_tmp.T()*vStar_tmp;</span>
  2282. <a name="l02203"></a>02203 <span class="comment">// </span>
  2283. <a name="l02204"></a>02204 <span class="comment">// // now we can solve the actual matrix</span>
  2284. <a name="l02205"></a>02205 <span class="comment">// matrixRdWtSz_Data&lt;dataType&gt; result_tmp=v_tmp.T()*Dae+Dee;</span>
  2285. <a name="l02206"></a>02206
  2286. <a name="l02207"></a>02207 <span class="comment">// ##################################################</span>
  2287. <a name="l02208"></a>02208 <span class="comment">// this is the test version based on Psi and the linear solve</span>
  2288. <a name="l02209"></a>02209 <span class="comment">// ##################################################</span>
  2289. <a name="l02210"></a>02210
  2290. <a name="l02211"></a>02211 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
  2291. <a name="l02212"></a>02212 <span class="preprocessor"></span>
  2292. <a name="l02213"></a>02213 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  2293. <a name="l02214"></a>02214 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a64fad33a25509725cf641d6f6d9c6f63">TIMEALG::vabsNCalcStart</a>();
  2294. <a name="l02215"></a>02215 <span class="preprocessor">#endif</span>
  2295. <a name="l02216"></a>02216 <span class="preprocessor"></span>
  2296. <a name="l02217"></a>02217 <span class="comment">// build the source matrix and nullifier</span>
  2297. <a name="l02218"></a>02218 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> PsiTHPsi=Psi.T()*H*Psi;
  2298. <a name="l02219"></a>02219 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> PsiTHPsi_Inverse=PsiTHPsi.<a class="code" href="classmatrixSqr.html#a991ebad568b11587f75c85cc3b8da408">inverse</a>();
  2299. <a name="l02220"></a>02220 <a class="code" href="classmatrixRdWtSzSqr__Data.html">matrixRdWtSzSqr_Data&lt;dataType&gt;</a> prePostMatrix=<a class="code" href="classmatrix.html">matrix&lt;dataType&gt;::identityMatrix</a>(rCnt)-H*Psi*PsiTHPsi_Inverse*Psi.<a class="code" href="classmatrixRdWtStaticSqr__Data.html#a3db65c97e3f5de1fe52b5f0831e11176">T</a>();
  2300. <a name="l02221"></a>02221 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
  2301. <a name="l02222"></a>02222 <span class="preprocessor"></span> N=prePostMatrix.<a class="code" href="classmatrixRdWtSzSqr__Data.html#a0aaafd5034f44c778cd2a793c992e5e9">T</a>();
  2302. <a name="l02223"></a>02223 <span class="preprocessor">#endif</span>
  2303. <a name="l02224"></a>02224 <span class="preprocessor"></span>
  2304. <a name="l02225"></a>02225 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  2305. <a name="l02226"></a>02226 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a294dfa8c6f83f364d880655b35f8531f">TIMEALG::vabsNCalcStop</a>();
  2306. <a name="l02227"></a>02227 <a class="code" href="namespaceTIMEALG.html#a3ceb53d2150ae4680275daf80a03cab2">TIMEALG::vabsSolveStart</a>();
  2307. <a name="l02228"></a>02228 <span class="preprocessor">#endif</span>
  2308. <a name="l02229"></a>02229 <span class="preprocessor"></span>
  2309. <a name="l02230"></a>02230 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> vStarSource=-prePostMatrix*Dae;
  2310. <a name="l02231"></a>02231
  2311. <a name="l02232"></a>02232 <span class="comment">// The solve operator</span>
  2312. <a name="l02233"></a>02233 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data&lt;dataType&gt;</a> PsiDyad=Psi*Psi.<a class="code" href="classmatrixRdWtSz__Data.html#ae1c7af296930751d1ceaf95429e9bb57">T</a>();
  2313. <a name="l02234"></a>02234 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> tracePsi=0.0;
  2314. <a name="l02235"></a>02235 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> traceE=0.0;
  2315. <a name="l02236"></a>02236 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;rCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  2316. <a name="l02237"></a>02237 {
  2317. <a name="l02238"></a>02238 tracePsi+=PsiDyad.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>);
  2318. <a name="l02239"></a>02239 traceE+=solver.<a class="code" href="classmatrixMatrixSolver.html#a06093225d93b903dc93612fb23ddadf2">A</a>().<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>,<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>);
  2319. <a name="l02240"></a>02240 }
  2320. <a name="l02241"></a>02241 <span class="comment">// #ifdef ADJOINT_VABS</span>
  2321. <a name="l02242"></a>02242 <span class="comment">// ET=solver.A().T();</span>
  2322. <a name="l02243"></a>02243 <span class="comment">// #endif</span>
  2323. <a name="l02244"></a>02244 solver.<a class="code" href="classmatrixMatrixSolver.html#a06093225d93b903dc93612fb23ddadf2">A</a>()+=(traceE/tracePsi)*PsiDyad;
  2324. <a name="l02245"></a>02245
  2325. <a name="l02246"></a>02246 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
  2326. <a name="l02247"></a>02247 <span class="preprocessor"></span> ETDyad=solver.<a class="code" href="classmatrixMatrixSolver.html#a06093225d93b903dc93612fb23ddadf2">A</a>().<a class="code" href="classmatrixRdWtSqr.html#a8112f63f51201ab630429b45b5488fba">T</a>();
  2327. <a name="l02248"></a>02248 <span class="preprocessor">#endif</span>
  2328. <a name="l02249"></a>02249 <span class="preprocessor"></span>
  2329. <a name="l02250"></a>02250 solver.<a class="code" href="classmatrixMatrixSolver.html#a3d4eb5a5c9b8a11961f29cf94c0c64d7">B</a>()=vStarSource;
  2330. <a name="l02251"></a>02251 solver.<a class="code" href="classmatrixMatrixSolver.html#a91ec4089eb228ec89bbe390eeeb899f4">solve</a>();
  2331. <a name="l02252"></a>02252
  2332. <a name="l02253"></a>02253 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
  2333. <a name="l02254"></a>02254 <span class="preprocessor"></span> vStar_adjoint=solver.<a class="code" href="classmatrixMatrixSolver.html#a3d4eb5a5c9b8a11961f29cf94c0c64d7">B</a>();
  2334. <a name="l02255"></a>02255 <span class="preprocessor">#endif</span>
  2335. <a name="l02256"></a>02256 <span class="preprocessor"></span>
  2336. <a name="l02257"></a>02257 <span class="comment">// now lets solve the actual v</span>
  2337. <a name="l02258"></a>02258 v=prePostMatrix.<a class="code" href="classmatrixRdWtSzSqr__Data.html#a0aaafd5034f44c778cd2a793c992e5e9">T</a>()*solver.<a class="code" href="classmatrixMatrixSolver.html#a3d4eb5a5c9b8a11961f29cf94c0c64d7">B</a>();
  2338. <a name="l02259"></a>02259 <span class="comment">// now we can solve the actual matrix</span>
  2339. <a name="l02260"></a>02260 result=v.T()*Dae+Dee;
  2340. <a name="l02261"></a>02261
  2341. <a name="l02262"></a>02262 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  2342. <a name="l02263"></a>02263 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#aa949ffb65130aaa897589e2cb68b2bee">TIMEALG::vabsSolveStop</a>();
  2343. <a name="l02264"></a>02264 <span class="preprocessor">#endif</span>
  2344. <a name="l02265"></a>02265 <span class="preprocessor"></span>
  2345. <a name="l02266"></a>02266 <span class="preprocessor">#endif</span>
  2346. <a name="l02267"></a>02267 <span class="preprocessor"></span>
  2347. <a name="l02268"></a>02268 <span class="comment">// std::cout &lt;&lt; &quot;This is v_tmp-v&quot; &lt;&lt; std::endl;</span>
  2348. <a name="l02269"></a>02269 <span class="comment">// printMatrix(v_tmp-v);</span>
  2349. <a name="l02270"></a>02270 <span class="comment">// std::cout &lt;&lt; &quot;This is result_tmp-result&quot; &lt;&lt; std::endl;</span>
  2350. <a name="l02271"></a>02271 <span class="comment">// printMatrix(result_tmp-result);</span>
  2351. <a name="l02272"></a>02272 <span class="comment">// std::cout &lt;&lt; &quot;This is result_lin-result&quot; &lt;&lt; std::endl;</span>
  2352. <a name="l02273"></a>02273 <span class="comment">// printMatrix(result_lin-result);</span>
  2353. <a name="l02274"></a>02274 <span class="comment">// std::cout &lt;&lt; &quot;This is the result&quot; &lt;&lt; std::endl;</span>
  2354. <a name="l02275"></a>02275 <span class="comment">// printMatrix(result);</span>
  2355. <a name="l02276"></a>02276 <span class="comment">// std::cout &lt;&lt; &quot;This is solver.Psi^T*Psi&quot; &lt;&lt; std::endl;</span>
  2356. <a name="l02277"></a>02277 <span class="comment">// printMatrix(solver.Psi().T()*Psi);</span>
  2357. <a name="l02278"></a>02278 <span class="comment">// std::cout &lt;&lt; &quot;This is solver.Psi&quot; &lt;&lt; std::endl;</span>
  2358. <a name="l02279"></a>02279 <span class="comment">// printMatrix(solver.Psi());</span>
  2359. <a name="l02280"></a>02280 <span class="comment">// std::cout &lt;&lt; &quot;This is E*solver.Psi&quot; &lt;&lt; std::endl;</span>
  2360. <a name="l02281"></a>02281 <span class="comment">// printMatrix(E*solver.Psi());</span>
  2361. <a name="l02282"></a>02282 <span class="comment">// std::cout &lt;&lt; &quot;This is position&quot; &lt;&lt; std::endl;</span>
  2362. <a name="l02283"></a>02283 <span class="comment">// unsigned long ndCnt;</span>
  2363. <a name="l02284"></a>02284 <span class="comment">// unsigned long elmCnt;</span>
  2364. <a name="l02285"></a>02285 <span class="comment">// cxMesh-&gt;size(ndCnt,elmCnt);</span>
  2365. <a name="l02286"></a>02286 <span class="comment">// std::streamsize prec=std::cout.precision(16);</span>
  2366. <a name="l02287"></a>02287 <span class="comment">// for(unsigned long i=0;i&lt;ndCnt;i++)</span>
  2367. <a name="l02288"></a>02288 <span class="comment">// std::cout &lt;&lt; cxMesh-&gt;getNode(i).x &lt;&lt; &#39;\t&#39; &lt;&lt; cxMesh-&gt;getNode(i).y &lt;&lt; std::endl;</span>
  2368. <a name="l02289"></a>02289 <span class="comment">// std::cout.precision(prec);</span>
  2369. <a name="l02290"></a>02290
  2370. <a name="l02291"></a>02291 isSolved=<span class="keyword">true</span>;
  2371. <a name="l02292"></a>02292
  2372. <a name="l02293"></a>02293 }
  2373. <a name="l02294"></a>02294
  2374. <a name="l02295"></a>02295 <span class="keywordtype">void</span> solveMatrix()
  2375. <a name="l02296"></a>02296 {
  2376. <a name="l02297"></a>02297 initSVDMatrix();
  2377. <a name="l02298"></a>02298 solveSVDMatrix();
  2378. <a name="l02299"></a>02299 finalizeSVDSolution();
  2379. <a name="l02300"></a>02300 }
  2380. <a name="l02301"></a>02301
  2381. <a name="l02302"></a>02302 <span class="keyword">public</span>:
  2382. <a name="l02303"></a>02303
  2383. <a name="l02304"></a><a class="code" href="classVABS1Model__Base.html#a05845e1cd43341b8b970dcad0331fdae">02304</a> <a class="code" href="classVABS1Model__Base.html#a05845e1cd43341b8b970dcad0331fdae">VABS1Model_Base</a>(<a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>* cxMesh_in=NULL,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : cxMesh(cxMesh_in) , isBuilt(false) , isSolved(false) , canDelete(canDelete_in)
  2384. <a name="l02305"></a>02305 {
  2385. <a name="l02306"></a>02306 <span class="preprocessor">#if defined(SAVE_INTERMEDIATES) || defined(ADJOINT_VABS)</span>
  2386. <a name="l02307"></a>02307 <span class="preprocessor"></span> <span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <span class="keywordtype">id</span>=0;
  2387. <a name="l02308"></a>02308
  2388. <a name="l02309"></a>02309 vabsList.resize(<span class="keywordtype">id</span>+1);
  2389. <a name="l02310"></a>02310 vabsList[id]=<span class="keyword">this</span>;
  2390. <a name="l02311"></a>02311 <span class="keywordtype">id</span>++;
  2391. <a name="l02312"></a>02312 <span class="preprocessor">#endif</span>
  2392. <a name="l02313"></a>02313 <span class="preprocessor"></span> }
  2393. <a name="l02314"></a>02314
  2394. <a name="l02315"></a><a class="code" href="classVABS1Model__Base.html#a731de32069c1e13f442ea4b9bdae73af">02315</a> <span class="keyword">virtual</span> <a class="code" href="classVABS1Model__Base.html#a731de32069c1e13f442ea4b9bdae73af">~VABS1Model_Base</a>()
  2395. <a name="l02316"></a>02316 {
  2396. <a name="l02317"></a>02317 <span class="keywordflow">if</span>(canDelete &amp;&amp; cxMesh!=NULL)
  2397. <a name="l02318"></a>02318 <span class="keyword">delete</span> cxMesh;
  2398. <a name="l02319"></a>02319 }
  2399. <a name="l02320"></a>02320
  2400. <a name="l02321"></a><a class="code" href="classVABS1Model__Base.html#a01c2e0567b140ca8b207e97d675cd6d5">02321</a> <span class="keywordtype">void</span> <a class="code" href="classVABS1Model__Base.html#a01c2e0567b140ca8b207e97d675cd6d5">setMesh</a>(<a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>* cxMesh_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
  2401. <a name="l02322"></a>02322 {
  2402. <a name="l02323"></a>02323 <span class="keywordflow">if</span>(canDelete &amp;&amp; cxMesh!=NULL &amp;&amp; cxMesh_in!=cxMesh)
  2403. <a name="l02324"></a>02324 <span class="keyword">delete</span> cxMesh;
  2404. <a name="l02325"></a>02325 cxMesh=cxMesh_in;
  2405. <a name="l02326"></a>02326 canDelete=canDelete_in;
  2406. <a name="l02327"></a>02327 isBuilt=<span class="keyword">false</span>;
  2407. <a name="l02328"></a>02328 isSolved=<span class="keyword">false</span>;
  2408. <a name="l02329"></a>02329 }
  2409. <a name="l02330"></a>02330
  2410. <a name="l02331"></a><a class="code" href="classVABS1Model__Base.html#a8363f050c3d8cf35423f6f843ad8f66a">02331</a> <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> <a class="code" href="classVABS1Model__Base.html#a8363f050c3d8cf35423f6f843ad8f66a">beamMatrix</a>()
  2411. <a name="l02332"></a>02332 {
  2412. <a name="l02333"></a>02333 <span class="keywordflow">if</span>(!isSolved)
  2413. <a name="l02334"></a>02334 this-&gt;solveMatrix();
  2414. <a name="l02335"></a>02335
  2415. <a name="l02336"></a>02336 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
  2416. <a name="l02337"></a>02337 <span class="preprocessor"></span> <span class="keywordflow">if</span>(gradientMode)
  2417. <a name="l02338"></a>02338 {
  2418. <a name="l02339"></a>02339 <span class="keywordflow">if</span>(highCalc)
  2419. <a name="l02340"></a>02340 <span class="keywordflow">return</span> result+dC_dy*step;
  2420. <a name="l02341"></a>02341 <span class="keywordflow">else</span>
  2421. <a name="l02342"></a>02342 <span class="keywordflow">return</span> result-dC_dy*step;
  2422. <a name="l02343"></a>02343 }
  2423. <a name="l02344"></a>02344 <span class="preprocessor">#endif</span>
  2424. <a name="l02345"></a>02345 <span class="preprocessor"></span>
  2425. <a name="l02346"></a>02346 <span class="keywordflow">return</span> result;
  2426. <a name="l02347"></a>02347 }
  2427. <a name="l02348"></a>02348
  2428. <a name="l02349"></a><a class="code" href="classVABS1Model__Base.html#a08fecfc60f313ed5bcace521a4a9f927">02349</a> <span class="keywordtype">void</span> <a class="code" href="classVABS1Model__Base.html#a08fecfc60f313ed5bcace521a4a9f927">buildSVD</a>()
  2429. <a name="l02350"></a>02350 {
  2430. <a name="l02351"></a>02351 initSVDMatrix();
  2431. <a name="l02352"></a>02352 }
  2432. <a name="l02353"></a>02353
  2433. <a name="l02354"></a><a class="code" href="classVABS1Model__Base.html#a7281ca009b4c115a169e219f8fc89b3c">02354</a> <span class="keywordtype">void</span> <a class="code" href="classVABS1Model__Base.html#a7281ca009b4c115a169e219f8fc89b3c">solveSVD</a>()
  2434. <a name="l02355"></a>02355 {
  2435. <a name="l02356"></a>02356 solveSVDMatrix();
  2436. <a name="l02357"></a>02357 }
  2437. <a name="l02358"></a>02358
  2438. <a name="l02359"></a><a class="code" href="classVABS1Model__Base.html#a53ef32d123434477968a6b36ec89364b">02359</a> <span class="keywordtype">void</span> <a class="code" href="classVABS1Model__Base.html#a53ef32d123434477968a6b36ec89364b">processSVD</a>()
  2439. <a name="l02360"></a>02360 {
  2440. <a name="l02361"></a>02361 finalizeSVDSolution();
  2441. <a name="l02362"></a>02362 }
  2442. <a name="l02363"></a>02363
  2443. <a name="l02364"></a><a class="code" href="classVABS1Model__Base.html#a6cf12ba008114ff62ad061b0c8513bec">02364</a> <span class="keywordtype">void</span> <a class="code" href="classVABS1Model__Base.html#a6cf12ba008114ff62ad061b0c8513bec">solve</a>()
  2444. <a name="l02365"></a>02365 {
  2445. <a name="l02366"></a>02366 <span class="keywordflow">if</span>(!isSolved)
  2446. <a name="l02367"></a>02367 this-&gt;solveMatrix();
  2447. <a name="l02368"></a>02368 }
  2448. <a name="l02369"></a>02369
  2449. <a name="l02370"></a>02370 <span class="comment">// A method that informs the post process module about the number of elements</span>
  2450. <a name="l02371"></a><a class="code" href="classVABS1Model__Base.html#abee243939153e899b2422b856dc52818">02371</a> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classVABS1Model__Base.html#abee243939153e899b2422b856dc52818">size</a>()
  2451. <a name="l02372"></a>02372 {
  2452. <a name="l02373"></a>02373 <span class="keywordflow">return</span> elements.size();
  2453. <a name="l02374"></a>02374 }
  2454. <a name="l02375"></a>02375
  2455. <a name="l02376"></a>02376 <span class="comment">// This is an access method to perform post processing</span>
  2456. <a name="l02377"></a><a class="code" href="classVABS1Model__Base.html#aacac281ad0abf6c05900163e6ef9479a">02377</a> <a class="code" href="classautoPntr.html">autoPntr&lt;VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,4&gt;</a> &gt; &gt; <a class="code" href="classVABS1Model__Base.html#aacac281ad0abf6c05900163e6ef9479a">getElement</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)
  2457. <a name="l02378"></a>02378 {
  2458. <a name="l02379"></a>02379 <span class="keywordflow">if</span>(at&gt;=elements.size())
  2459. <a name="l02380"></a>02380 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS1Model_Base::getElement(): Cannot retrieve element because it does not exist&quot;</span>);
  2460. <a name="l02381"></a>02381
  2461. <a name="l02382"></a>02382 <span class="keywordflow">return</span> <a class="code" href="classautoPntr.html">autoPntr&lt;VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,4&gt;</a> &gt; &gt;(<span class="keyword">new</span> <a class="code" href="classVABSElementInfo__Pntr.html">VABSElementInfo_Pntr&lt;dataType,matrixStaticVectCol&lt;dataType,4&gt;</a> &gt;(&amp;elements[at]));
  2462. <a name="l02383"></a>02383 }
  2463. <a name="l02384"></a>02384
  2464. <a name="l02385"></a>02385
  2465. <a name="l02386"></a>02386 <span class="preprocessor">#if defined(SAVE_INTERMEDIATES) || defined(ADJOINT_VABS)</span>
  2466. <a name="l02387"></a>02387 <span class="preprocessor"></span>
  2467. <a name="l02388"></a>02388 <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad&lt;dataType&gt;</a>&amp; getMaxElm()
  2468. <a name="l02389"></a>02389 {
  2469. <a name="l02390"></a>02390 <span class="keywordflow">return</span> elements[maxElm];
  2470. <a name="l02391"></a>02391 }
  2471. <a name="l02392"></a>02392
  2472. <a name="l02393"></a>02393 <span class="preprocessor">#endif</span>
  2473. <a name="l02394"></a>02394 <span class="preprocessor"></span>
  2474. <a name="l02395"></a>02395 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
  2475. <a name="l02396"></a>02396 <span class="preprocessor"></span>
  2476. <a name="l02397"></a>02397 <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad&lt;dataType&gt;</a>&amp; getMaxElmLow()
  2477. <a name="l02398"></a>02398 {
  2478. <a name="l02399"></a>02399 <span class="keywordflow">return</span> elementsLow[maxElm];
  2479. <a name="l02400"></a>02400 }
  2480. <a name="l02401"></a>02401
  2481. <a name="l02402"></a>02402 <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad&lt;dataType&gt;</a>&amp; getMaxElmHigh()
  2482. <a name="l02403"></a>02403 {
  2483. <a name="l02404"></a>02404 <span class="keywordflow">return</span> elementsHigh[maxElm];
  2484. <a name="l02405"></a>02405 }
  2485. <a name="l02406"></a>02406
  2486. <a name="l02407"></a>02407 <span class="preprocessor">#endif</span>
  2487. <a name="l02408"></a>02408 <span class="preprocessor"></span>
  2488. <a name="l02409"></a>02409 <span class="comment">// void getFailList(const matrixStaticVectCol&lt;dataType&gt;&amp; beamStrain, std::list&lt;failPoint&lt;dataType&gt; &gt;&amp; failList)</span>
  2489. <a name="l02410"></a>02410 <span class="comment">// {</span>
  2490. <a name="l02411"></a>02411 <span class="comment">// dataType max=0;</span>
  2491. <a name="l02412"></a>02412 <span class="comment">// dataType tmp;</span>
  2492. <a name="l02413"></a>02413 <span class="comment">// dataType div=pow(2.0,-dataType(sweepN));</span>
  2493. <a name="l02414"></a>02414 <span class="comment">// unsigned long cnt=(1 &lt;&lt; sweepN);</span>
  2494. <a name="l02415"></a>02415 <span class="comment">// </span>
  2495. <a name="l02416"></a>02416 <span class="comment">// for(unsigned long i=0;i&lt;elements.size();i++)</span>
  2496. <a name="l02417"></a>02417 <span class="comment">// {</span>
  2497. <a name="l02418"></a>02418 <span class="comment">// dataType s=div-dataType(1.0);</span>
  2498. <a name="l02419"></a>02419 <span class="comment">// for(unsigned long j=0;j&lt;=cnt;j++)</span>
  2499. <a name="l02420"></a>02420 <span class="comment">// {</span>
  2500. <a name="l02421"></a>02421 <span class="comment">// dataType t=div-dataType(1.0);</span>
  2501. <a name="l02422"></a>02422 <span class="comment">// for(unsigned long k=0;k&lt;=cnt;k++)</span>
  2502. <a name="l02423"></a>02423 <span class="comment">// {</span>
  2503. <a name="l02424"></a>02424 <span class="comment">// tmp=elements[i].fail(s,t,beamStrain);</span>
  2504. <a name="l02425"></a>02425 <span class="comment">// failList.push_back(failPoint&lt;dataType&gt;(tmp,s,t,i));</span>
  2505. <a name="l02426"></a>02426 <span class="comment">// }</span>
  2506. <a name="l02427"></a>02427 <span class="comment">// s+=div;</span>
  2507. <a name="l02428"></a>02428 <span class="comment">// }</span>
  2508. <a name="l02429"></a>02429 <span class="comment">// }</span>
  2509. <a name="l02430"></a>02430 <span class="comment">// }</span>
  2510. <a name="l02431"></a>02431
  2511. <a name="l02432"></a>02432 <span class="comment">// dataType getMaxFail(const matrixStaticVectCol&lt;dataType&gt;&amp; beamStrain,unsigned long n=0)</span>
  2512. <a name="l02433"></a>02433 <span class="comment">// {</span>
  2513. <a name="l02434"></a>02434 <span class="comment">// dataType max=0;</span>
  2514. <a name="l02435"></a>02435 <span class="comment">// dataType tmp;</span>
  2515. <a name="l02436"></a>02436 <span class="comment">// dataType div=pow(2.0,-dataType(n));</span>
  2516. <a name="l02437"></a>02437 <span class="comment">// unsigned long cnt=(1 &lt;&lt; n);</span>
  2517. <a name="l02438"></a>02438 <span class="comment">// </span>
  2518. <a name="l02439"></a>02439 <span class="comment">// for(unsigned long i=0;i&lt;elements.size();i++)</span>
  2519. <a name="l02440"></a>02440 <span class="comment">// {</span>
  2520. <a name="l02441"></a>02441 <span class="comment">// dataType s=dataType(1.0)-div;</span>
  2521. <a name="l02442"></a>02442 <span class="comment">// for(unsigned long j=0;j&lt;=cnt;j++)</span>
  2522. <a name="l02443"></a>02443 <span class="comment">// {</span>
  2523. <a name="l02444"></a>02444 <span class="comment">// dataType t=dataType(1.0)-div;</span>
  2524. <a name="l02445"></a>02445 <span class="comment">// for(unsigned long k=0;k&lt;=cnt;k++)</span>
  2525. <a name="l02446"></a>02446 <span class="comment">// {</span>
  2526. <a name="l02447"></a>02447 <span class="comment">// tmp=elements[i].fail(s,t,beamStrain);</span>
  2527. <a name="l02448"></a>02448 <span class="comment">// if(max&lt;tmp)</span>
  2528. <a name="l02449"></a>02449 <span class="comment">// max=tmp;</span>
  2529. <a name="l02450"></a>02450 <span class="comment">// t+=div;</span>
  2530. <a name="l02451"></a>02451 <span class="comment">// }</span>
  2531. <a name="l02452"></a>02452 <span class="comment">// s+=div;</span>
  2532. <a name="l02453"></a>02453 <span class="comment">// }</span>
  2533. <a name="l02454"></a>02454 <span class="comment">// }</span>
  2534. <a name="l02455"></a>02455 <span class="comment">// </span>
  2535. <a name="l02456"></a>02456 <span class="comment">// return max;</span>
  2536. <a name="l02457"></a>02457 <span class="comment">// }</span>
  2537. <a name="l02458"></a>02458 };
  2538. <a name="l02459"></a>02459
  2539. <a name="l02460"></a>02460 <span class="preprocessor">#if defined(SAVE_INTERMEDIATES) || defined(ADJOINT_VABS)</span>
  2540. <a name="l02461"></a>02461 <span class="preprocessor"></span>
  2541. <a name="l02462"></a>02462 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2542. <a name="l02463"></a>02463 std::vector&lt;VABS1Model_Base&lt;dataType&gt;*&gt; <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base&lt;dataType&gt;::vabsList</a>;
  2543. <a name="l02464"></a>02464
  2544. <a name="l02465"></a>02465 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2545. <a name="l02466"></a>02466 <span class="keywordtype">bool</span> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base&lt;dataType&gt;::gradientMode</a>=<span class="keyword">false</span>;
  2546. <a name="l02467"></a>02467
  2547. <a name="l02468"></a>02468 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2548. <a name="l02469"></a>02469 <span class="keywordtype">bool</span> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base&lt;dataType&gt;::highCalc</a>=<span class="keyword">false</span>;
  2549. <a name="l02470"></a>02470
  2550. <a name="l02471"></a>02471 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2551. <a name="l02472"></a>02472 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base&lt;dataType&gt;::step</a>=0.0001;
  2552. <a name="l02473"></a>02473
  2553. <a name="l02474"></a>02474 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2554. <a name="l02475"></a>02475 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base&lt;dataType&gt;::maxElm</a>=0;
  2555. <a name="l02476"></a>02476
  2556. <a name="l02477"></a>02477 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2557. <a name="l02478"></a>02478 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base&lt;dataType&gt;::maxCX</a>=0;
  2558. <a name="l02479"></a>02479
  2559. <a name="l02480"></a>02480 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2560. <a name="l02481"></a>02481 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base&lt;dataType&gt;::atS</a>=0.0;
  2561. <a name="l02482"></a>02482
  2562. <a name="l02483"></a>02483 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2563. <a name="l02484"></a>02484 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base&lt;dataType&gt;::atT</a>=0.0;
  2564. <a name="l02485"></a>02485
  2565. <a name="l02486"></a>02486 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2566. <a name="l02487"></a>02487 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base&lt;dataType&gt;::beamLocation</a>=0.0;
  2567. <a name="l02488"></a>02488
  2568. <a name="l02489"></a>02489 <span class="preprocessor">#endif</span>
  2569. <a name="l02490"></a>02490 <span class="preprocessor"></span>
  2570. <a name="l02491"></a>02491 <span class="comment">// This version was used befor the realization the only difference is one type.</span>
  2571. <a name="l02492"></a>02492 <span class="comment">// Thus it is better the differentiation is made between template parameters</span>
  2572. <a name="l02493"></a>02493 <span class="comment">// // // this implementation is still a VABS model but this gives the timoshenko version of the model</span>
  2573. <a name="l02494"></a>02494 <span class="comment">// // template&lt;class dataType,class failType&gt;</span>
  2574. <a name="l02495"></a>02495 <span class="comment">// // class VABS2Model</span>
  2575. <a name="l02496"></a>02496 <span class="comment">// // {</span>
  2576. <a name="l02497"></a>02497 <span class="comment">// // public:</span>
  2577. <a name="l02498"></a>02498 <span class="comment">// // </span>
  2578. <a name="l02499"></a>02499 <span class="comment">// // VABS2Model()</span>
  2579. <a name="l02500"></a>02500 <span class="comment">// // {}</span>
  2580. <a name="l02501"></a>02501 <span class="comment">// // </span>
  2581. <a name="l02502"></a>02502 <span class="comment">// // virtual ~VABS2Model()</span>
  2582. <a name="l02503"></a>02503 <span class="comment">// // {}</span>
  2583. <a name="l02504"></a>02504 <span class="comment">// // </span>
  2584. <a name="l02505"></a>02505 <span class="comment">// // // This is a function that provides the mesh to the vabs model</span>
  2585. <a name="l02506"></a>02506 <span class="comment">// // virtual void setMesh(mesh&lt;dataType&gt;* cxMesh_in,bool canDelete_in=false)=0;</span>
  2586. <a name="l02507"></a>02507 <span class="comment">// // // this is teh method that provides the timoshenko beam model</span>
  2587. <a name="l02508"></a>02508 <span class="comment">// // virtual matrixRdWtStaticSqr_Data&lt;dataType,6&gt; beamMatrix()=0;</span>
  2588. <a name="l02509"></a>02509 <span class="comment">// // // this is the method that collects a set of failure statistics</span>
  2589. <a name="l02510"></a>02510 <span class="comment">// // virtual void getFailList(const matrixStaticVectCol&lt;dataType&gt;&amp; beamStrain, std::list&lt;failType&gt;&amp; failList)=0;</span>
  2590. <a name="l02511"></a>02511 <span class="comment">// // };</span>
  2591. <a name="l02512"></a>02512
  2592. <a name="l02513"></a>02513 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2593. <a name="l02514"></a><a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html">02514</a> <span class="keyword">class </span><a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html">VABS2ElmInfo_fromVABS1ElmInfo</a> : <span class="keyword">public</span> <a class="code" href="classVABSElementInfo.html">VABSElementInfo</a>&lt;dataType,matrixStaticVectCol&lt;dataType,6&gt; &gt;
  2594. <a name="l02515"></a>02515 {
  2595. <a name="l02516"></a>02516 <span class="keyword">private</span>:
  2596. <a name="l02517"></a>02517
  2597. <a name="l02518"></a>02518 <a class="code" href="classVABSElementInfo.html">VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,4&gt;</a> &gt;* vabs1Elm;
  2598. <a name="l02519"></a>02519 <span class="keywordtype">bool</span> canDelete;
  2599. <a name="l02520"></a>02520
  2600. <a name="l02521"></a>02521 <span class="keyword">public</span>:
  2601. <a name="l02522"></a>02522
  2602. <a name="l02523"></a><a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#ada906bd4f37e7a84c52efc43ced59344">02523</a> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#ada906bd4f37e7a84c52efc43ced59344">VABS2ElmInfo_fromVABS1ElmInfo</a>(<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol&lt;dataType,4&gt;</a> &gt;* vabs1Elm_in=NULL,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : vabs1Elm(vabs1Elm_in) , canDelete(canDelete_in)
  2603. <a name="l02524"></a>02524 {}
  2604. <a name="l02525"></a>02525
  2605. <a name="l02526"></a><a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#a77d62b9f0a5b14ce0c7c4c076e7ccf04">02526</a> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#ada906bd4f37e7a84c52efc43ced59344">VABS2ElmInfo_fromVABS1ElmInfo</a>(<span class="keyword">const</span> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html">VABS2ElmInfo_fromVABS1ElmInfo&lt;dataType&gt;</a>&amp; asg) : vabs1Elm(asg.vabs1Elm) , canDelete(false)
  2606. <a name="l02527"></a>02527 {}
  2607. <a name="l02528"></a>02528
  2608. <a name="l02529"></a><a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#a1b3acaa9f6e29a8ceae3713df1608c5a">02529</a> <span class="keyword">virtual</span> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#a1b3acaa9f6e29a8ceae3713df1608c5a">~VABS2ElmInfo_fromVABS1ElmInfo</a>()
  2609. <a name="l02530"></a>02530 {
  2610. <a name="l02531"></a>02531 <span class="keywordflow">if</span>(canDelete &amp;&amp; vabs1Elm!=NULL)
  2611. <a name="l02532"></a>02532 <span class="keyword">delete</span> vabs1Elm;
  2612. <a name="l02533"></a>02533 }
  2613. <a name="l02534"></a>02534
  2614. <a name="l02535"></a><a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#a130856510b8c96e68504dc880ff769bc">02535</a> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html">VABS2ElmInfo_fromVABS1ElmInfo&lt;dataType&gt;</a>&amp; <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#a130856510b8c96e68504dc880ff769bc">operator=</a>(<span class="keyword">const</span> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html">VABS2ElmInfo_fromVABS1ElmInfo&lt;dataType&gt;</a>&amp; asg)
  2615. <a name="l02536"></a>02536 {
  2616. <a name="l02537"></a>02537 this-&gt;vabs1Elm=asg.vabs1Elm;
  2617. <a name="l02538"></a>02538 this-&gt;canDelete=<span class="keyword">false</span>;
  2618. <a name="l02539"></a>02539 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  2619. <a name="l02540"></a>02540 }
  2620. <a name="l02541"></a>02541
  2621. <a name="l02542"></a><a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#a5cec266f790a45ffe1e94c067c95f7f2">02542</a> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html">VABS2ElmInfo_fromVABS1ElmInfo&lt;dataType&gt;</a>&amp; <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#a5cec266f790a45ffe1e94c067c95f7f2">setVABSElementInfo</a>(<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol&lt;dataType,4&gt;</a> &gt;* vabs1Elm_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
  2622. <a name="l02543"></a>02543 {
  2623. <a name="l02544"></a>02544 vabs1Elm=vabs1Elm_in;
  2624. <a name="l02545"></a>02545 canDelete=canDelete_in;
  2625. <a name="l02546"></a>02546 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  2626. <a name="l02547"></a>02547 }
  2627. <a name="l02548"></a>02548
  2628. <a name="l02549"></a><a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#ac2c25633f73399d0afffa177724b7349">02549</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#ac2c25633f73399d0afffa177724b7349">fail</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> t,<span class="keyword">const</span> <a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol&lt;dataType,6&gt;</a>&amp; beamStrain)
  2629. <a name="l02550"></a>02550 {
  2630. <a name="l02551"></a>02551 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data&lt;dataType,4&gt;</a> bernoulliStrain;
  2631. <a name="l02552"></a>02552
  2632. <a name="l02553"></a>02553 <span class="keywordflow">if</span>(vabs1Elm==NULL)
  2633. <a name="l02554"></a>02554 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS2ElmInfo_fromVABS1ElmInfo::fail(): The vabs1 element has not been set&quot;</span>);
  2634. <a name="l02555"></a>02555
  2635. <a name="l02556"></a>02556 bernoulliStrain.<a class="code" href="classmatrixRdWtVect.html#ab6754006e5bfc55c5a3ade09cb9f5a65">entry</a>(0)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(0);
  2636. <a name="l02557"></a>02557 bernoulliStrain.<a class="code" href="classmatrixRdWtVect.html#ab6754006e5bfc55c5a3ade09cb9f5a65">entry</a>(1)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(3);
  2637. <a name="l02558"></a>02558 bernoulliStrain.<a class="code" href="classmatrixRdWtVect.html#ab6754006e5bfc55c5a3ade09cb9f5a65">entry</a>(2)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(4);
  2638. <a name="l02559"></a>02559 bernoulliStrain.<a class="code" href="classmatrixRdWtVect.html#ab6754006e5bfc55c5a3ade09cb9f5a65">entry</a>(3)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(5);
  2639. <a name="l02560"></a>02560
  2640. <a name="l02561"></a>02561 <span class="keywordflow">return</span> vabs1Elm-&gt;<a class="code" href="classVABSElementInfo.html#a20130a423f8b19120fbf4be6361283f7">fail</a>(s,t,bernoulliStrain);
  2641. <a name="l02562"></a>02562 }
  2642. <a name="l02563"></a>02563
  2643. <a name="l02564"></a>02564 };
  2644. <a name="l02565"></a>02565
  2645. <a name="l02566"></a>02566 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2646. <a name="l02567"></a><a class="code" href="classVABS2Model__fromVABS1Model.html">02567</a> <span class="keyword">class </span><a class="code" href="classVABS2Model__fromVABS1Model.html">VABS2Model_fromVABS1Model</a> : <span class="keyword">public</span> <a class="code" href="classVABSModel.html">VABSModel</a>&lt;dataType,matrixRdWtStaticSqr_Data&lt;dataType,6&gt;,VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,6&gt; &gt; &gt;
  2647. <a name="l02568"></a>02568 {
  2648. <a name="l02569"></a>02569 <span class="keyword">private</span>:
  2649. <a name="l02570"></a>02570
  2650. <a name="l02571"></a>02571 <a class="code" href="classVABSModel.html">VABSModel&lt;dataType,matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a>,<a class="code" href="classVABSElementInfo.html">VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,4&gt;</a> &gt; &gt;* vabs1;
  2651. <a name="l02572"></a>02572 <span class="keywordtype">bool</span> canDelete;
  2652. <a name="l02573"></a>02573
  2653. <a name="l02574"></a>02574 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> shearConstant;
  2654. <a name="l02575"></a>02575
  2655. <a name="l02576"></a>02576 <span class="keyword">public</span>:
  2656. <a name="l02577"></a>02577
  2657. <a name="l02578"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#a6233560e391d20ea02bdc731c0e8a0ce">02578</a> <a class="code" href="classVABS2Model__fromVABS1Model.html#a6233560e391d20ea02bdc731c0e8a0ce">VABS2Model_fromVABS1Model</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> shearConstant_in=1000.0,<a class="code" href="classVABSModel.html">VABSModel</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a>,<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol&lt;dataType,4&gt;</a> &gt; &gt;* vabs1_in=NULL,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : vabs1(vabs1_in) , canDelete(canDelete_in) , shearConstant(shearConstant_in)
  2658. <a name="l02579"></a>02579 {}
  2659. <a name="l02580"></a>02580
  2660. <a name="l02581"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#a8b9ba93da21bf2cb3df8a2f4e3ed1cf3">02581</a> <span class="keyword">virtual</span> <a class="code" href="classVABS2Model__fromVABS1Model.html#a8b9ba93da21bf2cb3df8a2f4e3ed1cf3">~VABS2Model_fromVABS1Model</a>()
  2661. <a name="l02582"></a>02582 {
  2662. <a name="l02583"></a>02583 <span class="keywordflow">if</span>(canDelete &amp;&amp; vabs1!=NULL)
  2663. <a name="l02584"></a>02584 <span class="keyword">delete</span> vabs1;
  2664. <a name="l02585"></a>02585 }
  2665. <a name="l02586"></a>02586
  2666. <a name="l02587"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#a1cb16a485393183c2fc7d21716e74879">02587</a> <span class="keywordtype">void</span> <a class="code" href="classVABS2Model__fromVABS1Model.html#a1cb16a485393183c2fc7d21716e74879">setVABS1</a>(<a class="code" href="classVABSModel.html">VABSModel</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a>,<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol&lt;dataType,4&gt;</a> &gt; &gt;* vabs1_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
  2667. <a name="l02588"></a>02588 {
  2668. <a name="l02589"></a>02589 <span class="keywordflow">if</span>(vabs1_in==vabs1)
  2669. <a name="l02590"></a>02590 {
  2670. <a name="l02591"></a>02591 canDelete=canDelete_in;
  2671. <a name="l02592"></a>02592 <span class="keywordflow">return</span>;
  2672. <a name="l02593"></a>02593 }
  2673. <a name="l02594"></a>02594 <span class="keywordflow">if</span>(canDelete &amp;&amp; vabs1!=NULL)
  2674. <a name="l02595"></a>02595 <span class="keyword">delete</span> vabs1;
  2675. <a name="l02596"></a>02596 vabs1=vabs1_in;
  2676. <a name="l02597"></a>02597 canDelete=canDelete_in;
  2677. <a name="l02598"></a>02598 }
  2678. <a name="l02599"></a>02599
  2679. <a name="l02600"></a>02600 <span class="comment">// This is a function that provides the mesh to the vabs model</span>
  2680. <a name="l02601"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#a6304f767b6af7875075ec0de60cea779">02601</a> <span class="keywordtype">void</span> <a class="code" href="classVABS2Model__fromVABS1Model.html#a6304f767b6af7875075ec0de60cea779">setMesh</a>(<a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>* cxMesh_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
  2681. <a name="l02602"></a>02602 {
  2682. <a name="l02603"></a>02603 <span class="keywordflow">if</span>(vabs1==NULL)
  2683. <a name="l02604"></a>02604 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS2Model_fromVABS1Model::setMesh(): The vabs 1 model has not been set&quot;</span>);
  2684. <a name="l02605"></a>02605 vabs1-&gt;<a class="code" href="classVABSModelInput.html#a34bb1d411f8b8303d932e0a1503fba25">setMesh</a>(cxMesh_in,canDelete_in);
  2685. <a name="l02606"></a>02606 }
  2686. <a name="l02607"></a>02607
  2687. <a name="l02608"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#afd8a5791697f589ceca5a160bcfda8a3">02608</a> <span class="keywordtype">void</span> <a class="code" href="classVABS2Model__fromVABS1Model.html#afd8a5791697f589ceca5a160bcfda8a3">buildSVD</a>()
  2688. <a name="l02609"></a>02609 {
  2689. <a name="l02610"></a>02610 <span class="keywordflow">if</span>(vabs1==NULL)
  2690. <a name="l02611"></a>02611 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS2Model_fromVABS1Model::solve(): The vabs 1 model has not been set&quot;</span>);
  2691. <a name="l02612"></a>02612
  2692. <a name="l02613"></a>02613 vabs1-&gt;<a class="code" href="classVABSModelInput.html#ae9e0c54fac2464d9f13a599c5af1784a">buildSVD</a>();
  2693. <a name="l02614"></a>02614 }
  2694. <a name="l02615"></a>02615
  2695. <a name="l02616"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#ab6ea58a1bff23273173dea10f7eaa7c6">02616</a> <span class="keywordtype">void</span> <a class="code" href="classVABS2Model__fromVABS1Model.html#ab6ea58a1bff23273173dea10f7eaa7c6">solveSVD</a>()
  2696. <a name="l02617"></a>02617 {
  2697. <a name="l02618"></a>02618 <span class="keywordflow">if</span>(vabs1==NULL)
  2698. <a name="l02619"></a>02619 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS2Model_fromVABS1Model::solve(): The vabs 1 model has not been set&quot;</span>);
  2699. <a name="l02620"></a>02620
  2700. <a name="l02621"></a>02621 vabs1-&gt;<a class="code" href="classVABSModelInput.html#aa964d19fe486ffc21a58e341a34ab2d8">solveSVD</a>();
  2701. <a name="l02622"></a>02622 }
  2702. <a name="l02623"></a>02623
  2703. <a name="l02624"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#aa4dba2ae9fbac8ec6214353e295ba3e9">02624</a> <span class="keywordtype">void</span> <a class="code" href="classVABS2Model__fromVABS1Model.html#aa4dba2ae9fbac8ec6214353e295ba3e9">processSVD</a>()
  2704. <a name="l02625"></a>02625 {
  2705. <a name="l02626"></a>02626 <span class="keywordflow">if</span>(vabs1==NULL)
  2706. <a name="l02627"></a>02627 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS2Model_fromVABS1Model::solve(): The vabs 1 model has not been set&quot;</span>);
  2707. <a name="l02628"></a>02628
  2708. <a name="l02629"></a>02629 vabs1-&gt;<a class="code" href="classVABSModelInput.html#aa1e92195b3ac2661ec4e001d4b2f6c47">processSVD</a>();
  2709. <a name="l02630"></a>02630 }
  2710. <a name="l02631"></a>02631
  2711. <a name="l02632"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#aba72098ecdab147dc715be6a784007da">02632</a> <span class="keywordtype">void</span> <a class="code" href="classVABS2Model__fromVABS1Model.html#aba72098ecdab147dc715be6a784007da">solve</a>()
  2712. <a name="l02633"></a>02633 {
  2713. <a name="l02634"></a>02634 <span class="keywordflow">if</span>(vabs1==NULL)
  2714. <a name="l02635"></a>02635 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS2Model_fromVABS1Model::solve(): The vabs 1 model has not been set&quot;</span>);
  2715. <a name="l02636"></a>02636
  2716. <a name="l02637"></a>02637 vabs1-&gt;<a class="code" href="classVABSModelInput.html#a14f9d151b0d089a8a140418264b1ff15">solve</a>();
  2717. <a name="l02638"></a>02638 }
  2718. <a name="l02639"></a>02639
  2719. <a name="l02640"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#ad7c5d9724a3bddda2532d29425598b03">02640</a> <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,6&gt;</a> <a class="code" href="classVABS2Model__fromVABS1Model.html#ad7c5d9724a3bddda2532d29425598b03">beamMatrix</a>()
  2720. <a name="l02641"></a>02641 {
  2721. <a name="l02642"></a>02642 <span class="keywordflow">if</span>(vabs1==NULL)
  2722. <a name="l02643"></a>02643 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS2Model_fromVABS1Model::beamMatrix(): The vabs 1 model has not been set&quot;</span>);
  2723. <a name="l02644"></a>02644
  2724. <a name="l02645"></a>02645 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,6&gt;</a> retVal=<a class="code" href="classmatrixStatic__Zero.html">matrixStatic_Zero&lt;dataType,6,6&gt;</a>();
  2725. <a name="l02646"></a>02646 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> vabs1Result=vabs1-&gt;<a class="code" href="classVABSModelBeamMatrix.html#ad74f2717ec4415b3603ba49f42403b0c">beamMatrix</a>();
  2726. <a name="l02647"></a>02647 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  2727. <a name="l02648"></a>02648 {
  2728. <a name="l02649"></a>02649 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> atI=<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>;
  2729. <a name="l02650"></a>02650 <span class="keywordflow">if</span>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&gt;0)
  2730. <a name="l02651"></a>02651 atI+=2;
  2731. <a name="l02652"></a>02652 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;4;j++)
  2732. <a name="l02653"></a>02653 {
  2733. <a name="l02654"></a>02654 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> atJ=j;
  2734. <a name="l02655"></a>02655 <span class="keywordflow">if</span>(j&gt;0)
  2735. <a name="l02656"></a>02656 atJ+=2;
  2736. <a name="l02657"></a>02657 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(atI,atJ)=vabs1Result.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>,j);
  2737. <a name="l02658"></a>02658 <span class="comment">// if(i==j) retVal.entry(atI,atJ)=vabs1Result.entry(i,j);</span>
  2738. <a name="l02659"></a>02659 }
  2739. <a name="l02660"></a>02660 }
  2740. <a name="l02661"></a>02661 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(1,1)=shearConstant*retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(0,0);
  2741. <a name="l02662"></a>02662 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(2,2)=shearConstant*retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(0,0);
  2742. <a name="l02663"></a>02663
  2743. <a name="l02664"></a>02664 <span class="keywordflow">return</span> retVal;
  2744. <a name="l02665"></a>02665 }
  2745. <a name="l02666"></a>02666
  2746. <a name="l02667"></a>02667 <span class="comment">// A method that informs the post process module about the number of elements</span>
  2747. <a name="l02668"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#af9441292ddf3a5a0d2e4629025268a46">02668</a> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classVABS2Model__fromVABS1Model.html#af9441292ddf3a5a0d2e4629025268a46">size</a>()
  2748. <a name="l02669"></a>02669 {
  2749. <a name="l02670"></a>02670 <span class="keywordflow">if</span>(vabs1==NULL)
  2750. <a name="l02671"></a>02671 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS2Model_fromVABS1Model::size(): The vabs model has not been set&quot;</span>);
  2751. <a name="l02672"></a>02672 <span class="keywordflow">return</span> vabs1-&gt;<a class="code" href="classVABSModelPost.html#a476038f832b9ef6181ac62f3874fd0ec">size</a>();
  2752. <a name="l02673"></a>02673 }
  2753. <a name="l02674"></a>02674
  2754. <a name="l02675"></a>02675 <span class="comment">// This is an access method to perform post processing</span>
  2755. <a name="l02676"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#a371b92b54277066775273a8af5c1cf2a">02676</a> <a class="code" href="classautoPntr.html">autoPntr&lt; VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,6&gt;</a> &gt; &gt; <a class="code" href="classVABS2Model__fromVABS1Model.html#a371b92b54277066775273a8af5c1cf2a">getElement</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)
  2756. <a name="l02677"></a>02677 {
  2757. <a name="l02678"></a>02678 <span class="keywordflow">if</span>(vabs1==NULL)
  2758. <a name="l02679"></a>02679 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABS2Model_fromVABS1Model::getElement(): The vabs model has not been set&quot;</span>);
  2759. <a name="l02680"></a>02680
  2760. <a name="l02681"></a>02681 <a class="code" href="classautoPntr.html">autoPntr&lt;VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,4&gt;</a> &gt; &gt; elm4Pntr=vabs1-&gt;<a class="code" href="classVABSModelPost.html#ab22c953c94473d150d7b45b30833969d">getElement</a>(at);
  2761. <a name="l02682"></a>02682 <span class="keywordtype">bool</span> shouldDelete=elm4Pntr.<a class="code" href="classautoPntr.html#aeff67239fbb801ebdf76d8e8e6f242bc">deleteStatus</a>();
  2762. <a name="l02683"></a>02683 <span class="keywordflow">return</span> <a class="code" href="classautoPntr.html">autoPntr&lt;VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,6&gt;</a> &gt; &gt;(<span class="keyword">new</span> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html">VABS2ElmInfo_fromVABS1ElmInfo&lt;dataType&gt;</a>(elm4Pntr.<a class="code" href="classautoPntr.html#a3533ca63305b90c93c617ca4cb40f9e6">release</a>(),shouldDelete),<span class="keyword">true</span>);
  2763. <a name="l02684"></a>02684 }
  2764. <a name="l02685"></a>02685
  2765. <a name="l02686"></a>02686 <span class="comment">// void getFailList(const matrixStaticVectCol&lt;dataType&gt;&amp; beamStrain, std::list&lt;failPoint&lt;dataType&gt;&gt;&amp; failList)</span>
  2766. <a name="l02687"></a>02687 <span class="comment">// {</span>
  2767. <a name="l02688"></a>02688 <span class="comment">// if(vabs1==NULL)</span>
  2768. <a name="l02689"></a>02689 <span class="comment">// throw eMsg(&quot;VABS2Model_VABS1Model::getFailList(): The vabs 1 model has not been set&quot;);</span>
  2769. <a name="l02690"></a>02690 <span class="comment">// vabs1-&gt;getFailList(beamStrain,failList);</span>
  2770. <a name="l02691"></a>02691 <span class="comment">// }</span>
  2771. <a name="l02692"></a>02692
  2772. <a name="l02693"></a>02693 };
  2773. <a name="l02694"></a>02694
  2774. <a name="l02695"></a>02695 <span class="comment">// the vabs module determines various physical quantities with respect to a mesh scaled</span>
  2775. <a name="l02696"></a>02696 <span class="comment">// The mesh is generally based on geometry with a reference length. In most cases the chord length is one unit</span>
  2776. <a name="l02697"></a>02697 <span class="comment">// However the real chord length is something else lets say c.</span>
  2777. <a name="l02698"></a>02698 <span class="comment">// In this case we need a scale (real chord length)/(reference length)</span>
  2778. <a name="l02699"></a>02699 <span class="comment">// in the typical case where the reference length is unity, then this scale is merely real chord length</span>
  2779. <a name="l02700"></a>02700 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2780. <a name="l02701"></a><a class="code" href="classscaling.html">02701</a> <span class="keyword">class </span><a class="code" href="classscaling.html">scaling</a>
  2781. <a name="l02702"></a>02702 {
  2782. <a name="l02703"></a>02703 <span class="keyword">private</span>:
  2783. <a name="l02704"></a>02704
  2784. <a name="l02705"></a>02705 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale; <span class="comment">// this is the ratio of real L / reference L</span>
  2785. <a name="l02706"></a>02706
  2786. <a name="l02707"></a>02707 <span class="keyword">protected</span>:
  2787. <a name="l02708"></a>02708
  2788. <a name="l02709"></a>02709 <span class="comment">// #####################################</span>
  2789. <a name="l02710"></a>02710 <span class="comment">// The followign methods return coefficients that convert various quantities between the reference and real system</span>
  2790. <a name="l02711"></a>02711 <span class="comment">// #####################################</span>
  2791. <a name="l02712"></a>02712
  2792. <a name="l02713"></a>02713 <span class="comment">// these methods simply scale the length</span>
  2793. <a name="l02714"></a>02714
  2794. <a name="l02715"></a><a class="code" href="classscaling.html#aaa8ca0c232c882036494a978ac7cbe75">02715</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscaling.html#aac7e81203dc733ae8a467ca89c34d640">referenceToRealScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="namespaceViewWake.html#a7f186dc00f139878e136f6c3b4d10e71">scale</a>)<span class="keyword"> const</span>
  2795. <a name="l02716"></a>02716 <span class="keyword"> </span>{
  2796. <a name="l02717"></a>02717 <span class="keywordflow">return</span> <a class="code" href="namespaceViewWake.html#a7f186dc00f139878e136f6c3b4d10e71">scale</a>;
  2797. <a name="l02718"></a>02718 }
  2798. <a name="l02719"></a>02719
  2799. <a name="l02720"></a><a class="code" href="classscaling.html#aac7e81203dc733ae8a467ca89c34d640">02720</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscaling.html#aac7e81203dc733ae8a467ca89c34d640">referenceToRealScale</a>()<span class="keyword"> const</span>
  2800. <a name="l02721"></a>02721 <span class="keyword"> </span>{
  2801. <a name="l02722"></a>02722 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#aac7e81203dc733ae8a467ca89c34d640">referenceToRealScale</a>(defaultScale);
  2802. <a name="l02723"></a>02723 }
  2803. <a name="l02724"></a>02724
  2804. <a name="l02725"></a><a class="code" href="classscaling.html#acaa514589165141bf608c3384abf4492">02725</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscaling.html#a17caca9a9ac0e89bdf1bcddd35d7382b">realToReferenceScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="namespaceViewWake.html#a7f186dc00f139878e136f6c3b4d10e71">scale</a>)<span class="keyword"> const</span>
  2805. <a name="l02726"></a>02726 <span class="keyword"> </span>{
  2806. <a name="l02727"></a>02727 <span class="keywordflow">return</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>(1.0)/<a class="code" href="namespaceViewWake.html#a7f186dc00f139878e136f6c3b4d10e71">scale</a>;
  2807. <a name="l02728"></a>02728 }
  2808. <a name="l02729"></a>02729
  2809. <a name="l02730"></a><a class="code" href="classscaling.html#a17caca9a9ac0e89bdf1bcddd35d7382b">02730</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscaling.html#a17caca9a9ac0e89bdf1bcddd35d7382b">realToReferenceScale</a>()<span class="keyword"> const</span>
  2810. <a name="l02731"></a>02731 <span class="keyword"> </span>{
  2811. <a name="l02732"></a>02732 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#a17caca9a9ac0e89bdf1bcddd35d7382b">realToReferenceScale</a>(defaultScale);
  2812. <a name="l02733"></a>02733 }
  2813. <a name="l02734"></a>02734
  2814. <a name="l02735"></a>02735 <span class="comment">// these methods scale other physical quantities based on a length scale given as an argument</span>
  2815. <a name="l02736"></a>02736
  2816. <a name="l02737"></a><a class="code" href="classscaling.html#a00e1dcb12d1308ecc77c57ee8d2eb21c">02737</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscaling.html#a00e1dcb12d1308ecc77c57ee8d2eb21c">pressureScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> lengthScale)<span class="keyword"> const</span>
  2817. <a name="l02738"></a>02738 <span class="keyword"> </span>{
  2818. <a name="l02739"></a>02739 <span class="keywordflow">return</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>(1.0)/lengthScale;
  2819. <a name="l02740"></a>02740 }
  2820. <a name="l02741"></a>02741
  2821. <a name="l02742"></a><a class="code" href="classscaling.html#a3003829a4fb8ac09164f2c18abc429aa">02742</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscaling.html#a3003829a4fb8ac09164f2c18abc429aa">forceScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> lengthScale)<span class="keyword"> const</span>
  2822. <a name="l02743"></a>02743 <span class="keyword"> </span>{
  2823. <a name="l02744"></a>02744 <span class="keywordflow">return</span> lengthScale;
  2824. <a name="l02745"></a>02745 }
  2825. <a name="l02746"></a>02746
  2826. <a name="l02747"></a><a class="code" href="classscaling.html#a34b661aaa9affea1c7d2f67923a14e62">02747</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscaling.html#a34b661aaa9affea1c7d2f67923a14e62">momentScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> lengthScale)<span class="keyword"> const</span>
  2827. <a name="l02748"></a>02748 <span class="keyword"> </span>{
  2828. <a name="l02749"></a>02749 <span class="keywordflow">return</span> pow(lengthScale,2.0);
  2829. <a name="l02750"></a>02750 }
  2830. <a name="l02751"></a>02751
  2831. <a name="l02752"></a><a class="code" href="classscaling.html#aff9eeb5a1d8f09cb38de91196972a15c">02752</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscaling.html#aff9eeb5a1d8f09cb38de91196972a15c">curvatureScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> lengthScale)<span class="keyword"> const</span>
  2832. <a name="l02753"></a>02753 <span class="keyword"> </span>{
  2833. <a name="l02754"></a>02754 <span class="keywordflow">return</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>(1.0)/lengthScale;
  2834. <a name="l02755"></a>02755 }
  2835. <a name="l02756"></a>02756
  2836. <a name="l02757"></a><a class="code" href="classscaling.html#a1ff8be1bc53c7fc91951ba9f10c41518">02757</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscaling.html#a1ff8be1bc53c7fc91951ba9f10c41518">areaScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> lengthScale)<span class="keyword"> const</span>
  2837. <a name="l02758"></a>02758 <span class="keyword"> </span>{
  2838. <a name="l02759"></a>02759 <span class="keywordflow">return</span> pow(lengthScale,2.0);
  2839. <a name="l02760"></a>02760 }
  2840. <a name="l02761"></a>02761
  2841. <a name="l02762"></a><a class="code" href="classscaling.html#af84bc45022ad992488c57661462c696f">02762</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscaling.html#af84bc45022ad992488c57661462c696f">secondMomentScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> lengthScale)<span class="keyword"> const</span>
  2842. <a name="l02763"></a>02763 <span class="keyword"> </span>{
  2843. <a name="l02764"></a>02764 <span class="keywordflow">return</span> pow(lengthScale,4.0);
  2844. <a name="l02765"></a>02765 }
  2845. <a name="l02766"></a>02766
  2846. <a name="l02767"></a>02767 <span class="keyword">public</span>:
  2847. <a name="l02768"></a>02768
  2848. <a name="l02769"></a><a class="code" href="classscaling.html#a077c92c6fa4bad7bc345a8e78bac0e34">02769</a> <a class="code" href="classscaling.html#a077c92c6fa4bad7bc345a8e78bac0e34">scaling</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in=1.0) : defaultScale(defaultScale_in)
  2849. <a name="l02770"></a>02770 {}
  2850. <a name="l02771"></a>02771
  2851. <a name="l02772"></a><a class="code" href="classscaling.html#ac12d0b050c39b690ea4c930aacde81fa">02772</a> <a class="code" href="classscaling.html#a077c92c6fa4bad7bc345a8e78bac0e34">scaling</a>(<span class="keyword">const</span> <a class="code" href="classscaling.html">scaling&lt;dataType&gt;</a>&amp; asg) : defaultScale(asg.defaultScale)
  2852. <a name="l02773"></a>02773 {}
  2853. <a name="l02774"></a>02774
  2854. <a name="l02775"></a><a class="code" href="classscaling.html#a65e5b4e73369a519f85ee8cbfe25b381">02775</a> <span class="keyword">virtual</span> <a class="code" href="classscaling.html#a65e5b4e73369a519f85ee8cbfe25b381">~scaling</a>()
  2855. <a name="l02776"></a>02776 {}
  2856. <a name="l02777"></a>02777
  2857. <a name="l02778"></a><a class="code" href="classscaling.html#aeff03c9d32f3ece3db8c61db83591eb6">02778</a> <span class="keywordtype">void</span> <a class="code" href="classscaling.html#aeff03c9d32f3ece3db8c61db83591eb6">setDefaultScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in)
  2858. <a name="l02779"></a>02779 {
  2859. <a name="l02780"></a>02780 defaultScale=defaultScale_in;
  2860. <a name="l02781"></a>02781 }
  2861. <a name="l02782"></a>02782
  2862. <a name="l02783"></a><a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">02783</a> <span class="keyword">const</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&amp; <a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>()<span class="keyword"> const</span>
  2863. <a name="l02784"></a>02784 <span class="keyword"> </span>{
  2864. <a name="l02785"></a>02785 <span class="keywordflow">return</span> defaultScale;
  2865. <a name="l02786"></a>02786 }
  2866. <a name="l02787"></a>02787 };
  2867. <a name="l02788"></a>02788
  2868. <a name="l02789"></a>02789 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> abstractType&gt;
  2869. <a name="l02790"></a><a class="code" href="classscalingObject.html">02790</a> <span class="keyword">class </span><a class="code" href="classscalingObject.html">scalingObject</a> : <span class="keyword">public</span> <a class="code" href="classscaling.html">scaling</a>&lt;dataType&gt; , <span class="keyword">public</span> abstractType
  2870. <a name="l02791"></a>02791 {
  2871. <a name="l02792"></a>02792 <span class="keyword">protected</span>:
  2872. <a name="l02793"></a>02793
  2873. <a name="l02794"></a>02794 <span class="keyword">virtual</span> abstractType&amp; <a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>()=0;
  2874. <a name="l02795"></a>02795 <span class="keyword">virtual</span> <span class="keyword">const</span> abstractType&amp; <a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>() <span class="keyword">const</span>=0;
  2875. <a name="l02796"></a>02796
  2876. <a name="l02797"></a>02797 <span class="keyword">public</span>:
  2877. <a name="l02798"></a>02798
  2878. <a name="l02799"></a><a class="code" href="classscalingObject.html#ab6dfdb6e69938a4f5e70a73ce9036131">02799</a> <a class="code" href="classscalingObject.html#ab6dfdb6e69938a4f5e70a73ce9036131">scalingObject</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in=1.0) : <a class="code" href="classscaling.html">scaling</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt;(defaultScale_in)
  2879. <a name="l02800"></a>02800 {}
  2880. <a name="l02801"></a>02801
  2881. <a name="l02802"></a><a class="code" href="classscalingObject.html#ab3de889f8dd041f481eb23da14371fa7">02802</a> <span class="keyword">virtual</span> <a class="code" href="classscalingObject.html#ab3de889f8dd041f481eb23da14371fa7">~scalingObject</a>()
  2882. <a name="l02803"></a>02803 {}
  2883. <a name="l02804"></a>02804
  2884. <a name="l02805"></a><a class="code" href="classscalingObject.html#ad0f703a14521945e34417f5bbc84ba77">02805</a> <a class="code" href="classscalingObject.html">scalingObject&lt;dataType,abstractType&gt;</a>&amp; <a class="code" href="classscalingObject.html#ad0f703a14521945e34417f5bbc84ba77">setDefaultScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in)
  2885. <a name="l02806"></a>02806 {
  2886. <a name="l02807"></a>02807 this-&gt;<a class="code" href="classscalingObject.html#ad0f703a14521945e34417f5bbc84ba77">scaling&lt;dataType&gt;::setDefaultScale</a>(defaultScale_in);
  2887. <a name="l02808"></a>02808 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  2888. <a name="l02809"></a>02809 }
  2889. <a name="l02810"></a>02810 };
  2890. <a name="l02811"></a>02811
  2891. <a name="l02812"></a>02812 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> abstractType&gt;
  2892. <a name="l02813"></a><a class="code" href="classscalingObject__Ref.html">02813</a> <span class="keyword">class </span><a class="code" href="classscalingObject__Ref.html">scalingObject_Ref</a> : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classscalingObject.html">scalingObject</a>&lt;dataType,abstractType&gt;
  2893. <a name="l02814"></a>02814 {
  2894. <a name="l02815"></a>02815 <span class="keyword">private</span>:
  2895. <a name="l02816"></a>02816
  2896. <a name="l02817"></a>02817 abstractType&amp; ref;
  2897. <a name="l02818"></a>02818
  2898. <a name="l02819"></a>02819 <span class="keyword">protected</span>:
  2899. <a name="l02820"></a>02820
  2900. <a name="l02821"></a><a class="code" href="classscalingObject__Ref.html#ab9e979697cb6fc23c900ec0095106d39">02821</a> abstractType&amp; <a class="code" href="classscalingObject__Ref.html#ab9e979697cb6fc23c900ec0095106d39">getAbstract</a>()
  2901. <a name="l02822"></a>02822 {
  2902. <a name="l02823"></a>02823 <span class="keywordflow">return</span> ref;
  2903. <a name="l02824"></a>02824 }
  2904. <a name="l02825"></a>02825
  2905. <a name="l02826"></a><a class="code" href="classscalingObject__Ref.html#ac45acc04491ab272ab2b6c3e66008251">02826</a> <span class="keyword">const</span> abstractType&amp; <a class="code" href="classscalingObject__Ref.html#ab9e979697cb6fc23c900ec0095106d39">getAbstract</a>()<span class="keyword"> const</span>
  2906. <a name="l02827"></a>02827 <span class="keyword"> </span>{
  2907. <a name="l02828"></a>02828 <span class="keywordflow">return</span> ref;
  2908. <a name="l02829"></a>02829 }
  2909. <a name="l02830"></a>02830
  2910. <a name="l02831"></a>02831 <span class="keyword">public</span>:
  2911. <a name="l02832"></a>02832
  2912. <a name="l02833"></a><a class="code" href="classscalingObject__Ref.html#a50c6966af24b04a43d848d73675d8d90">02833</a> <a class="code" href="classscalingObject__Ref.html#a50c6966af24b04a43d848d73675d8d90">scalingObject_Ref</a>(abstractType&amp; ref_in,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in=1.0) : ref(ref_in)
  2913. <a name="l02834"></a>02834 {
  2914. <a name="l02835"></a>02835 this-&gt;<a class="code" href="classscalingObject.html#ad0f703a14521945e34417f5bbc84ba77">setDefaultScale</a>(defaultScale_in);
  2915. <a name="l02836"></a>02836 }
  2916. <a name="l02837"></a>02837
  2917. <a name="l02838"></a><a class="code" href="classscalingObject__Ref.html#a2c8bbb85c2d92989961940c5187c5231">02838</a> <span class="keyword">virtual</span> <a class="code" href="classscalingObject__Ref.html#a2c8bbb85c2d92989961940c5187c5231">~scalingObject_Ref</a>()
  2918. <a name="l02839"></a>02839 {}
  2919. <a name="l02840"></a>02840 };
  2920. <a name="l02841"></a>02841
  2921. <a name="l02842"></a>02842 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> abstractType&gt;
  2922. <a name="l02843"></a><a class="code" href="classscalingObject__Pntr.html">02843</a> <span class="keyword">class </span><a class="code" href="classscalingObject__Pntr.html">scalingObject_Pntr</a> : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classscalingObject.html">scalingObject</a>&lt;dataType,abstractType&gt;
  2923. <a name="l02844"></a>02844 {
  2924. <a name="l02845"></a>02845 <span class="keyword">private</span>:
  2925. <a name="l02846"></a>02846
  2926. <a name="l02847"></a>02847 abstractType* pAbstract;
  2927. <a name="l02848"></a>02848 <span class="keywordtype">bool</span> canDelete;
  2928. <a name="l02849"></a>02849
  2929. <a name="l02850"></a>02850 <span class="keyword">protected</span>:
  2930. <a name="l02851"></a>02851
  2931. <a name="l02852"></a><a class="code" href="classscalingObject__Pntr.html#a5879fda88e332f23c6840911acfff092">02852</a> abstractType&amp; <a class="code" href="classscalingObject__Pntr.html#a5879fda88e332f23c6840911acfff092">getAbstract</a>()
  2932. <a name="l02853"></a>02853 {
  2933. <a name="l02854"></a>02854 <span class="keywordflow">if</span>(pAbstract==NULL)
  2934. <a name="l02855"></a>02855 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;scalingObject_Pntr::getAbstract(): Pointer to the abstract type is NULL&quot;</span>);
  2935. <a name="l02856"></a>02856 <span class="keywordflow">return</span> *pAbstract;
  2936. <a name="l02857"></a>02857 }
  2937. <a name="l02858"></a>02858
  2938. <a name="l02859"></a><a class="code" href="classscalingObject__Pntr.html#a493bea743297d11a1bca4e7fe675e022">02859</a> <span class="keyword">const</span> abstractType&amp; <a class="code" href="classscalingObject__Pntr.html#a5879fda88e332f23c6840911acfff092">getAbstract</a>()<span class="keyword"> const</span>
  2939. <a name="l02860"></a>02860 <span class="keyword"> </span>{
  2940. <a name="l02861"></a>02861 <span class="keywordflow">if</span>(pAbstract==NULL)
  2941. <a name="l02862"></a>02862 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;scalingObject_Pntr::getAbstract(): Pointer to the abstract type is NULL&quot;</span>);
  2942. <a name="l02863"></a>02863 <span class="keywordflow">return</span> *pAbstract;
  2943. <a name="l02864"></a>02864 }
  2944. <a name="l02865"></a>02865
  2945. <a name="l02866"></a>02866 <span class="keyword">public</span>:
  2946. <a name="l02867"></a>02867
  2947. <a name="l02868"></a><a class="code" href="classscalingObject__Pntr.html#a091ee368a07d2b57075e44c4a4b047d0">02868</a> <a class="code" href="classscalingObject__Pntr.html#a091ee368a07d2b57075e44c4a4b047d0">scalingObject_Pntr</a>(abstractType* ref_in=NULL,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in=1.0,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : pAbstract(ref_in) , canDelete(canDelete_in)
  2948. <a name="l02869"></a>02869 {
  2949. <a name="l02870"></a>02870 this-&gt;<a class="code" href="classscalingObject.html#ad0f703a14521945e34417f5bbc84ba77">setDefaultScale</a>(defaultScale_in);
  2950. <a name="l02871"></a>02871 }
  2951. <a name="l02872"></a>02872
  2952. <a name="l02873"></a><a class="code" href="classscalingObject__Pntr.html#adfa2c4037c017856bc9bcebbbca8df62">02873</a> <span class="keyword">virtual</span> <a class="code" href="classscalingObject__Pntr.html#adfa2c4037c017856bc9bcebbbca8df62">~scalingObject_Pntr</a>()
  2953. <a name="l02874"></a>02874 {
  2954. <a name="l02875"></a>02875 <span class="keywordflow">if</span>(canDelete &amp;&amp; pAbstract!=NULL)
  2955. <a name="l02876"></a>02876 <span class="keyword">delete</span> pAbstract;
  2956. <a name="l02877"></a>02877 }
  2957. <a name="l02878"></a>02878
  2958. <a name="l02879"></a><a class="code" href="classscalingObject__Pntr.html#afbdd6daef451689dc355edb8c721138e">02879</a> <a class="code" href="classscalingObject__Pntr.html">scalingObject_Pntr&lt;dataType,abstractType&gt;</a>&amp; <a class="code" href="classscalingObject__Pntr.html#afbdd6daef451689dc355edb8c721138e">setPointer</a>(abstractType* ref_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
  2959. <a name="l02880"></a>02880 {
  2960. <a name="l02881"></a>02881 <span class="keywordflow">if</span>(canDelete &amp;&amp; pAbstract!=NULL)
  2961. <a name="l02882"></a>02882 <span class="keyword">delete</span> pAbstract;
  2962. <a name="l02883"></a>02883
  2963. <a name="l02884"></a>02884 pAbstract=ref_in;
  2964. <a name="l02885"></a>02885 canDelete=canDelete_in;
  2965. <a name="l02886"></a>02886
  2966. <a name="l02887"></a>02887 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  2967. <a name="l02888"></a>02888 }
  2968. <a name="l02889"></a>02889 };
  2969. <a name="l02890"></a>02890
  2970. <a name="l02891"></a>02891 <span class="comment">// This is a template that require specialization</span>
  2971. <a name="l02892"></a>02892 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> strainType&gt;
  2972. <a name="l02893"></a><a class="code" href="classscalingObject__VABSElementInfo.html">02893</a> <span class="keyword">class </span><a class="code" href="classscalingObject__VABSElementInfo.html">scalingObject_VABSElementInfo</a> <span class="comment">// : public virtual scalingObject&lt;dataType,VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,4&gt; &gt; &gt;</span>
  2973. <a name="l02894"></a>02894 {};
  2974. <a name="l02895"></a>02895
  2975. <a name="l02896"></a>02896 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  2976. <a name="l02897"></a><a class="code" href="classscalingObject__VABSElementInfo_3_01dataType_00_01matrixStaticVectCol_3_01dataType_00_014_01_4_01_4.html">02897</a> <span class="keyword">class </span><a class="code" href="classscalingObject__VABSElementInfo.html">scalingObject_VABSElementInfo</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,4&gt; &gt; : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classscalingObject.html">scalingObject</a>&lt;dataType,VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,4&gt; &gt; &gt;
  2977. <a name="l02898"></a>02898 {
  2978. <a name="l02899"></a>02899 <span class="keyword">public</span>:
  2979. <a name="l02900"></a>02900
  2980. <a name="l02901"></a><a class="code" href="classscalingObject__VABSElementInfo_3_01dataType_00_01matrixStaticVectCol_3_01dataType_00_014_01_4_01_4.html#a1531a4fd7fd82ed06d437fba44dd29d2">02901</a> <a class="code" href="classscalingObject__VABSElementInfo.html">scalingObject_VABSElementInfo</a>()
  2981. <a name="l02902"></a>02902 {}
  2982. <a name="l02903"></a>02903
  2983. <a name="l02904"></a><a class="code" href="classscalingObject__VABSElementInfo_3_01dataType_00_01matrixStaticVectCol_3_01dataType_00_014_01_4_01_4.html#aa12c19ea973d4e753affd26a00cc0246">02904</a> <span class="keyword">virtual</span> ~<a class="code" href="classscalingObject__VABSElementInfo.html">scalingObject_VABSElementInfo</a>()
  2984. <a name="l02905"></a>02905 {}
  2985. <a name="l02906"></a>02906
  2986. <a name="l02907"></a><a class="code" href="classscalingObject__VABSElementInfo_3_01dataType_00_01matrixStaticVectCol_3_01dataType_00_014_01_4_01_4.html#a9629a4a09a96be132c0bb71f8e33d926">02907</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> fail(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> t,<span class="keyword">const</span> <a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol&lt;dataType,4&gt;</a>&amp; beamStrain)
  2987. <a name="l02908"></a>02908 {
  2988. <a name="l02909"></a>02909 <span class="keywordflow">return</span> this-&gt;fail_Scaled(s,t,beamStrain,this-&gt;getDefaultScale());
  2989. <a name="l02910"></a>02910 }
  2990. <a name="l02911"></a>02911
  2991. <a name="l02912"></a><a class="code" href="classscalingObject__VABSElementInfo_3_01dataType_00_01matrixStaticVectCol_3_01dataType_00_014_01_4_01_4.html#aebc9764dd621b8fcbdc940593f57a7fa">02912</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> fail_Scaled(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> t,<span class="keyword">const</span> <a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol&lt;dataType,4&gt;</a>&amp; beamStrain,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)
  2992. <a name="l02913"></a>02913 {
  2993. <a name="l02914"></a>02914 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data&lt;dataType,4&gt;</a> scaledBeamStrain;
  2994. <a name="l02915"></a>02915
  2995. <a name="l02916"></a>02916 scaledBeamStrain.<a class="code" href="classmatrixRdWtVect.html#ab6754006e5bfc55c5a3ade09cb9f5a65">entry</a>(0)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(0);
  2996. <a name="l02917"></a>02917 scaledBeamStrain.<a class="code" href="classmatrixRdWtVect.html#ab6754006e5bfc55c5a3ade09cb9f5a65">entry</a>(1)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(1)*this-&gt;curvatureScale(this-&gt;realToReferenceScale(realScale));
  2997. <a name="l02918"></a>02918 scaledBeamStrain.<a class="code" href="classmatrixRdWtVect.html#ab6754006e5bfc55c5a3ade09cb9f5a65">entry</a>(2)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(2)*this-&gt;curvatureScale(this-&gt;realToReferenceScale(realScale));
  2998. <a name="l02919"></a>02919 scaledBeamStrain.<a class="code" href="classmatrixRdWtVect.html#ab6754006e5bfc55c5a3ade09cb9f5a65">entry</a>(3)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(3)*this-&gt;curvatureScale(this-&gt;realToReferenceScale(realScale));
  2999. <a name="l02920"></a>02920
  3000. <a name="l02921"></a>02921 <span class="keywordflow">return</span> this-&gt;getAbstract().fail(s,t,scaledBeamStrain);
  3001. <a name="l02922"></a>02922 }
  3002. <a name="l02923"></a>02923 };
  3003. <a name="l02924"></a>02924
  3004. <a name="l02925"></a>02925 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  3005. <a name="l02926"></a><a class="code" href="classscalingObject__VABSElementInfo_3_01dataType_00_01matrixStaticVectCol_3_01dataType_00_016_01_4_01_4.html">02926</a> <span class="keyword">class </span><a class="code" href="classscalingObject__VABSElementInfo.html">scalingObject_VABSElementInfo</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,6&gt; &gt; : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classscalingObject.html">scalingObject</a>&lt;dataType,VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,6&gt; &gt; &gt;
  3006. <a name="l02927"></a>02927 {
  3007. <a name="l02928"></a>02928 <span class="keyword">public</span>:
  3008. <a name="l02929"></a>02929
  3009. <a name="l02930"></a><a class="code" href="classscalingObject__VABSElementInfo_3_01dataType_00_01matrixStaticVectCol_3_01dataType_00_016_01_4_01_4.html#ac27ed3fcd7aa7345762337f6db338d34">02930</a> <a class="code" href="classscalingObject__VABSElementInfo.html">scalingObject_VABSElementInfo</a>()
  3010. <a name="l02931"></a>02931 {}
  3011. <a name="l02932"></a>02932
  3012. <a name="l02933"></a><a class="code" href="classscalingObject__VABSElementInfo_3_01dataType_00_01matrixStaticVectCol_3_01dataType_00_016_01_4_01_4.html#a1497136eb0485d35f527e5ca02f0cb6c">02933</a> <span class="keyword">virtual</span> ~<a class="code" href="classscalingObject__VABSElementInfo.html">scalingObject_VABSElementInfo</a>()
  3013. <a name="l02934"></a>02934 {}
  3014. <a name="l02935"></a>02935
  3015. <a name="l02936"></a><a class="code" href="classscalingObject__VABSElementInfo_3_01dataType_00_01matrixStaticVectCol_3_01dataType_00_016_01_4_01_4.html#a066531f55498bc29bf46570f1206a2b6">02936</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> fail(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> t,<span class="keyword">const</span> <a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol&lt;dataType,6&gt;</a>&amp; beamStrain)
  3016. <a name="l02937"></a>02937 {
  3017. <a name="l02938"></a>02938 <span class="keywordflow">return</span> this-&gt;fail_Scaled(s,t,beamStrain,this-&gt;getDefaultScale());
  3018. <a name="l02939"></a>02939 }
  3019. <a name="l02940"></a>02940
  3020. <a name="l02941"></a><a class="code" href="classscalingObject__VABSElementInfo_3_01dataType_00_01matrixStaticVectCol_3_01dataType_00_016_01_4_01_4.html#afd152b5a469a0c478d39e266a21cd611">02941</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> fail_Scaled(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> s,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> t,<span class="keyword">const</span> <a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol&lt;dataType,6&gt;</a>&amp; beamStrain,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)
  3021. <a name="l02942"></a>02942 {
  3022. <a name="l02943"></a>02943 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data&lt;dataType,6&gt;</a> scaledBeamStrain;
  3023. <a name="l02944"></a>02944
  3024. <a name="l02945"></a>02945 scaledBeamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(0)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(0);
  3025. <a name="l02946"></a>02946 scaledBeamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(1)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(1);
  3026. <a name="l02947"></a>02947 scaledBeamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(2)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(2);
  3027. <a name="l02948"></a>02948 scaledBeamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(3)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(3)*this-&gt;curvatureScale(this-&gt;realToReferenceScale(realScale));
  3028. <a name="l02949"></a>02949 scaledBeamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(4)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(4)*this-&gt;curvatureScale(this-&gt;realToReferenceScale(realScale));
  3029. <a name="l02950"></a>02950 scaledBeamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(5)=beamStrain.<a class="code" href="classmatrixVect.html#adb2ffeb4b912280fe62e0d0b46189eca">entry</a>(5)*this-&gt;curvatureScale(this-&gt;realToReferenceScale(realScale));
  3030. <a name="l02951"></a>02951
  3031. <a name="l02952"></a>02952 <span class="keywordflow">return</span> this-&gt;getAbstract().fail(s,t,scaledBeamStrain);
  3032. <a name="l02953"></a>02953 }
  3033. <a name="l02954"></a>02954 };
  3034. <a name="l02955"></a>02955
  3035. <a name="l02956"></a>02956 <span class="comment">// this is a template that require partial specialization according to beamMtxType </span>
  3036. <a name="l02957"></a>02957 <span class="comment">// the reason is one type corresponds to a bernoulli model the other to a timoshenko model</span>
  3037. <a name="l02958"></a>02958 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> beamMtxType&gt;
  3038. <a name="l02959"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix.html">02959</a> <span class="keyword">class </span><a class="code" href="classscalingObject__VABSModelBeamMatrix.html">scalingObject_VABSModelBeamMatrix</a> <span class="comment">// : public virtual scalingObject&lt;dataType,VABSModelBeamMatrix&lt;beamMtxType&gt; &gt;</span>
  3039. <a name="l02960"></a>02960 {};
  3040. <a name="l02961"></a>02961
  3041. <a name="l02962"></a>02962 <span class="comment">// beamMtxType is matrixRdWtStaticSqr_Data&lt;dataType,4&gt; for Bernoulli type</span>
  3042. <a name="l02963"></a>02963 <span class="comment">// is matrixRdWtStaticSqr_Data&lt;dataType,6&gt; for Timoshenko type</span>
  3043. <a name="l02964"></a>02964 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  3044. <a name="l02965"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix_3_01dataType_00_01matrixRdWtStaticSqr__Data_3_01dataType_00_014_01_4_01_4.html">02965</a> <span class="keyword">class </span><a class="code" href="classscalingObject__VABSModelBeamMatrix.html">scalingObject_VABSModelBeamMatrix</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,4&gt; &gt; : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classscalingObject.html">scalingObject</a>&lt;dataType,VABSModelBeamMatrix&lt;matrixRdWtStaticSqr_Data&lt;dataType,4&gt; &gt; &gt;
  3045. <a name="l02966"></a>02966 {
  3046. <a name="l02967"></a>02967 <span class="keyword">public</span>:
  3047. <a name="l02968"></a>02968
  3048. <a name="l02969"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix_3_01dataType_00_01matrixRdWtStaticSqr__Data_3_01dataType_00_014_01_4_01_4.html#a6d73b25aa4b646a41a384e8a413b79fc">02969</a> <a class="code" href="classscalingObject__VABSModelBeamMatrix.html">scalingObject_VABSModelBeamMatrix</a>()
  3049. <a name="l02970"></a>02970 {}
  3050. <a name="l02971"></a>02971
  3051. <a name="l02972"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix_3_01dataType_00_01matrixRdWtStaticSqr__Data_3_01dataType_00_014_01_4_01_4.html#a6406b0f6dd7c8c006c00332574afd3c2">02972</a> <span class="keyword">virtual</span> ~<a class="code" href="classscalingObject__VABSModelBeamMatrix.html">scalingObject_VABSModelBeamMatrix</a>()
  3052. <a name="l02973"></a>02973 {}
  3053. <a name="l02974"></a>02974
  3054. <a name="l02975"></a>02975 <span class="comment">//This retrieve the beam matrix</span>
  3055. <a name="l02976"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix_3_01dataType_00_01matrixRdWtStaticSqr__Data_3_01dataType_00_014_01_4_01_4.html#aa106a15c4d07a726a91754983f188c6a">02976</a> <span class="keyword">virtual</span> <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> beamMatrix()
  3056. <a name="l02977"></a>02977 {
  3057. <a name="l02978"></a>02978 <span class="keywordflow">return</span> this-&gt;beamMatrix_Scaled(this-&gt;getDefaultScale());
  3058. <a name="l02979"></a>02979 }
  3059. <a name="l02980"></a>02980
  3060. <a name="l02981"></a>02981 <span class="comment">//This retrieve the beam matrix</span>
  3061. <a name="l02982"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix_3_01dataType_00_01matrixRdWtStaticSqr__Data_3_01dataType_00_014_01_4_01_4.html#a881b884829e952d818dc0df11288a221">02982</a> <span class="keyword">virtual</span> <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> beamMatrix_Scaled(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)
  3062. <a name="l02983"></a>02983 {
  3063. <a name="l02984"></a>02984 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,4&gt;</a> retVal;
  3064. <a name="l02985"></a>02985
  3065. <a name="l02986"></a>02986 retVal=this-&gt;getAbstract().beamMatrix();
  3066. <a name="l02987"></a>02987
  3067. <a name="l02988"></a>02988 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> rowScale;
  3068. <a name="l02989"></a>02989 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> colScale;
  3069. <a name="l02990"></a>02990 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  3070. <a name="l02991"></a>02991 {
  3071. <a name="l02992"></a>02992 <span class="keywordflow">if</span>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>==0)
  3072. <a name="l02993"></a>02993 rowScale=this-&gt;forceScale(referenceToRealScale(realScale));
  3073. <a name="l02994"></a>02994 <span class="keywordflow">else</span>
  3074. <a name="l02995"></a>02995 rowScale=this-&gt;momentScale(referenceToRealScale(realScale));
  3075. <a name="l02996"></a>02996 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;4;j++)
  3076. <a name="l02997"></a>02997 {
  3077. <a name="l02998"></a>02998 <span class="keywordflow">if</span>(j==0)
  3078. <a name="l02999"></a>02999 colScale=1.0;
  3079. <a name="l03000"></a>03000 <span class="keywordflow">else</span>
  3080. <a name="l03001"></a>03001 colScale=this-&gt;curvatureScale(realToReferenceScale(realScale));
  3081. <a name="l03002"></a>03002 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>,j)*=rowScale*colScale;
  3082. <a name="l03003"></a>03003 }
  3083. <a name="l03004"></a>03004 }
  3084. <a name="l03005"></a>03005
  3085. <a name="l03006"></a>03006 <span class="keywordflow">return</span> retVal;
  3086. <a name="l03007"></a>03007 }
  3087. <a name="l03008"></a>03008 };
  3088. <a name="l03009"></a>03009
  3089. <a name="l03010"></a>03010 <span class="comment">// beamMtxType is matrixRdWtStaticSqr_Data&lt;dataType,4&gt; for Bernoulli type</span>
  3090. <a name="l03011"></a>03011 <span class="comment">// is matrixRdWtStaticSqr_Data&lt;dataType,6&gt; for Timoshenko type</span>
  3091. <a name="l03012"></a>03012 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  3092. <a name="l03013"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix_3_01dataType_00_01matrixRdWtStaticSqr__Data_3_01dataType_00_016_01_4_01_4.html">03013</a> <span class="keyword">class </span><a class="code" href="classscalingObject__VABSModelBeamMatrix.html">scalingObject_VABSModelBeamMatrix</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,6&gt; &gt; : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classscalingObject.html">scalingObject</a>&lt;dataType,VABSModelBeamMatrix&lt;matrixRdWtStaticSqr_Data&lt;dataType,6&gt; &gt; &gt;
  3093. <a name="l03014"></a>03014 {
  3094. <a name="l03015"></a>03015 <span class="keyword">public</span>:
  3095. <a name="l03016"></a>03016
  3096. <a name="l03017"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix_3_01dataType_00_01matrixRdWtStaticSqr__Data_3_01dataType_00_016_01_4_01_4.html#a9205008e3fbdae35e31353afee4ac09b">03017</a> <a class="code" href="classscalingObject__VABSModelBeamMatrix.html">scalingObject_VABSModelBeamMatrix</a>()
  3097. <a name="l03018"></a>03018 {}
  3098. <a name="l03019"></a>03019
  3099. <a name="l03020"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix_3_01dataType_00_01matrixRdWtStaticSqr__Data_3_01dataType_00_016_01_4_01_4.html#aefb40adbbca2430a3bb805043b1d07cf">03020</a> <span class="keyword">virtual</span> ~<a class="code" href="classscalingObject__VABSModelBeamMatrix.html">scalingObject_VABSModelBeamMatrix</a>()
  3100. <a name="l03021"></a>03021 {}
  3101. <a name="l03022"></a>03022
  3102. <a name="l03023"></a>03023 <span class="comment">//This retrieve the beam matrix</span>
  3103. <a name="l03024"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix_3_01dataType_00_01matrixRdWtStaticSqr__Data_3_01dataType_00_016_01_4_01_4.html#a40ab57abd56403bdf51356d0208dcb57">03024</a> <span class="keyword">virtual</span> <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,6&gt;</a> beamMatrix()
  3104. <a name="l03025"></a>03025 {
  3105. <a name="l03026"></a>03026 <span class="keywordflow">return</span> this-&gt;beamMatrix_Scaled(this-&gt;getDefaultScale());
  3106. <a name="l03027"></a>03027 }
  3107. <a name="l03028"></a>03028
  3108. <a name="l03029"></a>03029 <span class="comment">//This retrieve the beam matrix</span>
  3109. <a name="l03030"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix_3_01dataType_00_01matrixRdWtStaticSqr__Data_3_01dataType_00_016_01_4_01_4.html#a5fb2cdae48e5b549ff1ccc397f6babfa">03030</a> <span class="keyword">virtual</span> <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,6&gt;</a> beamMatrix_Scaled(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)
  3110. <a name="l03031"></a>03031 {
  3111. <a name="l03032"></a>03032 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data&lt;dataType,6&gt;</a> retVal;
  3112. <a name="l03033"></a>03033
  3113. <a name="l03034"></a>03034 retVal=this-&gt;getAbstract().beamMatrix();
  3114. <a name="l03035"></a>03035
  3115. <a name="l03036"></a>03036 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> rowScale;
  3116. <a name="l03037"></a>03037 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> colScale;
  3117. <a name="l03038"></a>03038 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;6;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  3118. <a name="l03039"></a>03039 {
  3119. <a name="l03040"></a>03040 <span class="keywordflow">if</span>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;3)
  3120. <a name="l03041"></a>03041 rowScale=this-&gt;forceScale(referenceToRealScale(realScale));
  3121. <a name="l03042"></a>03042 <span class="keywordflow">else</span>
  3122. <a name="l03043"></a>03043 rowScale=this-&gt;momentScale(referenceToRealScale(realScale));
  3123. <a name="l03044"></a>03044 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j&lt;6;j++)
  3124. <a name="l03045"></a>03045 {
  3125. <a name="l03046"></a>03046 <span class="keywordflow">if</span>(j&lt;3)
  3126. <a name="l03047"></a>03047 colScale=1.0;
  3127. <a name="l03048"></a>03048 <span class="keywordflow">else</span>
  3128. <a name="l03049"></a>03049 colScale=this-&gt;curvatureScale(realToReferenceScale(realScale));
  3129. <a name="l03050"></a>03050 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>,j)*=rowScale*colScale;
  3130. <a name="l03051"></a>03051 }
  3131. <a name="l03052"></a>03052 }
  3132. <a name="l03053"></a>03053
  3133. <a name="l03054"></a>03054 <span class="keywordflow">return</span> retVal;
  3134. <a name="l03055"></a>03055 }
  3135. <a name="l03056"></a>03056 };
  3136. <a name="l03057"></a>03057
  3137. <a name="l03058"></a>03058 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  3138. <a name="l03059"></a><a class="code" href="classscalingObject__cxAreaIntProp.html">03059</a> <span class="keyword">class </span><a class="code" href="classscalingObject__cxAreaIntProp.html">scalingObject_cxAreaIntProp</a> : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classscalingObject.html">scalingObject</a>&lt;dataType,cxAreaIntProp&lt;dataType&gt; &gt;
  3139. <a name="l03060"></a>03060 {
  3140. <a name="l03061"></a>03061 <span class="keyword">public</span>:
  3141. <a name="l03062"></a>03062
  3142. <a name="l03063"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#a2aa8da9a13b19ae17ce3e08b73894919">03063</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#a2aa8da9a13b19ae17ce3e08b73894919">scalingObject_cxAreaIntProp</a>()
  3143. <a name="l03064"></a>03064 {}
  3144. <a name="l03065"></a>03065
  3145. <a name="l03066"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#a9134a01d5c80883ad3da85b070f1ecae">03066</a> <span class="keyword">virtual</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#a9134a01d5c80883ad3da85b070f1ecae">~scalingObject_cxAreaIntProp</a>()
  3146. <a name="l03067"></a>03067 {}
  3147. <a name="l03068"></a>03068
  3148. <a name="l03069"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#a79fab7baffefb933ebc78dddbb0b84ad">03069</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#a79fab7baffefb933ebc78dddbb0b84ad">getArea</a>()<span class="keyword"> const</span>
  3149. <a name="l03070"></a>03070 <span class="keyword"> </span>{
  3150. <a name="l03071"></a>03071 <span class="keywordflow">return</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#abe8a6ee425c5aa6ac3bb864af82e1b56">getArea_Scaled</a>(this-&gt;<a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>());
  3151. <a name="l03072"></a>03072 }
  3152. <a name="l03073"></a>03073
  3153. <a name="l03074"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#af272ccfa1674c145333357968d0a31e5">03074</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#af272ccfa1674c145333357968d0a31e5">getXBar</a>()<span class="keyword"> const</span>
  3154. <a name="l03075"></a>03075 <span class="keyword"> </span>{
  3155. <a name="l03076"></a>03076 <span class="keywordflow">return</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#ad02f1edb8c48911ea5b4430f83c8ccb8">getXBar_Scaled</a>(this-&gt;<a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>());
  3156. <a name="l03077"></a>03077 }
  3157. <a name="l03078"></a>03078
  3158. <a name="l03079"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#aed38e4743cfc2470f7c5fb107b4baf62">03079</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#aed38e4743cfc2470f7c5fb107b4baf62">getYBar</a>()<span class="keyword"> const</span>
  3159. <a name="l03080"></a>03080 <span class="keyword"> </span>{
  3160. <a name="l03081"></a>03081 <span class="keywordflow">return</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#a7a827480a931c0c7b50529c17fa37017">getYBar_Scaled</a>(this-&gt;<a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>());
  3161. <a name="l03082"></a>03082 }
  3162. <a name="l03083"></a>03083
  3163. <a name="l03084"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#a4a1d17cbf21848439e9a733547dba15f">03084</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#a4a1d17cbf21848439e9a733547dba15f">getIxx</a>()<span class="keyword"> const</span>
  3164. <a name="l03085"></a>03085 <span class="keyword"> </span>{
  3165. <a name="l03086"></a>03086 <span class="keywordflow">return</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#a6e930f1f61b6551b5d4dd17ef8fd9658">getIxx_Scaled</a>(this-&gt;<a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>());
  3166. <a name="l03087"></a>03087 }
  3167. <a name="l03088"></a>03088
  3168. <a name="l03089"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#a1508fcf5f0194991daddd1c73382d0ed">03089</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#a1508fcf5f0194991daddd1c73382d0ed">getIxy</a>()<span class="keyword"> const</span>
  3169. <a name="l03090"></a>03090 <span class="keyword"> </span>{
  3170. <a name="l03091"></a>03091 <span class="keywordflow">return</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#aa6e5102ea881b7bc2b9f382516b58f34">getIxy_Scaled</a>(this-&gt;<a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>());
  3171. <a name="l03092"></a>03092 }
  3172. <a name="l03093"></a>03093
  3173. <a name="l03094"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#ae441f09ca1e1272ae181c94dcfb2768a">03094</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#ae441f09ca1e1272ae181c94dcfb2768a">getIyy</a>()<span class="keyword"> const</span>
  3174. <a name="l03095"></a>03095 <span class="keyword"> </span>{
  3175. <a name="l03096"></a>03096 <span class="keywordflow">return</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#a99d4f994ddea6a7ab4d6ccaae9c725e9">getIyy_Scaled</a>(this-&gt;<a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>());
  3176. <a name="l03097"></a>03097 }
  3177. <a name="l03098"></a>03098
  3178. <a name="l03099"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#abe8a6ee425c5aa6ac3bb864af82e1b56">03099</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#abe8a6ee425c5aa6ac3bb864af82e1b56">getArea_Scaled</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)<span class="keyword"> const</span>
  3179. <a name="l03100"></a>03100 <span class="keyword"> </span>{
  3180. <a name="l03101"></a>03101 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#a1ff8be1bc53c7fc91951ba9f10c41518">areaScale</a>(<a class="code" href="classscaling.html#aac7e81203dc733ae8a467ca89c34d640">referenceToRealScale</a>(realScale))*(this-&gt;<a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>().getArea());
  3181. <a name="l03102"></a>03102 }
  3182. <a name="l03103"></a>03103
  3183. <a name="l03104"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#ad02f1edb8c48911ea5b4430f83c8ccb8">03104</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#ad02f1edb8c48911ea5b4430f83c8ccb8">getXBar_Scaled</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)<span class="keyword"> const</span>
  3184. <a name="l03105"></a>03105 <span class="keyword"> </span>{
  3185. <a name="l03106"></a>03106 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#aac7e81203dc733ae8a467ca89c34d640">referenceToRealScale</a>(realScale)*(this-&gt;<a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>().getXBar());
  3186. <a name="l03107"></a>03107 }
  3187. <a name="l03108"></a>03108
  3188. <a name="l03109"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#a7a827480a931c0c7b50529c17fa37017">03109</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#a7a827480a931c0c7b50529c17fa37017">getYBar_Scaled</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)<span class="keyword"> const</span>
  3189. <a name="l03110"></a>03110 <span class="keyword"> </span>{
  3190. <a name="l03111"></a>03111 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#aac7e81203dc733ae8a467ca89c34d640">referenceToRealScale</a>(realScale)*(this-&gt;<a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>().getYBar());
  3191. <a name="l03112"></a>03112 }
  3192. <a name="l03113"></a>03113
  3193. <a name="l03114"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#a6e930f1f61b6551b5d4dd17ef8fd9658">03114</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#a6e930f1f61b6551b5d4dd17ef8fd9658">getIxx_Scaled</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)<span class="keyword"> const</span>
  3194. <a name="l03115"></a>03115 <span class="keyword"> </span>{
  3195. <a name="l03116"></a>03116 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#af84bc45022ad992488c57661462c696f">secondMomentScale</a>(realScale)*(this-&gt;<a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>().getIxx());
  3196. <a name="l03117"></a>03117 }
  3197. <a name="l03118"></a>03118
  3198. <a name="l03119"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#aa6e5102ea881b7bc2b9f382516b58f34">03119</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#aa6e5102ea881b7bc2b9f382516b58f34">getIxy_Scaled</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)<span class="keyword"> const</span>
  3199. <a name="l03120"></a>03120 <span class="keyword"> </span>{
  3200. <a name="l03121"></a>03121 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#af84bc45022ad992488c57661462c696f">secondMomentScale</a>(realScale)*(this-&gt;<a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>().getIxy());
  3201. <a name="l03122"></a>03122 }
  3202. <a name="l03123"></a>03123
  3203. <a name="l03124"></a><a class="code" href="classscalingObject__cxAreaIntProp.html#a99d4f994ddea6a7ab4d6ccaae9c725e9">03124</a> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classscalingObject__cxAreaIntProp.html#a99d4f994ddea6a7ab4d6ccaae9c725e9">getIyy_Scaled</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)<span class="keyword"> const</span>
  3204. <a name="l03125"></a>03125 <span class="keyword"> </span>{
  3205. <a name="l03126"></a>03126 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#af84bc45022ad992488c57661462c696f">secondMomentScale</a>(realScale)*(this-&gt;<a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>().getIyy());
  3206. <a name="l03127"></a>03127 }
  3207. <a name="l03128"></a>03128 };
  3208. <a name="l03129"></a>03129
  3209. <a name="l03130"></a>03130 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> strainType&gt;
  3210. <a name="l03131"></a><a class="code" href="classscalingObject__VABSElementInfo__Ref.html">03131</a> <span class="keyword">class </span><a class="code" href="classscalingObject__VABSElementInfo__Ref.html">scalingObject_VABSElementInfo_Ref</a> : <span class="keyword">public</span> <a class="code" href="classscalingObject__VABSElementInfo.html">scalingObject_VABSElementInfo</a>&lt;dataType,strainType&gt; , <span class="keyword">public</span> <a class="code" href="classscalingObject__Ref.html">scalingObject_Ref</a>&lt;dataType,VABSElementInfo&lt;dataType,strainType&gt; &gt;
  3211. <a name="l03132"></a>03132 {
  3212. <a name="l03133"></a>03133 <span class="keyword">public</span>:
  3213. <a name="l03134"></a>03134
  3214. <a name="l03135"></a><a class="code" href="classscalingObject__VABSElementInfo__Ref.html#acd724f1bfcf6b55f99cc4098aa315398">03135</a> <a class="code" href="classscalingObject__VABSElementInfo__Ref.html#acd724f1bfcf6b55f99cc4098aa315398">scalingObject_VABSElementInfo_Ref</a>(<a class="code" href="classVABSElementInfo.html">VABSElementInfo&lt;dataType,strainType&gt;</a>&amp; ref_in,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in=1.0) : <a class="code" href="classscalingObject__Ref.html">scalingObject_Ref</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,strainType&gt; &gt;(ref_in,defaultScale_in)
  3215. <a name="l03136"></a>03136 {}
  3216. <a name="l03137"></a>03137
  3217. <a name="l03138"></a><a class="code" href="classscalingObject__VABSElementInfo__Ref.html#a502a9ba483364cca5f323f8f975483f0">03138</a> <span class="keyword">virtual</span> <a class="code" href="classscalingObject__VABSElementInfo__Ref.html#a502a9ba483364cca5f323f8f975483f0">~scalingObject_VABSElementInfo_Ref</a>()
  3218. <a name="l03139"></a>03139 {}
  3219. <a name="l03140"></a>03140 };
  3220. <a name="l03141"></a>03141
  3221. <a name="l03142"></a>03142 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> strainType&gt;
  3222. <a name="l03143"></a><a class="code" href="classscalingObject__VABSElementInfo__Pntr.html">03143</a> <span class="keyword">class </span><a class="code" href="classscalingObject__VABSElementInfo__Pntr.html">scalingObject_VABSElementInfo_Pntr</a> : <span class="keyword">public</span> <a class="code" href="classscalingObject__VABSElementInfo.html">scalingObject_VABSElementInfo</a>&lt;dataType,strainType&gt; , <span class="keyword">public</span> <a class="code" href="classscalingObject__Pntr.html">scalingObject_Pntr</a>&lt;dataType,VABSElementInfo&lt;dataType,strainType&gt; &gt;
  3223. <a name="l03144"></a>03144 {
  3224. <a name="l03145"></a>03145 <span class="keyword">public</span>:
  3225. <a name="l03146"></a>03146
  3226. <a name="l03147"></a><a class="code" href="classscalingObject__VABSElementInfo__Pntr.html#a60885a9da3e0b14628138624a0cad336">03147</a> <a class="code" href="classscalingObject__VABSElementInfo__Pntr.html#a60885a9da3e0b14628138624a0cad336">scalingObject_VABSElementInfo_Pntr</a>(<a class="code" href="classVABSElementInfo.html">VABSElementInfo&lt;dataType,strainType&gt;</a>* ref_in=NULL,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in=1.0,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : <a class="code" href="classscalingObject__Pntr.html">scalingObject_Pntr</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,strainType&gt; &gt;(ref_in,defaultScale_in,canDelete_in)
  3227. <a name="l03148"></a>03148 {}
  3228. <a name="l03149"></a>03149
  3229. <a name="l03150"></a><a class="code" href="classscalingObject__VABSElementInfo__Pntr.html#a8fc06e344020c4c542086ac3c32ada20">03150</a> <span class="keyword">virtual</span> <a class="code" href="classscalingObject__VABSElementInfo__Pntr.html#a8fc06e344020c4c542086ac3c32ada20">~scalingObject_VABSElementInfo_Pntr</a>()
  3230. <a name="l03151"></a>03151 {}
  3231. <a name="l03152"></a>03152 };
  3232. <a name="l03153"></a>03153
  3233. <a name="l03154"></a>03154 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> beamMtxType&gt;
  3234. <a name="l03155"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix__Ref.html">03155</a> <span class="keyword">class </span><a class="code" href="classscalingObject__VABSModelBeamMatrix__Ref.html">scalingObject_VABSModelBeamMatrix_Ref</a> : <span class="keyword">public</span> <a class="code" href="classscalingObject__VABSModelBeamMatrix.html">scalingObject_VABSModelBeamMatrix</a>&lt;dataType,beamMtxType&gt; , <span class="keyword">public</span> <a class="code" href="classscalingObject__Ref.html">scalingObject_Ref</a>&lt;dataType,VABSModelBeamMatrix&lt;beamMtxType&gt; &gt;
  3235. <a name="l03156"></a>03156 {
  3236. <a name="l03157"></a>03157 <span class="keyword">public</span>:
  3237. <a name="l03158"></a>03158
  3238. <a name="l03159"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix__Ref.html#a40ddd457415ad320a71d1829bb14040c">03159</a> <a class="code" href="classscalingObject__VABSModelBeamMatrix__Ref.html#a40ddd457415ad320a71d1829bb14040c">scalingObject_VABSModelBeamMatrix_Ref</a>(<a class="code" href="classVABSModelBeamMatrix.html">VABSModelBeamMatrix&lt;beamMtxType&gt;</a>&amp; ref_in,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in=1.0) : <a class="code" href="classscalingObject__Ref.html">scalingObject_Ref</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classVABSModelBeamMatrix.html">VABSModelBeamMatrix</a>&lt;beamMtxType&gt; &gt;(ref_in,defaultScale_in)
  3239. <a name="l03160"></a>03160 {}
  3240. <a name="l03161"></a>03161
  3241. <a name="l03162"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix__Ref.html#a4298994644c05f4fcc150656b75bf8a4">03162</a> <span class="keyword">virtual</span> <a class="code" href="classscalingObject__VABSModelBeamMatrix__Ref.html#a4298994644c05f4fcc150656b75bf8a4">~scalingObject_VABSModelBeamMatrix_Ref</a>()
  3242. <a name="l03163"></a>03163 {}
  3243. <a name="l03164"></a>03164
  3244. <a name="l03165"></a>03165 };
  3245. <a name="l03166"></a>03166
  3246. <a name="l03167"></a>03167 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> beamMtxType&gt;
  3247. <a name="l03168"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix__Pntr.html">03168</a> <span class="keyword">class </span><a class="code" href="classscalingObject__VABSModelBeamMatrix__Pntr.html">scalingObject_VABSModelBeamMatrix_Pntr</a> : <span class="keyword">public</span> <a class="code" href="classscalingObject__VABSModelBeamMatrix.html">scalingObject_VABSModelBeamMatrix</a>&lt;dataType,beamMtxType&gt; , <span class="keyword">public</span> <a class="code" href="classscalingObject__Pntr.html">scalingObject_Pntr</a>&lt;dataType,VABSModelBeamMatrix&lt;beamMtxType&gt; &gt;
  3248. <a name="l03169"></a>03169 {
  3249. <a name="l03170"></a>03170 <span class="keyword">public</span>:
  3250. <a name="l03171"></a>03171
  3251. <a name="l03172"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix__Pntr.html#ae5f8cf06c2db06f62e61f52c38f41fd1">03172</a> <a class="code" href="classscalingObject__VABSModelBeamMatrix__Pntr.html#ae5f8cf06c2db06f62e61f52c38f41fd1">scalingObject_VABSModelBeamMatrix_Pntr</a>(<a class="code" href="classVABSModelBeamMatrix.html">VABSModelBeamMatrix&lt;beamMtxType&gt;</a>* ref_in=NULL,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in=1.0,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : <a class="code" href="classscalingObject__Pntr.html">scalingObject_Pntr</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classVABSModelBeamMatrix.html">VABSModelBeamMatrix</a>&lt;beamMtxType&gt; &gt;(ref_in,defaultScale_in,canDelete_in)
  3252. <a name="l03173"></a>03173 {}
  3253. <a name="l03174"></a>03174
  3254. <a name="l03175"></a><a class="code" href="classscalingObject__VABSModelBeamMatrix__Pntr.html#a828998c1c3db14b745b383db813c8afe">03175</a> <span class="keyword">virtual</span> <a class="code" href="classscalingObject__VABSModelBeamMatrix__Pntr.html#a828998c1c3db14b745b383db813c8afe">~scalingObject_VABSModelBeamMatrix_Pntr</a>()
  3255. <a name="l03176"></a>03176 {}
  3256. <a name="l03177"></a>03177 };
  3257. <a name="l03178"></a>03178
  3258. <a name="l03179"></a>03179 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType&gt;
  3259. <a name="l03180"></a><a class="code" href="classscalingObject__cxAreaIntProp__Pntr.html">03180</a> <span class="keyword">class </span><a class="code" href="classscalingObject__cxAreaIntProp__Pntr.html">scalingObject_cxAreaIntProp_Pntr</a> : <span class="keyword">public</span> <a class="code" href="classscalingObject__cxAreaIntProp.html">scalingObject_cxAreaIntProp</a>&lt;dataType&gt; , <span class="keyword">public</span> <a class="code" href="classscalingObject__Pntr.html">scalingObject_Pntr</a>&lt;dataType,cxAreaIntProp&lt;dataType&gt; &gt;
  3260. <a name="l03181"></a>03181 {
  3261. <a name="l03182"></a>03182 <span class="keyword">public</span>:
  3262. <a name="l03183"></a>03183
  3263. <a name="l03184"></a><a class="code" href="classscalingObject__cxAreaIntProp__Pntr.html#a2436f028fec29b98ac418ac55319f9d2">03184</a> <a class="code" href="classscalingObject__cxAreaIntProp__Pntr.html#a2436f028fec29b98ac418ac55319f9d2">scalingObject_cxAreaIntProp_Pntr</a>(<a class="code" href="classcxAreaIntProp.html">cxAreaIntProp&lt;dataType&gt;</a>* ref_in=NULL,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in=1.0,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : <a class="code" href="classscalingObject__Pntr.html">scalingObject_Pntr</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classcxAreaIntProp.html">cxAreaIntProp</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>&gt; &gt;(ref_in,defaultScale_in,canDelete_in)
  3264. <a name="l03185"></a>03185 {}
  3265. <a name="l03186"></a>03186
  3266. <a name="l03187"></a><a class="code" href="classscalingObject__cxAreaIntProp__Pntr.html#acb3a8e2ed190baab3da22d90425faffb">03187</a> <span class="keyword">virtual</span> <a class="code" href="classscalingObject__cxAreaIntProp__Pntr.html#acb3a8e2ed190baab3da22d90425faffb">~scalingObject_cxAreaIntProp_Pntr</a>()
  3267. <a name="l03188"></a>03188 {}
  3268. <a name="l03189"></a>03189 };
  3269. <a name="l03190"></a>03190
  3270. <a name="l03191"></a>03191 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> strainType&gt;
  3271. <a name="l03192"></a><a class="code" href="classVABSModelPost__scaling__Pntr.html">03192</a> <span class="keyword">class </span><a class="code" href="classVABSModelPost__scaling__Pntr.html">VABSModelPost_scaling_Pntr</a> : <span class="keyword">public</span> <a class="code" href="classVABSModelPost.html">VABSModelPost</a>&lt;scalingObject&lt;dataType,VABSElementInfo&lt;dataType,strainType&gt; &gt; &gt;
  3272. <a name="l03193"></a>03193 {
  3273. <a name="l03194"></a>03194 <span class="keyword">private</span>:
  3274. <a name="l03195"></a>03195
  3275. <a name="l03196"></a>03196 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> scale;
  3276. <a name="l03197"></a>03197 <a class="code" href="classVABSModelPost.html">VABSModelPost&lt;VABSElementInfo&lt;dataType,strainType&gt;</a> &gt;* vabsPost;
  3277. <a name="l03198"></a>03198 <span class="keywordtype">bool</span> canDelete;
  3278. <a name="l03199"></a>03199
  3279. <a name="l03200"></a>03200 <span class="keyword">public</span>:
  3280. <a name="l03201"></a>03201
  3281. <a name="l03202"></a><a class="code" href="classVABSModelPost__scaling__Pntr.html#a155647a7eb8fa929c353593cef7f9ef5">03202</a> <a class="code" href="classVABSModelPost__scaling__Pntr.html#a155647a7eb8fa929c353593cef7f9ef5">VABSModelPost_scaling_Pntr</a>(<a class="code" href="classVABSModelPost.html">VABSModelPost</a>&lt;<a class="code" href="classVABSElementInfo.html">VABSElementInfo&lt;dataType,strainType&gt;</a> &gt;* vabsPost_in=NULL,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> scale_in=1.0,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : scale(scale_in) , vabsPost(vabsPost_in) , canDelete(canDelete_in)
  3282. <a name="l03203"></a>03203 {}
  3283. <a name="l03204"></a>03204
  3284. <a name="l03205"></a><a class="code" href="classVABSModelPost__scaling__Pntr.html#aa2f72448886558250aecfe265e51788c">03205</a> <span class="keyword">virtual</span> <a class="code" href="classVABSModelPost__scaling__Pntr.html#aa2f72448886558250aecfe265e51788c">~VABSModelPost_scaling_Pntr</a>()
  3285. <a name="l03206"></a>03206 {
  3286. <a name="l03207"></a>03207 <span class="keywordflow">if</span>(canDelete &amp;&amp; vabsPost!=NULL)
  3287. <a name="l03208"></a>03208 <span class="keyword">delete</span> vabsPost;
  3288. <a name="l03209"></a>03209 }
  3289. <a name="l03210"></a>03210
  3290. <a name="l03211"></a><a class="code" href="classVABSModelPost__scaling__Pntr.html#a465da44edd8446ef67d162ad1e2fddf0">03211</a> <span class="keywordtype">void</span> <a class="code" href="classVABSModelPost__scaling__Pntr.html#a465da44edd8446ef67d162ad1e2fddf0">setPointer</a>(<a class="code" href="classVABSModelPost.html">VABSModelPost</a>&lt;<a class="code" href="classVABSElementInfo.html">VABSElementInfo&lt;dataType,strainType&gt;</a> &gt;* vabsPost_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
  3291. <a name="l03212"></a>03212 {
  3292. <a name="l03213"></a>03213 <span class="keywordflow">if</span>(canDelete &amp;&amp; vabsPost!=NULL)
  3293. <a name="l03214"></a>03214 <span class="keyword">delete</span> vabsPost;
  3294. <a name="l03215"></a>03215
  3295. <a name="l03216"></a>03216 vabsPost=vabsPost_in;
  3296. <a name="l03217"></a>03217 canDelete=canDelete_in;
  3297. <a name="l03218"></a>03218 }
  3298. <a name="l03219"></a>03219
  3299. <a name="l03220"></a><a class="code" href="classVABSModelPost__scaling__Pntr.html#acea2890313e51ae4ff031591e3019874">03220</a> <a class="code" href="classVABSModelPost__scaling__Pntr.html">VABSModelPost_scaling_Pntr&lt;dataType,strainType&gt;</a> <a class="code" href="classVABSModelPost__scaling__Pntr.html#acea2890313e51ae4ff031591e3019874">setDefaultScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> scale_in)
  3300. <a name="l03221"></a>03221 {
  3301. <a name="l03222"></a>03222 scale=scale_in;
  3302. <a name="l03223"></a>03223 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  3303. <a name="l03224"></a>03224 }
  3304. <a name="l03225"></a>03225
  3305. <a name="l03226"></a>03226 <span class="comment">// A method that informs the post process module about the number of elements</span>
  3306. <a name="l03227"></a><a class="code" href="classVABSModelPost__scaling__Pntr.html#afeb4360272e41f7539e2f95d2f528287">03227</a> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classVABSModelPost__scaling__Pntr.html#afeb4360272e41f7539e2f95d2f528287">size</a>()
  3307. <a name="l03228"></a>03228 {
  3308. <a name="l03229"></a>03229 <span class="keywordflow">return</span> vabsPost-&gt;<a class="code" href="classVABSModelPost.html#a476038f832b9ef6181ac62f3874fd0ec">size</a>();
  3309. <a name="l03230"></a>03230 }
  3310. <a name="l03231"></a>03231
  3311. <a name="l03232"></a>03232 <span class="comment">// This is an access method to perform post processing</span>
  3312. <a name="l03233"></a><a class="code" href="classVABSModelPost__scaling__Pntr.html#a0281e6d9a4e0aa85925b0b1db6e14379">03233</a> <a class="code" href="classautoPntr.html">autoPntr&lt;scalingObject&lt;dataType,VABSElementInfo&lt;dataType,strainType&gt;</a> &gt; &gt; <a class="code" href="classVABSModelPost__scaling__Pntr.html#a0281e6d9a4e0aa85925b0b1db6e14379">getElement</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)
  3313. <a name="l03234"></a>03234 {
  3314. <a name="l03235"></a>03235 <span class="keywordflow">if</span>(vabsPost==NULL)
  3315. <a name="l03236"></a>03236 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;VABSModelPost_scaling_Pntr::getElement(): The vabsPost is NULL&quot;</span>);
  3316. <a name="l03237"></a>03237
  3317. <a name="l03238"></a>03238 <a class="code" href="classautoPntr.html">autoPntr&lt;VABSElementInfo&lt;dataType,matrixStaticVectCol&lt;dataType,6&gt;</a> &gt; &gt; pntrToElm=vabsPost-&gt;<a class="code" href="classVABSModelPost.html#ab22c953c94473d150d7b45b30833969d">getElement</a>(at);
  3318. <a name="l03239"></a>03239 <span class="keywordtype">bool</span> deleteStatus=pntrToElm.<a class="code" href="classautoPntr.html#aeff67239fbb801ebdf76d8e8e6f242bc">deleteStatus</a>();
  3319. <a name="l03240"></a>03240 <span class="keywordflow">return</span> <a class="code" href="classautoPntr.html">autoPntr&lt;scalingObject&lt;dataType,VABSElementInfo&lt;dataType,strainType&gt;</a> &gt; &gt;(<span class="keyword">new</span> <a class="code" href="classscalingObject__VABSElementInfo__Pntr.html">scalingObject_VABSElementInfo_Pntr&lt;dataType,strainType&gt;</a>(pntrToElm.<a class="code" href="classautoPntr.html#a3533ca63305b90c93c617ca4cb40f9e6">release</a>(),scale,deleteStatus),<span class="keyword">true</span>);
  3320. <a name="l03241"></a>03241 }
  3321. <a name="l03242"></a>03242 };
  3322. <a name="l03243"></a>03243
  3323. <a name="l03244"></a>03244 <span class="keyword">template</span>&lt;<span class="keyword">class</span> locationType&gt;
  3324. <a name="l03245"></a><a class="code" href="classvabsBladeBase.html">03245</a> <span class="keyword">class </span><a class="code" href="classvabsBladeBase.html">vabsBladeBase</a>
  3325. <a name="l03246"></a>03246 {
  3326. <a name="l03247"></a>03247 <span class="keyword">public</span>:
  3327. <a name="l03248"></a>03248
  3328. <a name="l03249"></a><a class="code" href="classvabsBladeBase.html#a6601b540f4f698c5c4ab187a396733af">03249</a> <a class="code" href="classvabsBladeBase.html#a6601b540f4f698c5c4ab187a396733af">vabsBladeBase</a>()
  3329. <a name="l03250"></a>03250 {}
  3330. <a name="l03251"></a>03251
  3331. <a name="l03252"></a><a class="code" href="classvabsBladeBase.html#a3a7dffac7e485a73206d625ce2bb5010">03252</a> <span class="keyword">virtual</span> <a class="code" href="classvabsBladeBase.html#a3a7dffac7e485a73206d625ce2bb5010">~vabsBladeBase</a>()
  3332. <a name="l03253"></a>03253 {}
  3333. <a name="l03254"></a>03254
  3334. <a name="l03255"></a>03255 <span class="comment">// get the information about the contents</span>
  3335. <a name="l03256"></a>03256 <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classvabsBladeBase.html#ac975076254f9a2bb4817ebc3c90f4ce4">size</a>()=0;
  3336. <a name="l03257"></a>03257 <span class="keyword">virtual</span> locationType <a class="code" href="classvabsBladeBase.html#a2fa638f9373f64d376e4a169e3188e4b">getLocation</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)=0;
  3337. <a name="l03258"></a>03258 };
  3338. <a name="l03259"></a>03259
  3339. <a name="l03260"></a>03260 <span class="keyword">template</span>&lt;<span class="keyword">class</span> locationType,<span class="keyword">class</span> cxDesignType&gt;
  3340. <a name="l03261"></a><a class="code" href="classvabsBladeDesign.html">03261</a> <span class="keyword">class </span><a class="code" href="classvabsBladeDesign.html">vabsBladeDesign</a> : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classvabsBladeBase.html">vabsBladeBase</a>&lt;locationType&gt;
  3341. <a name="l03262"></a>03262 {
  3342. <a name="l03263"></a>03263 <span class="keyword">public</span>:
  3343. <a name="l03264"></a>03264
  3344. <a name="l03265"></a><a class="code" href="classvabsBladeDesign.html#a7a667907852fd406552f5424913011d1">03265</a> <a class="code" href="classvabsBladeDesign.html#a7a667907852fd406552f5424913011d1">vabsBladeDesign</a>()
  3345. <a name="l03266"></a>03266 {}
  3346. <a name="l03267"></a>03267
  3347. <a name="l03268"></a><a class="code" href="classvabsBladeDesign.html#a5359905bbd362ef6c75d7a9f25300467">03268</a> <span class="keyword">virtual</span> <a class="code" href="classvabsBladeDesign.html#a5359905bbd362ef6c75d7a9f25300467">~vabsBladeDesign</a>()
  3348. <a name="l03269"></a>03269 {}
  3349. <a name="l03270"></a>03270
  3350. <a name="l03271"></a>03271 <span class="comment">// pass in the input parameters</span>
  3351. <a name="l03272"></a>03272 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classvabsBladeDesign.html#a4ea596cc9de2bdaacc355b13674d1c34">setCXDesignSource</a>(<a class="code" href="classcxDesignSource.html">cxDesignSource&lt;locationType,cxDesignType&gt;</a>* desSrc_in,<span class="keywordtype">bool</span> deleteCXDesignSource=<span class="keyword">false</span>)=0;
  3352. <a name="l03273"></a>03273 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classvabsBladeDesign.html#a2eb63d98c53fe8d4643939d2454c80b3">newDesign</a>()=0;
  3353. <a name="l03274"></a>03274
  3354. <a name="l03275"></a>03275 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classvabsBladeDesign.html#ace03a2c55c309d199d8747f9a15b8e3b">solve</a>()=0;
  3355. <a name="l03276"></a>03276 };
  3356. <a name="l03277"></a>03277
  3357. <a name="l03278"></a>03278 <span class="keyword">template</span>&lt;<span class="keyword">class</span> locationType,<span class="keyword">class</span> lengthType,<span class="keyword">class</span> beamMtxType&gt;
  3358. <a name="l03279"></a><a class="code" href="classvabsBladeMatrix.html">03279</a> <span class="keyword">class </span><a class="code" href="classvabsBladeMatrix.html">vabsBladeMatrix</a> : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classvabsBladeBase.html">vabsBladeBase</a>&lt;locationType&gt;
  3359. <a name="l03280"></a>03280 {
  3360. <a name="l03281"></a>03281 <span class="keyword">public</span>:
  3361. <a name="l03282"></a>03282
  3362. <a name="l03283"></a><a class="code" href="classvabsBladeMatrix.html#a6e05b51606e3f5eaf38ac3e36ba2c4b1">03283</a> <a class="code" href="classvabsBladeMatrix.html#a6e05b51606e3f5eaf38ac3e36ba2c4b1">vabsBladeMatrix</a>()
  3363. <a name="l03284"></a>03284 {}
  3364. <a name="l03285"></a>03285
  3365. <a name="l03286"></a><a class="code" href="classvabsBladeMatrix.html#a8f632ab8be69b601c4f26eee52f161b1">03286</a> <span class="keyword">virtual</span> <a class="code" href="classvabsBladeMatrix.html#a8f632ab8be69b601c4f26eee52f161b1">~vabsBladeMatrix</a>()
  3366. <a name="l03287"></a>03287 {}
  3367. <a name="l03288"></a>03288
  3368. <a name="l03289"></a>03289 <span class="comment">// These are the methods the provide the K matrices</span>
  3369. <a name="l03290"></a>03290 <span class="keyword">virtual</span> <a class="code" href="classautoPntr.html">autoPntr&lt;scalingObject&lt;lengthType,VABSModelBeamMatrix&lt;beamMtxType&gt;</a> &gt; &gt; <a class="code" href="classvabsBladeMatrix.html#af45b951894c87b45191ddeaa32104638">getMatrix</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)=0;
  3370. <a name="l03291"></a>03291 };
  3371. <a name="l03292"></a>03292
  3372. <a name="l03293"></a>03293 <span class="comment">// template&lt;class locationType,class lengthType,class elmPostType,class cxPostType&gt;</span>
  3373. <a name="l03294"></a>03294 <span class="keyword">template</span>&lt;<span class="keyword">class</span> locationType,<span class="keyword">class</span> lengthType,<span class="keyword">class</span> elmPostType,<span class="keyword">class</span> areaType&gt;
  3374. <a name="l03295"></a><a class="code" href="classvabsBladePost.html">03295</a> <span class="keyword">class </span><a class="code" href="classvabsBladePost.html">vabsBladePost</a> : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classvabsBladeBase.html">vabsBladeBase</a>&lt;locationType&gt; , <span class="keyword">public</span> <a class="code" href="classcrossSectionAreaSource.html">crossSectionAreaSource</a>&lt;locationType,areaType&gt;
  3375. <a name="l03296"></a>03296 {
  3376. <a name="l03297"></a>03297 <span class="keyword">public</span>:
  3377. <a name="l03298"></a>03298
  3378. <a name="l03299"></a><a class="code" href="classvabsBladePost.html#a06c0c46ef05c4c222b2ae8b25fec2a4c">03299</a> <a class="code" href="classvabsBladePost.html#a06c0c46ef05c4c222b2ae8b25fec2a4c">vabsBladePost</a>()
  3379. <a name="l03300"></a>03300 {}
  3380. <a name="l03301"></a>03301
  3381. <a name="l03302"></a><a class="code" href="classvabsBladePost.html#a672eedf882c62eaab541011ed069bc04">03302</a> <span class="keyword">virtual</span> <a class="code" href="classvabsBladePost.html#a672eedf882c62eaab541011ed069bc04">~vabsBladePost</a>()
  3382. <a name="l03303"></a>03303 {}
  3383. <a name="l03304"></a>03304
  3384. <a name="l03305"></a>03305 <span class="comment">// these are the methods that are used for post processing</span>
  3385. <a name="l03306"></a>03306 <span class="keyword">virtual</span> <a class="code" href="classautoPntr.html">autoPntr&lt;VABSModelPost&lt;elmPostType&gt;</a> &gt; <a class="code" href="classvabsBladePost.html#a42e4b85b307b582d2bef59a21de1e365">getPost</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)=0;
  3386. <a name="l03307"></a>03307 <span class="comment">// virtual autoPntr&lt;scalingObject&lt;lengthType,cxPostType&gt; &gt; getCXPost(unsigned long at)=0;</span>
  3387. <a name="l03308"></a>03308 };
  3388. <a name="l03309"></a>03309
  3389. <a name="l03310"></a>03310 <span class="keyword">template</span>&lt;<span class="keyword">class</span> locationType,<span class="keyword">class</span> lengthType,<span class="keyword">class</span> cxDesignType,<span class="keyword">class</span> beamMtxType,<span class="keyword">class</span> elmPostType,<span class="keyword">class</span> areaType&gt;
  3390. <a name="l03311"></a><a class="code" href="classvabsBlade.html">03311</a> <span class="keyword">class </span><a class="code" href="classvabsBlade.html">vabsBlade</a> : <span class="keyword">public</span> <a class="code" href="classvabsBladeDesign.html">vabsBladeDesign</a>&lt;locationType,cxDesignType&gt; , <span class="keyword">public</span> <a class="code" href="classvabsBladeMatrix.html">vabsBladeMatrix</a>&lt;locationType,lengthType,beamMtxType&gt; , <span class="keyword">public</span> <a class="code" href="classvabsBladePost.html">vabsBladePost</a>&lt;locationType,lengthType,elmPostType,areaType&gt;
  3391. <a name="l03312"></a>03312 {
  3392. <a name="l03313"></a>03313 <span class="keyword">protected</span>:
  3393. <a name="l03314"></a>03314
  3394. <a name="l03315"></a><a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">03315</a> <a class="code" href="classchordSource.html">chordSource&lt;locationType,lengthType&gt;</a>* <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>;
  3395. <a name="l03316"></a><a class="code" href="classvabsBlade.html#a5e760efd8828271a6efd3371f1a8b50c">03316</a> <span class="keywordtype">bool</span> <a class="code" href="classvabsBlade.html#a5e760efd8828271a6efd3371f1a8b50c">canDelete</a>;
  3396. <a name="l03317"></a>03317
  3397. <a name="l03318"></a>03318 <span class="keyword">public</span>:
  3398. <a name="l03319"></a>03319
  3399. <a name="l03320"></a><a class="code" href="classvabsBlade.html#ade6079c1e76f192388bc4342c28664f3">03320</a> <a class="code" href="classvabsBlade.html#ade6079c1e76f192388bc4342c28664f3">vabsBlade</a>(<a class="code" href="classchordSource.html">chordSource&lt;locationType,lengthType&gt;</a>* chordScale_in=NULL,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>(chordScale_in) , <a class="code" href="classvabsBlade.html#a5e760efd8828271a6efd3371f1a8b50c">canDelete</a>(canDelete_in)
  3400. <a name="l03321"></a>03321 {}
  3401. <a name="l03322"></a>03322
  3402. <a name="l03323"></a><a class="code" href="classvabsBlade.html#aea12a41dcbd17e8cdb718e5bdfa31009">03323</a> <span class="keyword">virtual</span> <a class="code" href="classvabsBlade.html#aea12a41dcbd17e8cdb718e5bdfa31009">~vabsBlade</a>()
  3403. <a name="l03324"></a>03324 {
  3404. <a name="l03325"></a>03325 <span class="keywordflow">if</span>(<a class="code" href="classvabsBlade.html#a5e760efd8828271a6efd3371f1a8b50c">canDelete</a> &amp;&amp; <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>!=NULL)
  3405. <a name="l03326"></a>03326 <span class="keyword">delete</span> <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>;
  3406. <a name="l03327"></a>03327 }
  3407. <a name="l03328"></a>03328
  3408. <a name="l03329"></a>03329 <span class="comment">// set scaling data source</span>
  3409. <a name="l03330"></a><a class="code" href="classvabsBlade.html#a9e58b338d01009f906860b1501fe512d">03330</a> <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classvabsBlade.html#a9e58b338d01009f906860b1501fe512d">setChordSource</a>(<a class="code" href="classchordSource.html">chordSource&lt;locationType,lengthType&gt;</a>* chordScale_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
  3410. <a name="l03331"></a>03331 {
  3411. <a name="l03332"></a>03332 <span class="keywordflow">if</span>(<a class="code" href="classvabsBlade.html#a5e760efd8828271a6efd3371f1a8b50c">canDelete</a> &amp;&amp; <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>!=NULL)
  3412. <a name="l03333"></a>03333 <span class="keyword">delete</span> <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>;
  3413. <a name="l03334"></a>03334
  3414. <a name="l03335"></a>03335 <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>=chordScale_in;
  3415. <a name="l03336"></a>03336 <a class="code" href="classvabsBlade.html#a5e760efd8828271a6efd3371f1a8b50c">canDelete</a>=canDelete_in;
  3416. <a name="l03337"></a>03337 }
  3417. <a name="l03338"></a>03338 };
  3418. <a name="l03339"></a>03339
  3419. <a name="l03340"></a>03340 <span class="comment">// this version of vabsBlade assumes that there is a one-one correspondence between the crossSectionGeom and the vabs model</span>
  3420. <a name="l03341"></a>03341 <span class="comment">// other versions to be implemented later include one where there is one crossSectionGeom for all</span>
  3421. <a name="l03342"></a>03342 <span class="comment">// another is one where there is a different number of crossSectionGeom than vabsModels and there is some mapping between the two</span>
  3422. <a name="l03343"></a>03343 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> cxDesignType,<span class="keyword">class</span> beamMtxType,<span class="keyword">class</span> strainType,<span class="keyword">class</span> locationType=dataType,<span class="keyword">class</span> lengthType=dataType,<span class="keyword">class</span> areaType=dataType&gt;
  3423. <a name="l03344"></a><a class="code" href="classvabsBlade__vector.html">03344</a> <span class="keyword">class </span><a class="code" href="classvabsBlade__vector.html">vabsBlade_vector</a> : <span class="keyword">public</span> <a class="code" href="classvabsBlade.html">vabsBlade</a>&lt;locationType,lengthType,cxDesignType,beamMtxType,scalingObject&lt;dataType,VABSElementInfo&lt;dataType,strainType&gt; &gt;,areaType&gt;
  3424. <a name="l03345"></a>03345 {
  3425. <a name="l03346"></a>03346 <span class="keyword">private</span>:
  3426. <a name="l03347"></a>03347
  3427. <a name="l03348"></a>03348 <span class="comment">// chordSource&lt;locationType,lengthType&gt;* chordScale;</span>
  3428. <a name="l03349"></a>03349 <span class="comment">// bool canDelete;</span>
  3429. <a name="l03350"></a>03350
  3430. <a name="l03351"></a>03351 std::vector&lt;locationType&gt; locations;
  3431. <a name="l03352"></a>03352 std::vector&lt;crossSectionGeom&lt;dataType,cxDesignType&gt;*&gt; cxGeoms;
  3432. <a name="l03353"></a>03353 std::vector&lt;VABSModel&lt;dataType,beamMtxType,VABSElementInfo&lt;dataType,strainType&gt; &gt;*&gt; vabsModels;
  3433. <a name="l03354"></a>03354
  3434. <a name="l03355"></a>03355 <span class="comment">// variables for pre/post processing the mesh</span>
  3435. <a name="l03356"></a>03356 std::vector&lt;cxAreaIntProp_Data&lt;dataType&gt; &gt; meshProps;
  3436. <a name="l03357"></a>03357 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> centerX;
  3437. <a name="l03358"></a>03358 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> centerY;
  3438. <a name="l03359"></a>03359
  3439. <a name="l03360"></a>03360 std::vector&lt;bool&gt; deleteCX;
  3440. <a name="l03361"></a>03361 std::vector&lt;bool&gt; deleteVABS;
  3441. <a name="l03362"></a>03362
  3442. <a name="l03363"></a>03363 <a class="code" href="classcxDesignSource.html">cxDesignSource&lt;locationType,cxDesignType&gt;</a>* desSrc;
  3443. <a name="l03364"></a>03364 <span class="keywordtype">bool</span> deleteCXDesignSource;
  3444. <a name="l03365"></a>03365 <span class="keywordtype">bool</span> meshSet;
  3445. <a name="l03366"></a>03366
  3446. <a name="l03367"></a>03367 <span class="keyword">public</span>:
  3447. <a name="l03368"></a>03368
  3448. <a name="l03369"></a><a class="code" href="classvabsBlade__vector.html#ae123c234dfdbb4dbdc8b6e39d45c22d6">03369</a> <a class="code" href="classvabsBlade__vector.html#ae123c234dfdbb4dbdc8b6e39d45c22d6">vabsBlade_vector</a>(
  3449. <a name="l03370"></a>03370 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> size_in=1,
  3450. <a name="l03371"></a>03371 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> centerX_in=0.0,
  3451. <a name="l03372"></a>03372 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> centerY_in=0.0,
  3452. <a name="l03373"></a>03373 <a class="code" href="classchordSource.html">chordSource&lt;locationType,lengthType&gt;</a>* chordScale_in=NULL,
  3453. <a name="l03374"></a>03374 <a class="code" href="classcxDesignSource.html">cxDesignSource&lt;locationType,cxDesignType&gt;</a>* desSrc_in=NULL,
  3454. <a name="l03375"></a>03375 <span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>,
  3455. <a name="l03376"></a>03376 <span class="keywordtype">bool</span> deleteCXDesignSource_in=<span class="keyword">false</span>)
  3456. <a name="l03377"></a>03377 : <a class="code" href="classvabsBlade.html">vabsBlade</a>&lt;locationType,lengthType,cxDesignType,beamMtxType,<a class="code" href="classscalingObject.html">scalingObject</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,strainType&gt; &gt;,areaType&gt;(chordScale_in,canDelete_in)
  3457. <a name="l03378"></a>03378 , locations(size_in,0.0)
  3458. <a name="l03379"></a>03379 , cxGeoms(size_in,NULL)
  3459. <a name="l03380"></a>03380 , vabsModels(size_in,NULL)
  3460. <a name="l03381"></a>03381 , meshProps(size_in)
  3461. <a name="l03382"></a>03382 , centerX(centerX_in)
  3462. <a name="l03383"></a>03383 , centerY(centerY_in)
  3463. <a name="l03384"></a>03384 , deleteCX(size_in,false)
  3464. <a name="l03385"></a>03385 , deleteVABS(size_in,false)
  3465. <a name="l03386"></a>03386 , desSrc(desSrc_in)
  3466. <a name="l03387"></a>03387 , deleteCXDesignSource(deleteCXDesignSource_in)
  3467. <a name="l03388"></a>03388 , meshSet(false)
  3468. <a name="l03389"></a>03389 {}
  3469. <a name="l03390"></a>03390
  3470. <a name="l03391"></a><a class="code" href="classvabsBlade__vector.html#a0e0003a1412a1a34f0074a1ddc33973f">03391</a> <span class="keyword">virtual</span> <a class="code" href="classvabsBlade__vector.html#a0e0003a1412a1a34f0074a1ddc33973f">~vabsBlade_vector</a>()
  3471. <a name="l03392"></a>03392 {
  3472. <a name="l03393"></a>03393 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;cxGeoms.size();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  3473. <a name="l03394"></a>03394 {
  3474. <a name="l03395"></a>03395 <span class="keywordflow">if</span>(deleteCX[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>] &amp;&amp; cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]!=NULL)
  3475. <a name="l03396"></a>03396 <span class="keyword">delete</span> cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>];
  3476. <a name="l03397"></a>03397 <span class="keywordflow">if</span>(deleteVABS[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>] &amp;&amp; vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]!=NULL)
  3477. <a name="l03398"></a>03398 <span class="keyword">delete</span> vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>];
  3478. <a name="l03399"></a>03399 }
  3479. <a name="l03400"></a>03400
  3480. <a name="l03401"></a>03401 <span class="keywordflow">if</span>(deleteCXDesignSource &amp;&amp; desSrc!=NULL)
  3481. <a name="l03402"></a>03402 <span class="keyword">delete</span> desSrc;
  3482. <a name="l03403"></a>03403 }
  3483. <a name="l03404"></a>03404
  3484. <a name="l03405"></a><a class="code" href="classvabsBlade__vector.html#a7e461b772fe8adc53cee97f286e721ca">03405</a> <a class="code" href="classvabsBlade__vector.html">vabsBlade_vector&lt;dataType,cxDesignType,beamMtxType,strainType,locationType,lengthType&gt;</a>&amp; <a class="code" href="classvabsBlade__vector.html#a7e461b772fe8adc53cee97f286e721ca">setCrossSection</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at,locationType location_in,<a class="code" href="classcrossSectionGeom.html">crossSectionGeom&lt;dataType,cxDesignType&gt;</a>* cxGeom_in,<a class="code" href="classVABSModel.html">VABSModel</a>&lt;<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,beamMtxType,<a class="code" href="classVABSElementInfo.html">VABSElementInfo&lt;dataType,strainType&gt;</a> &gt;* vabsModel_in,<span class="keywordtype">bool</span> deleteCX_in=<span class="keyword">false</span>,<span class="keywordtype">bool</span> deleteVABS_in=<span class="keyword">false</span>)
  3485. <a name="l03406"></a>03406 {
  3486. <a name="l03407"></a>03407 <span class="keywordflow">if</span>(at&gt;=locations.size())
  3487. <a name="l03408"></a>03408 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::setCX(): The cross section does not exist&quot;</span>);
  3488. <a name="l03409"></a>03409
  3489. <a name="l03410"></a>03410 locations[at]=location_in;
  3490. <a name="l03411"></a>03411
  3491. <a name="l03412"></a>03412 <span class="keywordflow">if</span>(deleteCX[at] &amp;&amp; cxGeoms[at]!=NULL)
  3492. <a name="l03413"></a>03413 <span class="keyword">delete</span> cxGeoms[at];
  3493. <a name="l03414"></a>03414 cxGeoms[at]=cxGeom_in;
  3494. <a name="l03415"></a>03415
  3495. <a name="l03416"></a>03416 <span class="keywordflow">if</span>(deleteVABS[at] &amp;&amp; vabsModels[at]!=NULL)
  3496. <a name="l03417"></a>03417 <span class="keyword">delete</span> vabsModels[at];
  3497. <a name="l03418"></a>03418 vabsModels[at]=vabsModel_in;
  3498. <a name="l03419"></a>03419
  3499. <a name="l03420"></a>03420 deleteCX[at]=deleteCX_in;
  3500. <a name="l03421"></a>03421 deleteVABS[at]=deleteVABS_in;
  3501. <a name="l03422"></a>03422
  3502. <a name="l03423"></a>03423 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
  3503. <a name="l03424"></a>03424 }
  3504. <a name="l03425"></a>03425
  3505. <a name="l03426"></a><a class="code" href="classvabsBlade__vector.html#ac30a08e5ffc9674a68428260a74155e3">03426</a> <span class="keywordtype">void</span> <a class="code" href="classvabsBlade__vector.html#ac30a08e5ffc9674a68428260a74155e3">resize</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> size_in)
  3506. <a name="l03427"></a>03427 {
  3507. <a name="l03428"></a>03428 <span class="keywordflow">if</span>(size_in==this-&gt;<a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>())
  3508. <a name="l03429"></a>03429 <span class="keywordflow">return</span>;
  3509. <a name="l03430"></a>03430 <span class="keywordflow">if</span>(size_in&lt;this-&gt;<a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>())
  3510. <a name="l03431"></a>03431 {
  3511. <a name="l03432"></a>03432 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=size_in;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;cxGeoms.size();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  3512. <a name="l03433"></a>03433 {
  3513. <a name="l03434"></a>03434 <span class="keywordflow">if</span>(deleteCX[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>] &amp;&amp; cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]!=NULL)
  3514. <a name="l03435"></a>03435 <span class="keyword">delete</span> cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>];
  3515. <a name="l03436"></a>03436 <span class="keywordflow">if</span>(deleteVABS[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>] &amp;&amp; vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]!=NULL)
  3516. <a name="l03437"></a>03437 <span class="keyword">delete</span> vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>];
  3517. <a name="l03438"></a>03438 }
  3518. <a name="l03439"></a>03439 }
  3519. <a name="l03440"></a>03440
  3520. <a name="l03441"></a>03441 locations.resize(size_in,0.0);
  3521. <a name="l03442"></a>03442 cxGeoms.resize(size_in,NULL);
  3522. <a name="l03443"></a>03443 vabsModels.resize(size_in,NULL);
  3523. <a name="l03444"></a>03444 deleteCX.resize(size_in,<span class="keyword">false</span>);
  3524. <a name="l03445"></a>03445 deleteVABS.resize(size_in,<span class="keyword">false</span>);
  3525. <a name="l03446"></a>03446 }
  3526. <a name="l03447"></a>03447
  3527. <a name="l03448"></a>03448 <span class="comment">// get the information about the contents</span>
  3528. <a name="l03449"></a><a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">03449</a> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>()
  3529. <a name="l03450"></a>03450 {
  3530. <a name="l03451"></a>03451 <span class="keywordflow">return</span> locations.size();
  3531. <a name="l03452"></a>03452 }
  3532. <a name="l03453"></a>03453
  3533. <a name="l03454"></a><a class="code" href="classvabsBlade__vector.html#a71834860eca9726e6189fb4da20e7078">03454</a> locationType <a class="code" href="classvabsBlade__vector.html#a71834860eca9726e6189fb4da20e7078">getLocation</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)
  3534. <a name="l03455"></a>03455 {
  3535. <a name="l03456"></a>03456 <span class="keywordflow">if</span>(at&gt;=locations.size())
  3536. <a name="l03457"></a>03457 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::getLocation(): The cross section does not exist&quot;</span>);
  3537. <a name="l03458"></a>03458
  3538. <a name="l03459"></a>03459 <span class="keywordflow">return</span> locations[at];
  3539. <a name="l03460"></a>03460 }
  3540. <a name="l03461"></a>03461
  3541. <a name="l03462"></a>03462 <span class="comment">// pass in the input parameters</span>
  3542. <a name="l03463"></a><a class="code" href="classvabsBlade__vector.html#ac103c6c6410d0effc5921fd8857a1f9e">03463</a> <span class="keywordtype">void</span> <a class="code" href="classvabsBlade__vector.html#ac103c6c6410d0effc5921fd8857a1f9e">setCXDesignSource</a>(<a class="code" href="classcxDesignSource.html">cxDesignSource&lt;locationType,cxDesignType&gt;</a>* desSrc_in,<span class="keywordtype">bool</span> deleteCXDesignSource_in=<span class="keyword">false</span>)
  3543. <a name="l03464"></a>03464 {
  3544. <a name="l03465"></a>03465 <span class="keywordflow">if</span>(deleteCXDesignSource &amp;&amp; desSrc!=NULL &amp;&amp; desSrc!=desSrc_in)
  3545. <a name="l03466"></a>03466 <span class="keyword">delete</span> desSrc;
  3546. <a name="l03467"></a>03467
  3547. <a name="l03468"></a>03468 desSrc=desSrc_in;
  3548. <a name="l03469"></a>03469 deleteCXDesignSource=deleteCXDesignSource_in;
  3549. <a name="l03470"></a>03470 }
  3550. <a name="l03471"></a>03471
  3551. <a name="l03472"></a><a class="code" href="classvabsBlade__vector.html#ade73ef7d1c851840595f6628d9ee3daf">03472</a> <span class="keywordtype">void</span> <a class="code" href="classvabsBlade__vector.html#ade73ef7d1c851840595f6628d9ee3daf">newDesign</a>()
  3552. <a name="l03473"></a>03473 {
  3553. <a name="l03474"></a>03474 <span class="keywordflow">if</span>(desSrc==NULL)
  3554. <a name="l03475"></a>03475 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::newDesign(): The design source has not been set&quot;</span>);
  3555. <a name="l03476"></a>03476 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;this-&gt;<a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  3556. <a name="l03477"></a>03477 {
  3557. <a name="l03478"></a>03478 <span class="keywordflow">if</span>(cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]==NULL)
  3558. <a name="l03479"></a>03479 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::newDesign(): Not all the cross section geometries have been set&quot;</span>);
  3559. <a name="l03480"></a>03480 <span class="keywordflow">if</span>(vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]==NULL)
  3560. <a name="l03481"></a>03481 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::newDesign(): Not all the vabs models have been set&quot;</span>);
  3561. <a name="l03482"></a>03482 }
  3562. <a name="l03483"></a>03483
  3563. <a name="l03484"></a>03484 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;this-&gt;<a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  3564. <a name="l03485"></a>03485 {
  3565. <a name="l03486"></a>03486 cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;setDesign(desSrc-&gt;getCXDesign(locations[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]));
  3566. <a name="l03487"></a>03487
  3567. <a name="l03488"></a>03488 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3568. <a name="l03489"></a>03489 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
  3569. <a name="l03490"></a>03490 <a class="code" href="namespaceTIMEALG.html#a3fb3afd05aab47f9f50f1d31f74b420d">TIMEALG::meshCalcStart</a>();
  3570. <a name="l03491"></a>03491 <span class="preprocessor">#endif</span>
  3571. <a name="l03492"></a>03492 <span class="preprocessor"></span>
  3572. <a name="l03493"></a>03493 <a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>* msh=<span class="keyword">new</span> <a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>();
  3573. <a name="l03494"></a>03494 <span class="keywordflow">if</span>(msh==NULL)
  3574. <a name="l03495"></a>03495 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::newDesign(): Failed to create the mesh&quot;</span>);
  3575. <a name="l03496"></a>03496 cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;getMesh(*msh);
  3576. <a name="l03497"></a>03497
  3577. <a name="l03498"></a>03498 <span class="comment">// generate the mesh statistics</span>
  3578. <a name="l03499"></a>03499 meshProps[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]=msh-&gt;<a class="code" href="classmesh.html#a5a1537dc32069794a5295a4a5e506ce7">getProperties</a>();
  3579. <a name="l03500"></a>03500
  3580. <a name="l03501"></a>03501 msh-&gt;<a class="code" href="classmesh.html#a16f338040b8caf85f37a48d9eaa1c744">shift</a>(-meshProps[i].xBar,-meshProps[i].yBar);
  3581. <a name="l03502"></a>03502
  3582. <a name="l03503"></a>03503 <span class="comment">// // shift the mesh to the desired origin</span>
  3583. <a name="l03504"></a>03504 <span class="comment">// if(centerX!=0.0 || centerY!=0.0)</span>
  3584. <a name="l03505"></a>03505 <span class="comment">// msh-&gt;shift(-centerX,-centerY);</span>
  3585. <a name="l03506"></a>03506
  3586. <a name="l03507"></a>03507 vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;setMesh(msh,<span class="keyword">true</span>);
  3587. <a name="l03508"></a>03508
  3588. <a name="l03509"></a>03509 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3589. <a name="l03510"></a>03510 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a0f6f1e21ec85156faf6da7393aae7287">TIMEALG::meshCalcStop</a>();
  3590. <a name="l03511"></a>03511 <span class="preprocessor">#endif</span>
  3591. <a name="l03512"></a>03512 <span class="preprocessor"></span>
  3592. <a name="l03513"></a>03513 }
  3593. <a name="l03514"></a>03514 meshSet=<span class="keyword">true</span>;
  3594. <a name="l03515"></a>03515 }
  3595. <a name="l03516"></a>03516
  3596. <a name="l03517"></a>03517 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
  3597. <a name="l03518"></a>03518 <span class="preprocessor"></span>
  3598. <a name="l03519"></a>03519 <span class="keywordtype">void</span> highDesign()
  3599. <a name="l03520"></a>03520 {
  3600. <a name="l03521"></a>03521 <span class="keywordflow">if</span>(desSrc==NULL)
  3601. <a name="l03522"></a>03522 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::newDesign(): The design source has not been set&quot;</span>);
  3602. <a name="l03523"></a>03523 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;this-&gt;<a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  3603. <a name="l03524"></a>03524 {
  3604. <a name="l03525"></a>03525 <span class="keywordflow">if</span>(cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]==NULL)
  3605. <a name="l03526"></a>03526 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::newDesign(): Not all the cross section geometries have been set&quot;</span>);
  3606. <a name="l03527"></a>03527 <span class="keywordflow">if</span>(vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]==NULL)
  3607. <a name="l03528"></a>03528 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::newDesign(): Not all the vabs models have been set&quot;</span>);
  3608. <a name="l03529"></a>03529 }
  3609. <a name="l03530"></a>03530
  3610. <a name="l03531"></a>03531 <span class="keyword">typename</span> std::vector&lt;VABS1Model_Base&lt;dataType&gt;*&gt;::iterator it=VABS1Model_Base&lt;dataType&gt;::vabsList.begin();
  3611. <a name="l03532"></a>03532 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> nLoop=this-&gt;<a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();
  3612. <a name="l03533"></a>03533
  3613. <a name="l03534"></a>03534 std::vector&lt; mesh&lt;dataType&gt;* &gt; msh(nLoop,NULL);
  3614. <a name="l03535"></a>03535
  3615. <a name="l03536"></a>03536 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;nLoop;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  3616. <a name="l03537"></a>03537 {
  3617. <a name="l03538"></a>03538 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3618. <a name="l03539"></a>03539 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>);
  3619. <a name="l03540"></a>03540 <a class="code" href="namespaceTIMEALG.html#a3fb3afd05aab47f9f50f1d31f74b420d">TIMEALG::meshCalcStart</a>();
  3620. <a name="l03541"></a>03541 <span class="preprocessor">#endif</span>
  3621. <a name="l03542"></a>03542 <span class="preprocessor"></span> msh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]=<span class="keyword">new</span> <a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>();
  3622. <a name="l03543"></a>03543 <span class="keywordflow">if</span>(msh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]==NULL)
  3623. <a name="l03544"></a>03544 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::newDesign(): Failed to create the mesh&quot;</span>);
  3624. <a name="l03545"></a>03545 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3625. <a name="l03546"></a>03546 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a0f6f1e21ec85156faf6da7393aae7287">TIMEALG::meshCalcStop</a>();
  3626. <a name="l03547"></a>03547 <span class="preprocessor">#endif</span>
  3627. <a name="l03548"></a>03548 <span class="preprocessor"></span> }
  3628. <a name="l03549"></a>03549
  3629. <a name="l03550"></a>03550 <span class="comment">// #pragma omp parallel default(shared)</span>
  3630. <a name="l03551"></a>03551 {
  3631. <a name="l03552"></a>03552 <span class="comment">// #pragma omp for schedule(static,1)</span>
  3632. <a name="l03553"></a>03553 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>=0;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>&lt;nLoop;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
  3633. <a name="l03554"></a>03554 {
  3634. <a name="l03555"></a>03555 cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;setDesign(desSrc-&gt;getCXDesign(locations[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]));
  3635. <a name="l03556"></a>03556
  3636. <a name="l03557"></a>03557 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3637. <a name="l03558"></a>03558 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
  3638. <a name="l03559"></a>03559 <a class="code" href="namespaceTIMEALG.html#a3fb3afd05aab47f9f50f1d31f74b420d">TIMEALG::meshCalcStart</a>();
  3639. <a name="l03560"></a>03560 <span class="preprocessor">#endif</span>
  3640. <a name="l03561"></a>03561 <span class="preprocessor"></span>
  3641. <a name="l03562"></a>03562 <span class="comment">// mesh&lt;dataType&gt;* msh=new mesh&lt;dataType&gt;();</span>
  3642. <a name="l03563"></a>03563 <span class="comment">// if(msh==NULL)</span>
  3643. <a name="l03564"></a>03564 <span class="comment">// throw eMsg(&quot;vabsBlade_vector::newDesign(): Failed to create the mesh&quot;);</span>
  3644. <a name="l03565"></a>03565 cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;getMesh(*msh[i]);
  3645. <a name="l03566"></a>03566
  3646. <a name="l03567"></a>03567 <span class="comment">// generate the mesh statistics</span>
  3647. <a name="l03568"></a>03568 meshProps[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]=msh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;getProperties();
  3648. <a name="l03569"></a>03569 <span class="comment">// cxAreaIntProp_Data&lt;dataType&gt; meshProp=msh-&gt;getProperties();</span>
  3649. <a name="l03570"></a>03570
  3650. <a name="l03571"></a>03571 msh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;shift(-meshProps[i].xBar,-meshProps[i].yBar);
  3651. <a name="l03572"></a>03572
  3652. <a name="l03573"></a>03573 <span class="comment">// // shift the mesh to the desired origin</span>
  3653. <a name="l03574"></a>03574 <span class="comment">// if(centerX!=0.0 || centerY!=0.0)</span>
  3654. <a name="l03575"></a>03575 <span class="comment">// msh-&gt;shift(-centerX,-centerY);</span>
  3655. <a name="l03576"></a>03576
  3656. <a name="l03577"></a>03577 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3657. <a name="l03578"></a>03578 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a0f6f1e21ec85156faf6da7393aae7287">TIMEALG::meshCalcStop</a>();
  3658. <a name="l03579"></a>03579 <span class="preprocessor">#endif</span>
  3659. <a name="l03580"></a>03580 <span class="preprocessor"></span>
  3660. <a name="l03581"></a>03581 (*it)-&gt;buildHighMatrix(msh[i]);
  3661. <a name="l03582"></a>03582 it++;
  3662. <a name="l03583"></a>03583
  3663. <a name="l03584"></a>03584 <span class="comment">// delete msh;</span>
  3664. <a name="l03585"></a>03585 }
  3665. <a name="l03586"></a>03586 }
  3666. <a name="l03587"></a>03587
  3667. <a name="l03588"></a>03588 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i&lt;nLoop;i++)
  3668. <a name="l03589"></a>03589 <span class="keyword">delete</span> msh[i];
  3669. <a name="l03590"></a>03590 }
  3670. <a name="l03591"></a>03591
  3671. <a name="l03592"></a>03592 <span class="keywordtype">void</span> lowDesign()
  3672. <a name="l03593"></a>03593 {
  3673. <a name="l03594"></a>03594 <span class="keywordflow">if</span>(desSrc==NULL)
  3674. <a name="l03595"></a>03595 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::newDesign(): The design source has not been set&quot;</span>);
  3675. <a name="l03596"></a>03596 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i&lt;this-&gt;<a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();i++)
  3676. <a name="l03597"></a>03597 {
  3677. <a name="l03598"></a>03598 <span class="keywordflow">if</span>(cxGeoms[i]==NULL)
  3678. <a name="l03599"></a>03599 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::newDesign(): Not all the cross section geometries have been set&quot;</span>);
  3679. <a name="l03600"></a>03600 <span class="keywordflow">if</span>(vabsModels[i]==NULL)
  3680. <a name="l03601"></a>03601 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::newDesign(): Not all the vabs models have been set&quot;</span>);
  3681. <a name="l03602"></a>03602 }
  3682. <a name="l03603"></a>03603
  3683. <a name="l03604"></a>03604 <span class="keyword">typename</span> std::vector&lt;VABS1Model_Base&lt;dataType&gt;*&gt;::iterator it=VABS1Model_Base&lt;dataType&gt;::vabsList.begin();
  3684. <a name="l03605"></a>03605 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> nLoop=this-&gt;<a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();
  3685. <a name="l03606"></a>03606
  3686. <a name="l03607"></a>03607 std::vector&lt; mesh&lt;dataType&gt;* &gt; msh(nLoop,NULL);
  3687. <a name="l03608"></a>03608
  3688. <a name="l03609"></a>03609 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i&lt;nLoop;i++)
  3689. <a name="l03610"></a>03610 {
  3690. <a name="l03611"></a>03611 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3691. <a name="l03612"></a>03612 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
  3692. <a name="l03613"></a>03613 <a class="code" href="namespaceTIMEALG.html#a3fb3afd05aab47f9f50f1d31f74b420d">TIMEALG::meshCalcStart</a>();
  3693. <a name="l03614"></a>03614 <span class="preprocessor">#endif</span>
  3694. <a name="l03615"></a>03615 <span class="preprocessor"></span> msh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]=<span class="keyword">new</span> <a class="code" href="classmesh.html">mesh&lt;dataType&gt;</a>();
  3695. <a name="l03616"></a>03616 <span class="keywordflow">if</span>(msh[i]==NULL)
  3696. <a name="l03617"></a>03617 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::newDesign(): Failed to create the mesh&quot;</span>);
  3697. <a name="l03618"></a>03618 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3698. <a name="l03619"></a>03619 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a0f6f1e21ec85156faf6da7393aae7287">TIMEALG::meshCalcStop</a>();
  3699. <a name="l03620"></a>03620 <span class="preprocessor">#endif</span>
  3700. <a name="l03621"></a>03621 <span class="preprocessor"></span> }
  3701. <a name="l03622"></a>03622
  3702. <a name="l03623"></a>03623 <span class="comment">// #pragma omp parallel default(shared)</span>
  3703. <a name="l03624"></a>03624 {
  3704. <a name="l03625"></a>03625 <span class="comment">// #pragma omp for schedule(static,1)</span>
  3705. <a name="l03626"></a>03626 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i&lt;nLoop;i++)
  3706. <a name="l03627"></a>03627 {
  3707. <a name="l03628"></a>03628 cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;setDesign(desSrc-&gt;getCXDesign(locations[i]));
  3708. <a name="l03629"></a>03629
  3709. <a name="l03630"></a>03630 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3710. <a name="l03631"></a>03631 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
  3711. <a name="l03632"></a>03632 <a class="code" href="namespaceTIMEALG.html#a3fb3afd05aab47f9f50f1d31f74b420d">TIMEALG::meshCalcStart</a>();
  3712. <a name="l03633"></a>03633 <span class="preprocessor">#endif</span>
  3713. <a name="l03634"></a>03634 <span class="preprocessor"></span>
  3714. <a name="l03635"></a>03635 <span class="comment">// mesh&lt;dataType&gt;* msh=new mesh&lt;dataType&gt;();</span>
  3715. <a name="l03636"></a>03636 <span class="comment">// if(msh==NULL)</span>
  3716. <a name="l03637"></a>03637 <span class="comment">// throw eMsg(&quot;vabsBlade_vector::newDesign(): Failed to create the mesh&quot;);</span>
  3717. <a name="l03638"></a>03638 cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;getMesh(*msh[i]);
  3718. <a name="l03639"></a>03639
  3719. <a name="l03640"></a>03640 <span class="comment">// generate the mesh statistics</span>
  3720. <a name="l03641"></a>03641 meshProps[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]=msh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;getProperties();
  3721. <a name="l03642"></a>03642 <span class="comment">// cxAreaIntProp_Data&lt;dataType&gt; meshProp=msh-&gt;getProperties();</span>
  3722. <a name="l03643"></a>03643
  3723. <a name="l03644"></a>03644 msh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;shift(-meshProps[i].xBar,-meshProps[i].yBar);
  3724. <a name="l03645"></a>03645
  3725. <a name="l03646"></a>03646 <span class="comment">// // shift the mesh to the desired origin</span>
  3726. <a name="l03647"></a>03647 <span class="comment">// if(centerX!=0.0 || centerY!=0.0)</span>
  3727. <a name="l03648"></a>03648 <span class="comment">// msh-&gt;shift(-centerX,-centerY);</span>
  3728. <a name="l03649"></a>03649
  3729. <a name="l03650"></a>03650 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3730. <a name="l03651"></a>03651 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a0f6f1e21ec85156faf6da7393aae7287">TIMEALG::meshCalcStop</a>();
  3731. <a name="l03652"></a>03652 <span class="preprocessor">#endif</span>
  3732. <a name="l03653"></a>03653 <span class="preprocessor"></span>
  3733. <a name="l03654"></a>03654 (*it)-&gt;buildLowMatrix(msh[i]);
  3734. <a name="l03655"></a>03655 it++;
  3735. <a name="l03656"></a>03656
  3736. <a name="l03657"></a>03657 <span class="comment">// delete msh;</span>
  3737. <a name="l03658"></a>03658 }
  3738. <a name="l03659"></a>03659
  3739. <a name="l03660"></a>03660 }
  3740. <a name="l03661"></a>03661
  3741. <a name="l03662"></a>03662 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i&lt;nLoop;i++)
  3742. <a name="l03663"></a>03663 <span class="keyword">delete</span> msh[i];
  3743. <a name="l03664"></a>03664 }
  3744. <a name="l03665"></a>03665
  3745. <a name="l03666"></a>03666 <span class="preprocessor">#endif</span>
  3746. <a name="l03667"></a>03667 <span class="preprocessor"></span>
  3747. <a name="l03668"></a><a class="code" href="classvabsBlade__vector.html#a3fb89cb57e5307bb08d6b16f1211ca47">03668</a> <span class="keywordtype">void</span> <a class="code" href="classvabsBlade__vector.html#a3fb89cb57e5307bb08d6b16f1211ca47">solve</a>()
  3748. <a name="l03669"></a>03669 {
  3749. <a name="l03670"></a>03670 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> maxLoop=this-&gt;<a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();
  3750. <a name="l03671"></a>03671
  3751. <a name="l03672"></a>03672 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i&lt;maxLoop;i++)
  3752. <a name="l03673"></a>03673 {
  3753. <a name="l03674"></a>03674 <span class="keywordflow">if</span>(vabsModels[i]==NULL)
  3754. <a name="l03675"></a>03675 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::solve(): Not all the vabs models have been set&quot;</span>);
  3755. <a name="l03676"></a>03676 }
  3756. <a name="l03677"></a>03677
  3757. <a name="l03678"></a>03678 <span class="keywordflow">if</span>(!meshSet)
  3758. <a name="l03679"></a>03679 <a class="code" href="classvabsBlade__vector.html#ade73ef7d1c851840595f6628d9ee3daf">newDesign</a>();
  3759. <a name="l03680"></a>03680
  3760. <a name="l03681"></a>03681 <span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
  3761. <a name="l03682"></a>03682 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> &lt;&lt; <span class="stringliteral">&quot;Starting the VABS calculations&quot;</span> &lt;&lt; std::endl;
  3762. <a name="l03683"></a>03683 <span class="preprocessor">#endif</span>
  3763. <a name="l03684"></a>03684 <span class="preprocessor"></span>
  3764. <a name="l03685"></a>03685 <span class="preprocessor">#ifndef IGNORE_OMP</span>
  3765. <a name="l03686"></a>03686 <span class="preprocessor"></span><span class="preprocessor"> #pragma omp parallel default(shared)</span>
  3766. <a name="l03687"></a>03687 <span class="preprocessor"></span> {
  3767. <a name="l03688"></a>03688 <span class="preprocessor"> #pragma omp for schedule(static,1)</span>
  3768. <a name="l03689"></a>03689 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
  3769. <a name="l03690"></a>03690 <span class="preprocessor"></span>
  3770. <a name="l03691"></a>03691 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i&lt;maxLoop;i++)
  3771. <a name="l03692"></a>03692 {
  3772. <a name="l03693"></a>03693 <span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
  3773. <a name="l03694"></a>03694 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> &lt;&lt; <span class="stringliteral">&quot;\tPreparing cross section &quot;</span> &lt;&lt; i &lt;&lt; std::endl;
  3774. <a name="l03695"></a>03695 <span class="preprocessor">#endif</span>
  3775. <a name="l03696"></a>03696 <span class="preprocessor"></span><span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3776. <a name="l03697"></a>03697 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
  3777. <a name="l03698"></a>03698 <span class="preprocessor">#endif</span>
  3778. <a name="l03699"></a>03699 <span class="preprocessor"></span> vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;buildSVD();
  3779. <a name="l03700"></a>03700 }
  3780. <a name="l03701"></a>03701 <span class="preprocessor">#ifndef IGNORE_OMP</span>
  3781. <a name="l03702"></a>03702 <span class="preprocessor"></span> }
  3782. <a name="l03703"></a>03703 <span class="preprocessor">#endif</span>
  3783. <a name="l03704"></a>03704 <span class="preprocessor"></span>
  3784. <a name="l03705"></a>03705 <span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
  3785. <a name="l03706"></a>03706 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> &lt;&lt; <span class="stringliteral">&quot;About to start decomposition&quot;</span> &lt;&lt; std::endl;
  3786. <a name="l03707"></a>03707 <span class="preprocessor">#endif</span>
  3787. <a name="l03708"></a>03708 <span class="preprocessor"></span>
  3788. <a name="l03709"></a>03709 <span class="preprocessor">#ifndef IGNORE_OMP</span>
  3789. <a name="l03710"></a>03710 <span class="preprocessor"></span><span class="preprocessor"> #pragma omp parallel default(shared)</span>
  3790. <a name="l03711"></a>03711 <span class="preprocessor"></span> {
  3791. <a name="l03712"></a>03712 <span class="preprocessor"> #pragma omp for schedule(static,1)</span>
  3792. <a name="l03713"></a>03713 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
  3793. <a name="l03714"></a>03714 <span class="preprocessor"></span> <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i&lt;maxLoop;i++)
  3794. <a name="l03715"></a>03715 {
  3795. <a name="l03716"></a>03716 <span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
  3796. <a name="l03717"></a>03717 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> &lt;&lt; <span class="stringliteral">&quot;\tDecomposing cross section &quot;</span> &lt;&lt; i &lt;&lt; std::endl;
  3797. <a name="l03718"></a>03718 <span class="preprocessor">#endif</span>
  3798. <a name="l03719"></a>03719 <span class="preprocessor"></span><span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3799. <a name="l03720"></a>03720 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
  3800. <a name="l03721"></a>03721 <span class="preprocessor">#endif</span>
  3801. <a name="l03722"></a>03722 <span class="preprocessor"></span> vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;solveSVD();
  3802. <a name="l03723"></a>03723 }
  3803. <a name="l03724"></a>03724 <span class="preprocessor">#ifndef IGNORE_OMP</span>
  3804. <a name="l03725"></a>03725 <span class="preprocessor"></span> }
  3805. <a name="l03726"></a>03726 <span class="preprocessor">#endif</span>
  3806. <a name="l03727"></a>03727 <span class="preprocessor"></span>
  3807. <a name="l03728"></a>03728 <span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
  3808. <a name="l03729"></a>03729 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> &lt;&lt; <span class="stringliteral">&quot;About to finalize the results&quot;</span> &lt;&lt; std::endl;
  3809. <a name="l03730"></a>03730 <span class="preprocessor">#endif</span>
  3810. <a name="l03731"></a>03731 <span class="preprocessor"></span>
  3811. <a name="l03732"></a>03732 <span class="preprocessor">#ifndef IGNORE_OMP</span>
  3812. <a name="l03733"></a>03733 <span class="preprocessor"></span><span class="preprocessor"> #pragma omp parallel</span>
  3813. <a name="l03734"></a>03734 <span class="preprocessor"></span> {
  3814. <a name="l03735"></a>03735 <span class="preprocessor"> #pragma omp for schedule(static,1)</span>
  3815. <a name="l03736"></a>03736 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
  3816. <a name="l03737"></a>03737 <span class="preprocessor"></span> <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i&lt;maxLoop;i++)
  3817. <a name="l03738"></a>03738 {
  3818. <a name="l03739"></a>03739 <span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
  3819. <a name="l03740"></a>03740 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> &lt;&lt; <span class="stringliteral">&quot;\tFinalizing cross section &quot;</span> &lt;&lt; i &lt;&lt; std::endl;
  3820. <a name="l03741"></a>03741 <span class="preprocessor">#endif</span>
  3821. <a name="l03742"></a>03742 <span class="preprocessor"></span><span class="preprocessor">#ifdef COLLECT_TIMING</span>
  3822. <a name="l03743"></a>03743 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
  3823. <a name="l03744"></a>03744 <span class="preprocessor">#endif</span>
  3824. <a name="l03745"></a>03745 <span class="preprocessor"></span> vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]-&gt;processSVD();
  3825. <a name="l03746"></a>03746 }
  3826. <a name="l03747"></a>03747 <span class="preprocessor">#ifndef IGNORE_OMP</span>
  3827. <a name="l03748"></a>03748 <span class="preprocessor"></span> }
  3828. <a name="l03749"></a>03749 <span class="preprocessor">#endif</span>
  3829. <a name="l03750"></a>03750 <span class="preprocessor"></span><span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
  3830. <a name="l03751"></a>03751 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> &lt;&lt; <span class="stringliteral">&quot;Done!&quot;</span> &lt;&lt; std::endl;
  3831. <a name="l03752"></a>03752 <span class="preprocessor">#endif</span>
  3832. <a name="l03753"></a>03753 <span class="preprocessor"></span> }
  3833. <a name="l03754"></a>03754
  3834. <a name="l03755"></a>03755 <span class="comment">// These are the methods the provide the K matrices</span>
  3835. <a name="l03756"></a><a class="code" href="classvabsBlade__vector.html#ae38d75c181e66138f6af1a029191c1d8">03756</a> <a class="code" href="classautoPntr.html">autoPntr&lt;scalingObject&lt;dataType,VABSModelBeamMatrix&lt;beamMtxType&gt;</a> &gt; &gt; <a class="code" href="classvabsBlade__vector.html#ae38d75c181e66138f6af1a029191c1d8">getMatrix</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)
  3836. <a name="l03757"></a>03757 {
  3837. <a name="l03758"></a>03758 <span class="keywordflow">if</span>(at&gt;=locations.size())
  3838. <a name="l03759"></a>03759 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::getMatrix(): The cross section does not exist&quot;</span>);
  3839. <a name="l03760"></a>03760 <span class="keywordflow">if</span>(this-&gt;<a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>==NULL)
  3840. <a name="l03761"></a>03761 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::getMatrix(): The chord scale has not been set&quot;</span>);
  3841. <a name="l03762"></a>03762 <span class="keywordflow">if</span>(vabsModels[at]==NULL)
  3842. <a name="l03763"></a>03763 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::getMatrix(): The VABS model has not been set&quot;</span>);
  3843. <a name="l03764"></a>03764
  3844. <a name="l03765"></a>03765 <span class="keywordflow">return</span> <a class="code" href="classautoPntr.html">autoPntr&lt;scalingObject&lt;dataType,VABSModelBeamMatrix&lt;beamMtxType&gt;</a> &gt; &gt;(<span class="keyword">new</span> <a class="code" href="classscalingObject__VABSModelBeamMatrix__Pntr.html">scalingObject_VABSModelBeamMatrix_Pntr&lt;lengthType,beamMtxType&gt;</a>(vabsModels[at],this-&gt;<a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>-&gt;<a class="code" href="classchordSource.html#acfdf28524e56a1d81727e1a834d55433">getChord</a>(locations[at]),<span class="keyword">false</span>),<span class="keyword">true</span>);
  3845. <a name="l03766"></a>03766 }
  3846. <a name="l03767"></a>03767
  3847. <a name="l03768"></a>03768 <span class="comment">// these are the methods that are used for post processing</span>
  3848. <a name="l03769"></a><a class="code" href="classvabsBlade__vector.html#ae8759e7e791303386f34dd858e8f4c26">03769</a> <a class="code" href="classautoPntr.html">autoPntr&lt;VABSModelPost&lt;scalingObject&lt;dataType,VABSElementInfo&lt;dataType,strainType&gt;</a> &gt; &gt; &gt; <a class="code" href="classvabsBlade__vector.html#ae8759e7e791303386f34dd858e8f4c26">getPost</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)
  3849. <a name="l03770"></a>03770 {
  3850. <a name="l03771"></a>03771 <span class="keywordflow">if</span>(at&gt;=locations.size())
  3851. <a name="l03772"></a>03772 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::getPost(): The cross section does not exist&quot;</span>);
  3852. <a name="l03773"></a>03773 <span class="keywordflow">if</span>(this-&gt;<a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>==NULL)
  3853. <a name="l03774"></a>03774 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::getPost(): The chord scale has not been set&quot;</span>);
  3854. <a name="l03775"></a>03775 <span class="keywordflow">if</span>(vabsModels[at]==NULL)
  3855. <a name="l03776"></a>03776 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::getPost(): The VABS model has not been set&quot;</span>);
  3856. <a name="l03777"></a>03777
  3857. <a name="l03778"></a>03778 <span class="keywordflow">return</span> <a class="code" href="classautoPntr.html">autoPntr&lt;VABSModelPost&lt;scalingObject&lt;dataType,VABSElementInfo&lt;dataType,strainType&gt;</a> &gt; &gt; &gt;(<span class="keyword">new</span> <a class="code" href="classVABSModelPost__scaling__Pntr.html">VABSModelPost_scaling_Pntr&lt;dataType,strainType&gt;</a>(vabsModels[at],this-&gt;<a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>-&gt;<a class="code" href="classchordSource.html#acfdf28524e56a1d81727e1a834d55433">getChord</a>(locations[at]),<span class="keyword">false</span>),<span class="keyword">true</span>);
  3858. <a name="l03779"></a>03779 }
  3859. <a name="l03780"></a>03780
  3860. <a name="l03781"></a><a class="code" href="classvabsBlade__vector.html#a22396fde7d382158677e43790149ca59">03781</a> areaType <a class="code" href="classvabsBlade__vector.html#a22396fde7d382158677e43790149ca59">getCrossSectionArea</a>(locationType location)
  3861. <a name="l03782"></a>03782 {
  3862. <a name="l03783"></a>03783 <span class="keywordflow">if</span>(location&lt;locationType(0.0) || location&gt;locationType(1.0))
  3863. <a name="l03784"></a>03784 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::getCrossSectionArea(): This area source is only defined on the domain of [0,1]&quot;</span>);
  3864. <a name="l03785"></a>03785 <span class="keywordflow">if</span>(this-&gt;<a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>==NULL)
  3865. <a name="l03786"></a>03786 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::getCrossSectionArea(): The chordScale object has not been set&quot;</span>);
  3866. <a name="l03787"></a>03787 <span class="keywordflow">if</span>(!meshSet)
  3867. <a name="l03788"></a>03788 <a class="code" href="classvabsBlade__vector.html#ade73ef7d1c851840595f6628d9ee3daf">newDesign</a>();
  3868. <a name="l03789"></a>03789
  3869. <a name="l03790"></a>03790 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;
  3870. <a name="l03791"></a>03791 <span class="keywordflow">while</span>(location&gt;locations[i] &amp;&amp; i&lt;(locations.size()-1))
  3871. <a name="l03792"></a>03792 i++;
  3872. <a name="l03793"></a>03793
  3873. <a name="l03794"></a>03794 <span class="comment">// collect the upper area</span>
  3874. <a name="l03795"></a>03795 <a class="code" href="classscalingObject__cxAreaIntProp__Pntr.html">scalingObject_cxAreaIntProp_Pntr&lt;dataType&gt;</a> aHigh(&amp;meshProps[i],this-&gt;<a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>-&gt;<a class="code" href="classchordSource.html#acfdf28524e56a1d81727e1a834d55433">getChord</a>(location),<span class="keyword">false</span>);
  3875. <a name="l03796"></a>03796
  3876. <a name="l03797"></a>03797 <span class="comment">// check if interpolation is needed... if not just return the value</span>
  3877. <a name="l03798"></a>03798 <span class="keywordflow">if</span>(i==0 || (i==(locations.size()-1) &amp;&amp; location&gt;locations[i]) )
  3878. <a name="l03799"></a>03799 <span class="keywordflow">return</span> aHigh.<a class="code" href="classscalingObject__cxAreaIntProp.html#a79fab7baffefb933ebc78dddbb0b84ad">getArea</a>();
  3879. <a name="l03800"></a>03800 <span class="keywordflow">if</span>(locations[i]==locations[i-1])
  3880. <a name="l03801"></a>03801 <span class="keywordflow">return</span> aHigh.getArea();
  3881. <a name="l03802"></a>03802
  3882. <a name="l03803"></a>03803 <span class="comment">// collect the lower matrix</span>
  3883. <a name="l03804"></a>03804 <a class="code" href="classscalingObject__cxAreaIntProp__Pntr.html">scalingObject_cxAreaIntProp_Pntr&lt;dataType&gt;</a> aLow(&amp;meshProps[i-1],this-&gt;<a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>-&gt;<a class="code" href="classchordSource.html#acfdf28524e56a1d81727e1a834d55433">getChord</a>(location),<span class="keyword">false</span>);
  3884. <a name="l03805"></a>03805
  3885. <a name="l03806"></a>03806 <span class="comment">// perform the interpolation (linear)</span>
  3886. <a name="l03807"></a>03807 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> weight=(location-locations[i-1])/(locations[i]-locations[i-1]);
  3887. <a name="l03808"></a>03808 <span class="keywordflow">return</span> (<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>(1.0)-weight)*aLow.<a class="code" href="classscalingObject__cxAreaIntProp.html#a79fab7baffefb933ebc78dddbb0b84ad">getArea</a>()+weight*aHigh.<a class="code" href="classscalingObject__cxAreaIntProp.html#a79fab7baffefb933ebc78dddbb0b84ad">getArea</a>();
  3888. <a name="l03809"></a>03809 }
  3889. <a name="l03810"></a>03810
  3890. <a name="l03811"></a><a class="code" href="classvabsBlade__vector.html#a63a0a7120f69a1ff735581358abacd0f">03811</a> <span class="keyword">const</span> areaType <a class="code" href="classvabsBlade__vector.html#a22396fde7d382158677e43790149ca59">getCrossSectionArea</a>(locationType location)<span class="keyword"> const</span>
  3891. <a name="l03812"></a>03812 <span class="keyword"> </span>{
  3892. <a name="l03813"></a>03813 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">&quot;vabsBlade_vector::getCrossSectionArea(): The const method has not been implemented&quot;</span>);
  3893. <a name="l03814"></a>03814 <span class="comment">// if(location&lt;locationType(0.0) || location&gt;locationType(1.0))</span>
  3894. <a name="l03815"></a>03815 <span class="comment">// throw eMsg(&quot;vabsBlade_vector::getCrossSectionArea(): This area source is only defined on the domain of [0,1]&quot;);</span>
  3895. <a name="l03816"></a>03816 <span class="comment">// if(this-&gt;chordScale==NULL)</span>
  3896. <a name="l03817"></a>03817 <span class="comment">// throw eMsg(&quot;vabsBlade_vector::getCrossSectionArea(): The chordScale object has not been set&quot;);</span>
  3897. <a name="l03818"></a>03818 <span class="comment">// if(!meshSet)</span>
  3898. <a name="l03819"></a>03819 <span class="comment">// newDesign();</span>
  3899. <a name="l03820"></a>03820 <span class="comment">// </span>
  3900. <a name="l03821"></a>03821 <span class="comment">// unsigned long i=0;</span>
  3901. <a name="l03822"></a>03822 <span class="comment">// while(location&gt;locations[i] &amp;&amp; i&lt;(locations.size()-1))</span>
  3902. <a name="l03823"></a>03823 <span class="comment">// i++;</span>
  3903. <a name="l03824"></a>03824 <span class="comment">// </span>
  3904. <a name="l03825"></a>03825 <span class="comment">// // collect the upper area</span>
  3905. <a name="l03826"></a>03826 <span class="comment">// scalingObject_cxAreaIntProp_Pntr&lt;dataType&gt; aHigh(&amp;meshProps[i],this-&gt;chordScale-&gt;getChord(location),false);</span>
  3906. <a name="l03827"></a>03827 <span class="comment">// </span>
  3907. <a name="l03828"></a>03828 <span class="comment">// // check if interpolation is needed... if not just return the value</span>
  3908. <a name="l03829"></a>03829 <span class="comment">// if(i==0 || i==(locations.size()-1))</span>
  3909. <a name="l03830"></a>03830 <span class="comment">// return aHigh.getArea();</span>
  3910. <a name="l03831"></a>03831 <span class="comment">// if(locations[i]==locations[i-1])</span>
  3911. <a name="l03832"></a>03832 <span class="comment">// return aHigh.getArea();</span>
  3912. <a name="l03833"></a>03833 <span class="comment">// </span>
  3913. <a name="l03834"></a>03834 <span class="comment">// // collect the lower matrix</span>
  3914. <a name="l03835"></a>03835 <span class="comment">// scalingObject_cxAreaIntProp_Pntr&lt;dataType&gt; aLow(&amp;meshProps[i-1],this-&gt;chordScale-&gt;getChord(location),false);</span>
  3915. <a name="l03836"></a>03836 <span class="comment">// </span>
  3916. <a name="l03837"></a>03837 <span class="comment">// // perform the interpolation (linear)</span>
  3917. <a name="l03838"></a>03838 <span class="comment">// dataType weight=(location-locations[i-1])/(locations[i]-locations[i-1]);</span>
  3918. <a name="l03839"></a>03839 <span class="comment">// return (dataType(1.0)-weight)*aLow.getArea()+weight*aHigh.getArea();</span>
  3919. <a name="l03840"></a>03840 }
  3920. <a name="l03841"></a>03841
  3921. <a name="l03842"></a>03842 <span class="comment">// autoPntr&lt;scalingObject&lt;lengthType,cxAreaIntProp&lt;dataType&gt; &gt; &gt; getCXPost(unsigned long at)</span>
  3922. <a name="l03843"></a>03843 <span class="comment">// {</span>
  3923. <a name="l03844"></a>03844 <span class="comment">// if(at&gt;=locations.size())</span>
  3924. <a name="l03845"></a>03845 <span class="comment">// throw eMsg(&quot;vabsBlade_vector::getCXPost(): The cross section does not exist&quot;);</span>
  3925. <a name="l03846"></a>03846 <span class="comment">// if(this-&gt;chordScale==NULL)</span>
  3926. <a name="l03847"></a>03847 <span class="comment">// throw eMsg(&quot;vabsBlade_vector::getCXPost(): The chord scale has not been set&quot;);</span>
  3927. <a name="l03848"></a>03848 <span class="comment">// </span>
  3928. <a name="l03849"></a>03849 <span class="comment">// return autoPntr&lt;scalingObject&lt;lengthType,cxAreaIntProp&lt;dataType&gt; &gt; &gt;(new scalingObject_cxAreaIntProp_Pntr(&amp;meshProps[at],this-&gt;chordScale-&gt;getChord(locations[at]),false),true);</span>
  3929. <a name="l03850"></a>03850 <span class="comment">// }</span>
  3930. <a name="l03851"></a>03851 };
  3931. <a name="l03852"></a>03852
  3932. <a name="l03853"></a>03853 <span class="keyword">template</span>&lt;<span class="keyword">class</span> dataType,<span class="keyword">class</span> beamMtxType,<span class="keyword">class</span> locationType=dataType,<span class="keyword">class</span> lengthType=dataType&gt;
  3933. <a name="l03854"></a><a class="code" href="classfunction__vabsBladeMatrix.html">03854</a> <span class="keyword">class </span><a class="code" href="classfunction__vabsBladeMatrix.html">function_vabsBlade