/doc/html/vabsSudo_8cpp_source.html
HTML | 3945 lines | 3932 code | 12 blank | 1 comment | 0 complexity | c0b71c54c03e62d2c468912abbc05e88 MD5 | raw file
Possible License(s): GPL-2.0, BSD-3-Clause
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
- <title>WindTurbineMDO: structural/VABS_Calc/source/ver_2/vabsSudo.cpp Source File</title>
- <link href="tabs.css" rel="stylesheet" type="text/css"/>
- <link href="doxygen.css" rel="stylesheet" type="text/css" />
- <link href="navtree.css" rel="stylesheet" type="text/css"/>
- <script type="text/javascript" src="jquery.js"></script>
- <script type="text/javascript" src="resize.js"></script>
- <script type="text/javascript" src="navtree.js"></script>
- <script type="text/javascript">
- $(document).ready(initResizable);
- </script>
- <link href="search/search.css" rel="stylesheet" type="text/css"/>
- <script type="text/javascript" src="search/search.js"></script>
- <script type="text/javascript">
- $(document).ready(function() { searchBox.OnSelectItem(0); });
- </script>
- </head>
- <body>
- <div id="top"><!-- do not remove this div! -->
- <div id="titlearea">
- <table cellspacing="0" cellpadding="0">
- <tbody>
- <tr style="height: 56px;">
-
-
- <td style="padding-left: 0.5em;">
- <div id="projectname">WindTurbineMDO
-
- </div>
-
- </td>
-
-
-
- </tr>
- </tbody>
- </table>
- </div>
- <!-- Generated by Doxygen 1.7.5.1 -->
- <script type="text/javascript">
- var searchBox = new SearchBox("searchBox", "search",false,'Search');
- </script>
- <div id="navrow1" class="tabs">
- <ul class="tablist">
- <li><a href="index.html"><span>Main Page</span></a></li>
- <li><a href="namespaces.html"><span>Namespaces</span></a></li>
- <li><a href="annotated.html"><span>Classes</span></a></li>
- <li class="current"><a href="files.html"><span>Files</span></a></li>
- <li>
- <div id="MSearchBox" class="MSearchBoxInactive">
- <span class="left">
- <img id="MSearchSelect" src="search/mag_sel.png"
- onmouseover="return searchBox.OnSearchSelectShow()"
- onmouseout="return searchBox.OnSearchSelectHide()"
- alt=""/>
- <input type="text" id="MSearchField" value="Search" accesskey="S"
- onfocus="searchBox.OnSearchFieldFocus(true)"
- onblur="searchBox.OnSearchFieldFocus(false)"
- onkeyup="searchBox.OnSearchFieldChange(event)"/>
- </span><span class="right">
- <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
- </span>
- </div>
- </li>
- </ul>
- </div>
- <div id="navrow2" class="tabs2">
- <ul class="tablist">
- <li><a href="files.html"><span>File List</span></a></li>
- <li><a href="globals.html"><span>File Members</span></a></li>
- </ul>
- </div>
- </div>
- <div id="side-nav" class="ui-resizable side-nav-resizable">
- <div id="nav-tree">
- <div id="nav-tree-contents">
- </div>
- </div>
- <div id="splitbar" style="-moz-user-select:none;"
- class="ui-resizable-handle">
- </div>
- </div>
- <script type="text/javascript">
- initNavTree('vabsSudo_8cpp.html','');
- </script>
- <div id="doc-content">
- <div class="header">
- <div class="headertitle">
- <div class="title">structural/VABS_Calc/source/ver_2/vabsSudo.cpp</div> </div>
- </div>
- <div class="contents">
- <a href="vabsSudo_8cpp.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001
- <a name="l00002"></a>00002 <span class="comment">// #include "matrix/matrixClass.h"</span>
- <a name="l00003"></a>00003 <span class="comment">// #include "/home/mike/work/UVic/NonlinearBeam/CAD_Calc/source/ver_1/meshSudo.cpp"</span>
- <a name="l00004"></a>00004 <span class="comment">// #include "/home/mike/work/UVic/NonlinearBeam/matrix_Solver/source/ver_1/matrixSolverSudo.cpp"</span>
- <a name="l00005"></a>00005 <span class="comment">// #include "/home/mike/work/UVic/NonlinearBeam/GEBT_Calc/source/ver_2/femSudoCode.cpp"</span>
- <a name="l00006"></a>00006 <span class="comment">// #include "material.cpp"</span>
- <a name="l00007"></a>00007 <span class="preprocessor">#include <algorithm></span>
- <a name="l00008"></a>00008 <span class="preprocessor">#include <memory></span>
- <a name="l00009"></a>00009
- <a name="l00010"></a>00010 <span class="comment">// #define ADJOINT_VABS</span>
- <a name="l00011"></a>00011
- <a name="l00012"></a>00012 <span class="comment">// #define SVD_BASED_VABS_SOLUTION</span>
- <a name="l00013"></a>00013
- <a name="l00014"></a>00014 <span class="comment">// #define PRINT_VABS_PROGRESS</span>
- <a name="l00015"></a>00015
- <a name="l00016"></a>00016 <span class="comment">// #define TIME_ADJOINT_CALCULATION</span>
- <a name="l00017"></a>00017
- <a name="l00018"></a>00018 <span class="comment">// #include <sys/time.h></span>
- <a name="l00019"></a>00019
- <a name="l00020"></a>00020 <span class="comment">// so lets talk about the VABS....</span>
- <a name="l00021"></a>00021
- <a name="l00022"></a>00022 <span class="comment">// ok the mesh program retrieves the minimal geometric information required to build a VABS model...</span>
- <a name="l00023"></a>00023
- <a name="l00024"></a>00024 <span class="comment">// A vabs element is only responsible for building a matrix</span>
- <a name="l00025"></a>00025
- <a name="l00026"></a>00026 <span class="comment">// Here is a structure</span>
- <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>
- <a name="l00028"></a>00028 <span class="comment">// we have VABS nodes that contain information from the mesh to build the matrices</span>
- <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>
- <a name="l00030"></a>00030
- <a name="l00031"></a>00031 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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>
- <a name="l00033"></a>00033 {
- <a name="l00034"></a>00034 <span class="keyword">public</span>:
- <a name="l00035"></a>00035
- <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>()
- <a name="l00037"></a>00037 {}
- <a name="l00038"></a>00038
- <a name="l00039"></a>00039 <span class="comment">// need to know position (2 scalars or 2-vect)</span>
- <a name="l00040"></a>00040 <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource<dataType></a>& <a class="code" href="classVABSNode.html#a04a4be0511f905869894e34c0b2901d8">x</a>() <span class="keyword">const</span> =0;
- <a name="l00041"></a>00041 <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource<dataType></a>& <a class="code" href="classVABSNode.html#ab8825545b32b55e848a2cdf394ebf8ed">y</a>() <span class="keyword">const</span> =0;
- <a name="l00042"></a>00042 <span class="comment">// need to know through thickness posisition (scalar)</span>
- <a name="l00043"></a>00043 <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource<dataType></a>& <a class="code" href="classVABSNode.html#a47bb48aeeb59af55084e7743bd2963b5">h</a>() <span class="keyword">const</span> =0;
- <a name="l00044"></a>00044 <span class="comment">// need to know ply angle (scalar)</span>
- <a name="l00045"></a>00045 <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource<dataType></a>& <a class="code" href="classVABSNode.html#acfd688e05d010009439d3459923ef7c0">plyAngle</a>() <span class="keyword">const</span> =0;
- <a name="l00046"></a>00046
- <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>
- <a name="l00048"></a>00048 <span class="comment">// need to know fiber angle (scalar) (optional for now ...)</span>
- <a name="l00049"></a>00049
- <a name="l00050"></a>00050 <span class="comment">// this is where the results of the VABS calculate is stored</span>
- <a name="l00051"></a>00051 <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="code" href="classdataSource.html">dataSource<matrixStatic<dataType,3,4></a> >& <a class="code" href="classVABSNode.html#a7bd73fd4e4208bb66e157c3882d01a29">warping</a>() <span class="keyword">const</span> =0;
- <a name="l00052"></a>00052
- <a name="l00053"></a>00053 };
- <a name="l00054"></a>00054
- <a name="l00055"></a>00055 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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>
- <a name="l00057"></a>00057 {
- <a name="l00058"></a>00058 <span class="keyword">private</span>:
- <a name="l00059"></a>00059
- <a name="l00060"></a>00060 <a class="code" href="classdataSource__Data.html">dataSource_Data<dataType></a> xSrc;
- <a name="l00061"></a>00061 <a class="code" href="classdataSource__Data.html">dataSource_Data<dataType></a> ySrc;
- <a name="l00062"></a>00062 <a class="code" href="classdataSource__Data.html">dataSource_Data<matrixStatic<dataType,3,4></a>,<a class="code" href="classmatrixRdWtStatic__pData.html">matrixRdWtStatic_pData<dataType,3,4></a> > warpSrc;
- <a name="l00063"></a>00063
- <a name="l00064"></a>00064 <span class="keyword">public</span>:
- <a name="l00065"></a>00065
- <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)
- <a name="l00067"></a>00067 {}
- <a name="l00068"></a>00068
- <a name="l00069"></a><a class="code" href="classVABSNode__common.html#ac7174c77d18117ebb8304c9f325262d8">00069</a> <a class="code" href="classVABSNode__common.html">VABSNode_common</a>& <a class="code" href="classVABSNode__common.html#ac7174c77d18117ebb8304c9f325262d8">setX</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> x_in)
- <a name="l00070"></a>00070 {
- <a name="l00071"></a>00071 xSrc.<a class="code" href="classdataSource__Data.html#aefa4c87ef5fb27413a5f2ce1356638d7">getData</a>()=x_in;
- <a name="l00072"></a>00072 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00073"></a>00073 }
- <a name="l00074"></a>00074
- <a name="l00075"></a><a class="code" href="classVABSNode__common.html#ae9c8384acbcc1a44b7424cfee345df20">00075</a> <a class="code" href="classVABSNode__common.html">VABSNode_common</a>& <a class="code" href="classVABSNode__common.html#ae9c8384acbcc1a44b7424cfee345df20">setY</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> y_in)
- <a name="l00076"></a>00076 {
- <a name="l00077"></a>00077 ySrc.<a class="code" href="classdataSource__Data.html#aefa4c87ef5fb27413a5f2ce1356638d7">getData</a>()=y_in;
- <a name="l00078"></a>00078 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00079"></a>00079 }
- <a name="l00080"></a>00080
- <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<dataType></a>& <a class="code" href="classVABSNode__common.html#a08b644d8490442f08872ef2679d119f3">x</a>()<span class="keyword"> const</span>
- <a name="l00082"></a>00082 <span class="keyword"> </span>{
- <a name="l00083"></a>00083 <span class="keywordflow">return</span> xSrc;
- <a name="l00084"></a>00084 }
- <a name="l00085"></a>00085
- <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<dataType></a>& <a class="code" href="classVABSNode__common.html#a091a6d771873b52c822d009c7bd8178e">y</a>()<span class="keyword"> const</span>
- <a name="l00087"></a>00087 <span class="keyword"> </span>{
- <a name="l00088"></a>00088 <span class="keywordflow">return</span> ySrc;
- <a name="l00089"></a>00089 }
- <a name="l00090"></a>00090
- <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<matrixStatic<dataType,3,4></a> >& <a class="code" href="classVABSNode__common.html#ab53b3d818bb3881738bed7b8a47c9eb2">warping</a>()<span class="keyword"> const</span>
- <a name="l00092"></a>00092 <span class="keyword"> </span>{
- <a name="l00093"></a>00093 <span class="keywordflow">return</span> warpSrc;
- <a name="l00094"></a>00094 }
- <a name="l00095"></a>00095
- <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)
- <a name="l00097"></a>00097 {
- <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>);
- <a name="l00099"></a>00099 }
- <a name="l00100"></a>00100 };
- <a name="l00101"></a>00101
- <a name="l00102"></a>00102 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><dataType>
- <a name="l00104"></a>00104 {
- <a name="l00105"></a>00105 <span class="keyword">private</span>:
- <a name="l00106"></a>00106
- <a name="l00107"></a>00107 <a class="code" href="classdataSource__Data.html">dataSource_Data<dataType></a> hSrc;
- <a name="l00108"></a>00108 <a class="code" href="classdataSource__Data.html">dataSource_Data<dataType></a> angSrc;
- <a name="l00109"></a>00109 <a class="code" href="classVABSNode__common.html">VABSNode_common<dataType></a>* common;
- <a name="l00110"></a>00110
- <a name="l00111"></a>00111 <span class="keyword">public</span>:
- <a name="l00112"></a>00112
- <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<dataType></a>* common_in=NULL) : hSrc(h_in) , angSrc(ang_in) , common(common_in)
- <a name="l00114"></a>00114 {}
- <a name="l00115"></a>00115
- <a name="l00116"></a><a class="code" href="classVABSNode__element.html#a89fa980bf57dbff7ee2b322e4e7e37a1">00116</a> <a class="code" href="classVABSNode__element.html">VABSNode_element</a>& <a class="code" href="classVABSNode__element.html#a89fa980bf57dbff7ee2b322e4e7e37a1">setH</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> h_in)
- <a name="l00117"></a>00117 {
- <a name="l00118"></a>00118 hSrc.<a class="code" href="classdataSource__Data.html#aefa4c87ef5fb27413a5f2ce1356638d7">getData</a>()=h_in;
- <a name="l00119"></a>00119 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00120"></a>00120 }
- <a name="l00121"></a>00121
- <a name="l00122"></a><a class="code" href="classVABSNode__element.html#ab65defe78f48f9e7d9eb8f41f24a86dd">00122</a> <a class="code" href="classVABSNode__element.html">VABSNode_element</a>& <a class="code" href="classVABSNode__element.html#ab65defe78f48f9e7d9eb8f41f24a86dd">setAng</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> ang_in)
- <a name="l00123"></a>00123 {
- <a name="l00124"></a>00124 angSrc.<a class="code" href="classdataSource__Data.html#aefa4c87ef5fb27413a5f2ce1356638d7">getData</a>()=ang_in;
- <a name="l00125"></a>00125 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00126"></a>00126 }
- <a name="l00127"></a>00127
- <a name="l00128"></a><a class="code" href="classVABSNode__element.html#a86c4d761fb1b24efac2356d8527f5196">00128</a> <a class="code" href="classVABSNode__element.html">VABSNode_element</a>& <a class="code" href="classVABSNode__element.html#a86c4d761fb1b24efac2356d8527f5196">setCommon</a>(<a class="code" href="classVABSNode__common.html">VABSNode_common<dataType></a>* common_in)
- <a name="l00129"></a>00129 {
- <a name="l00130"></a>00130 common=common_in;
- <a name="l00131"></a>00131 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00132"></a>00132 }
- <a name="l00133"></a>00133
- <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<dataType></a>& <a class="code" href="classVABSNode__element.html#a201c12a31d10e45f0036ecc3e7509fe4">x</a>()<span class="keyword"> const</span>
- <a name="l00135"></a>00135 <span class="keyword"> </span>{
- <a name="l00136"></a>00136 <span class="keywordflow">if</span>(common==NULL)
- <a name="l00137"></a>00137 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABSNode_element::x(): The common node data has not been set"</span>);
- <a name="l00138"></a>00138 <span class="keywordflow">return</span> common->x();
- <a name="l00139"></a>00139 }
- <a name="l00140"></a>00140
- <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<dataType></a>& <a class="code" href="classVABSNode__element.html#a5b4524069dfe5115920e9efe1aeebe13">y</a>()<span class="keyword"> const</span>
- <a name="l00142"></a>00142 <span class="keyword"> </span>{
- <a name="l00143"></a>00143 <span class="keywordflow">if</span>(common==NULL)
- <a name="l00144"></a>00144 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABSNode_element::y(): The common node data has not been set"</span>);
- <a name="l00145"></a>00145 <span class="keywordflow">return</span> common->y();
- <a name="l00146"></a>00146 }
- <a name="l00147"></a>00147
- <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<matrixStatic<dataType,3,4></a> >& <a class="code" href="classVABSNode__element.html#ad2dbcf0c1d265e3a2edcaa542e8f22c2">warping</a>()<span class="keyword"> const</span>
- <a name="l00149"></a>00149 <span class="keyword"> </span>{
- <a name="l00150"></a>00150 <span class="keywordflow">if</span>(common==NULL)
- <a name="l00151"></a>00151 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABSNode_element::warping(): The common node data has not been set"</span>);
- <a name="l00152"></a>00152 <span class="keywordflow">return</span> common->warping();
- <a name="l00153"></a>00153 }
- <a name="l00154"></a>00154
- <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<dataType></a>& <a class="code" href="classVABSNode__element.html#acfb36b6a9bdc5e5b39586adb35dc5514">h</a>()<span class="keyword"> const</span>
- <a name="l00156"></a>00156 <span class="keyword"> </span>{
- <a name="l00157"></a>00157 <span class="keywordflow">return</span> hSrc;
- <a name="l00158"></a>00158 }
- <a name="l00159"></a>00159
- <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<dataType></a>& <a class="code" href="classVABSNode__element.html#a71ba830ae4368a2d368624a48a4b0dad">plyAngle</a>()<span class="keyword"> const</span>
- <a name="l00161"></a>00161 <span class="keyword"> </span>{
- <a name="l00162"></a>00162 <span class="keywordflow">return</span> angSrc;
- <a name="l00163"></a>00163 }
- <a name="l00164"></a>00164 };
- <a name="l00165"></a>00165
- <a name="l00166"></a>00166 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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>
- <a name="l00168"></a>00168 {
- <a name="l00169"></a>00169 <span class="keyword">public</span>:
- <a name="l00170"></a>00170
- <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>()
- <a name="l00172"></a>00172 {}
- <a name="l00173"></a>00173
- <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;
- <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;
- <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;
- <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;
- <a name="l00178"></a>00178 <span class="comment">// virtual void addPsi()=0;</span>
- <a name="l00179"></a>00179 };
- <a name="l00180"></a>00180
- <a name="l00181"></a>00181 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><matrixRdWtSz_Data<dataType>,dataType>
- <a name="l00183"></a>00183 {
- <a name="l00184"></a>00184 <span class="keyword">private</span>:
- <a name="l00185"></a>00185
- <a name="l00186"></a>00186 std::vector<isoGrad2D<dataType,dataType> >* shpGrad;
- <a name="l00187"></a>00187
- <a name="l00188"></a>00188 <span class="keyword">public</span>:
- <a name="l00189"></a>00189
- <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<<a class="code" href="classisoGrad2D.html">isoGrad2D<dataType,dataType></a> >* shpGrad_in=NULL) : shpGrad(shpGrad_in)
- <a name="l00191"></a>00191 {}
- <a name="l00192"></a>00192
- <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>()
- <a name="l00194"></a>00194 {}
- <a name="l00195"></a>00195
- <a name="l00196"></a><a class="code" href="classfunction2D__Gamma__a.html#a87b84825cd3c347f8bc7681402a4b015">00196</a> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></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)
- <a name="l00197"></a>00197 {
- <a name="l00198"></a>00198 <span class="keywordflow">if</span>(shpGrad==NULL)
- <a name="l00199"></a>00199 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"function2D_Gamma_a::getValue2D(): The shape grad has not been set"</span>);
- <a name="l00200"></a>00200 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> colCnt=shpGrad->size();
- <a name="l00201"></a>00201 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> retVal(6,colCnt*3);
- <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><colCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l00203"></a>00203 {
- <a name="l00204"></a>00204 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<6;j++)
- <a name="l00205"></a>00205 {
- <a name="l00206"></a>00206 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k<3;k++)
- <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;
- <a name="l00208"></a>00208 }
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <a name="l00215"></a>00215 }
- <a name="l00216"></a>00216 <span class="keywordflow">return</span> retVal;
- <a name="l00217"></a>00217 }
- <a name="l00218"></a>00218 };
- <a name="l00219"></a>00219
- <a name="l00220"></a>00220 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><matrixRdWtStatic_Data<dataType,6,4>,dataType>
- <a name="l00222"></a>00222 {
- <a name="l00223"></a>00223 <span class="keyword">private</span>:
- <a name="l00224"></a>00224
- <a name="l00225"></a>00225 <a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* xLoc;
- <a name="l00226"></a>00226 <a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* yLoc;
- <a name="l00227"></a>00227
- <a name="l00228"></a>00228 <span class="keyword">static</span> <span class="keywordtype">bool</span> isFirst;
- <a name="l00229"></a>00229
- <a name="l00230"></a>00230 <span class="keyword">public</span>:
- <a name="l00231"></a>00231
- <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<dataType,dataType></a>* xLoc_in=NULL,<a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* yLoc_in=NULL) : xLoc(xLoc_in) , yLoc(yLoc_in)
- <a name="l00233"></a>00233 {}
- <a name="l00234"></a>00234
- <a name="l00235"></a><a class="code" href="classfunction2D__Gamma__e.html#a1fe0800dade51e4093b894ac7f30536f">00235</a> <a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data<dataType,6,4></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)
- <a name="l00236"></a>00236 {
- <a name="l00237"></a>00237 <span class="keywordflow">if</span>(xLoc==NULL || yLoc==NULL)
- <a name="l00238"></a>00238 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"function2D_Gamma_e::getValue2D(): The x and y locations have not been set"</span>);
- <a name="l00239"></a>00239 <a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data<dataType,6,4></a> retVal;
- <a name="l00240"></a>00240 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<6;j++)
- <a name="l00241"></a>00241 {
- <a name="l00242"></a>00242 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k<4;k++)
- <a name="l00243"></a>00243 retVal.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(j,k)=0.0;
- <a name="l00244"></a>00244 }
- <a name="l00245"></a>00245 retVal.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(0,0)=1.0; <span class="comment">// 11</span>
- <a name="l00246"></a>00246 retVal.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(0,2)=yLoc-><a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2); <span class="comment">// 11</span>
- <a name="l00247"></a>00247 retVal.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(0,3)=-(xLoc-><a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2)); <span class="comment">// 11</span>
- <a name="l00248"></a>00248 retVal.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(3,1)=-(yLoc-><a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2)); <span class="comment">// 12</span>
- <a name="l00249"></a>00249 retVal.<a class="code" href="classmatrix.html#a81a746378de5ff16645b2cc51189e302">entry</a>(4,1)=xLoc-><a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2); <span class="comment">// 13</span>
- <a name="l00250"></a>00250
- <a name="l00251"></a>00251 <span class="keywordflow">if</span>(isFirst)
- <a name="l00252"></a>00252 {
- <a name="l00253"></a>00253 std::cout << <span class="stringliteral">"Remember that you have to include the metric tensor into VABS for the case where there is initial curvature"</span> << std::endl;
- <a name="l00254"></a>00254 std::cout << <span class="stringliteral">"One other thing... the vabs blade does not shift the cross section to the desired origin. Just to the Xbar and Ybar"</span> << std::endl;
- <a name="l00255"></a>00255 isFirst=<span class="keyword">false</span>;
- <a name="l00256"></a>00256 }
- <a name="l00257"></a>00257
- <a name="l00258"></a>00258 <span class="keywordflow">return</span> retVal;
- <a name="l00259"></a>00259 }
- <a name="l00260"></a>00260 };
- <a name="l00261"></a>00261
- <a name="l00262"></a>00262 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <a name="l00263"></a>00263 <span class="keywordtype">bool</span> <a class="code" href="classfunction2D__Gamma__e.html">function2D_Gamma_e<dataType>::isFirst</a>=<span class="keyword">true</span>;
- <a name="l00264"></a>00264
- <a name="l00265"></a>00265 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><matrixRdWtSz_Data<dataType>,dataType>
- <a name="l00267"></a>00267 {
- <a name="l00268"></a>00268 <span class="keyword">private</span>:
- <a name="l00269"></a>00269
- <a name="l00270"></a>00270 std::vector<isoGrad2D<dataType,dataType> >* shpGrad;
- <a name="l00271"></a>00271
- <a name="l00272"></a>00272 <span class="keyword">public</span>:
- <a name="l00273"></a>00273
- <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<<a class="code" href="classisoGrad2D.html">isoGrad2D<dataType,dataType></a> >* shpGrad_in=NULL) : shpGrad(shpGrad_in)
- <a name="l00275"></a>00275 {}
- <a name="l00276"></a>00276
- <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>()
- <a name="l00278"></a>00278 {}
- <a name="l00279"></a>00279
- <a name="l00280"></a><a class="code" href="classfunction2D__ShapeDiag.html#a332be29feaa9b2b691036da939c2eb43">00280</a> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></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)
- <a name="l00281"></a>00281 {
- <a name="l00282"></a>00282 <span class="keywordflow">if</span>(shpGrad==NULL)
- <a name="l00283"></a>00283 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"function2D_ShapeDiag::getValue2D(): The shape grad has not been set"</span>);
- <a name="l00284"></a>00284 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> colCnt=shpGrad->size();
- <a name="l00285"></a>00285 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> retVal(3,colCnt*3);
- <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><colCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l00287"></a>00287 {
- <a name="l00288"></a>00288 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<3;j++)
- <a name="l00289"></a>00289 {
- <a name="l00290"></a>00290 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k<3;k++)
- <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;
- <a name="l00292"></a>00292 }
- <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);
- <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);
- <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);
- <a name="l00296"></a>00296 }
- <a name="l00297"></a>00297
- <a name="l00298"></a>00298 <span class="keywordflow">return</span> retVal;
- <a name="l00299"></a>00299 }
- <a name="l00300"></a>00300 };
- <a name="l00301"></a>00301
- <a name="l00302"></a>00302 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><matrixRdWtSz_Data<dataType>,dataType>
- <a name="l00304"></a>00304 {
- <a name="l00305"></a>00305 <span class="keyword">private</span>:
- <a name="l00306"></a>00306
- <a name="l00307"></a>00307 <a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* xFunc;
- <a name="l00308"></a>00308 <a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* yFunc;
- <a name="l00309"></a>00309 <span class="keywordtype">bool</span> deleteX;
- <a name="l00310"></a>00310 <span class="keywordtype">bool</span> deleteY;
- <a name="l00311"></a>00311
- <a name="l00312"></a>00312 <span class="keyword">public</span>:
- <a name="l00313"></a>00313
- <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>(
- <a name="l00315"></a>00315 <a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* xFunc_in=NULL
- <a name="l00316"></a>00316 , <a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* yFunc_in=NULL
- <a name="l00317"></a>00317 , <span class="keywordtype">bool</span> deleteX_in=<span class="keyword">false</span>
- <a name="l00318"></a>00318 , <span class="keywordtype">bool</span> deleteY_in=<span class="keyword">false</span>
- <a name="l00319"></a>00319 )
- <a name="l00320"></a>00320 : xFunc(xFunc_in)
- <a name="l00321"></a>00321 , yFunc(yFunc_in)
- <a name="l00322"></a>00322 , deleteX(deleteX_in)
- <a name="l00323"></a>00323 , deleteY(deleteY_in)
- <a name="l00324"></a>00324 {}
- <a name="l00325"></a>00325
- <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>()
- <a name="l00327"></a>00327 {
- <a name="l00328"></a>00328 <span class="keywordflow">if</span>(deleteX && xFunc!=NULL)
- <a name="l00329"></a>00329 <span class="keyword">delete</span> xFunc;
- <a name="l00330"></a>00330 <span class="keywordflow">if</span>(deleteY && yFunc!=NULL)
- <a name="l00331"></a>00331 <span class="keyword">delete</span> yFunc;
- <a name="l00332"></a>00332 }
- <a name="l00333"></a>00333
- <a name="l00334"></a><a class="code" href="classfunction2D__vabsNull.html#a842b1f91ef7d5ed7c17eaadfb6de2400">00334</a> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></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)
- <a name="l00335"></a>00335 {
- <a name="l00336"></a>00336 <span class="keywordflow">if</span>(xFunc==NULL)
- <a name="l00337"></a>00337 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"function2D_vabsNull::getValue2D(): The x function has not been specified"</span>);
- <a name="l00338"></a>00338 <span class="keywordflow">if</span>(yFunc==NULL)
- <a name="l00339"></a>00339 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"function2D_vabsNull::getValue2D(): The y function has not been specified"</span>);
- <a name="l00340"></a>00340
- <a name="l00341"></a>00341 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> retVal=<a class="code" href="classmatrixStatic__Zero.html">matrixStatic_Zero<dataType,3,4></a>();
- <a name="l00342"></a>00342
- <a name="l00343"></a>00343 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> x=xFunc-><a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2);
- <a name="l00344"></a>00344 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> y=yFunc-><a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2);
- <a name="l00345"></a>00345
- <a name="l00346"></a>00346 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(0,0)=1.0;
- <a name="l00347"></a>00347 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(1,1)=1.0;
- <a name="l00348"></a>00348 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(2,2)=1.0;
- <a name="l00349"></a>00349 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(1,3)=y;
- <a name="l00350"></a>00350 retVal.<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(2,3)=-x;
- <a name="l00351"></a>00351
- <a name="l00352"></a>00352 <span class="keywordflow">return</span> retVal;
- <a name="l00353"></a>00353 }
- <a name="l00354"></a>00354 };
- <a name="l00355"></a>00355
- <a name="l00356"></a>00356 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><matrixRdWtStaticSqr_Data<dataType,6>,dataType>
- <a name="l00358"></a>00358 {
- <a name="l00359"></a>00359 <span class="keyword">private</span>:
- <a name="l00360"></a>00360
- <a name="l00361"></a>00361 <a class="code" href="classconstituitive.html">constituitive<dataType></a>* matl;
- <a name="l00362"></a>00362 <a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* hFunc;
- <a name="l00363"></a>00363 <a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* angFunc;
- <a name="l00364"></a>00364
- <a name="l00365"></a>00365 <span class="keyword">public</span>:
- <a name="l00366"></a>00366
- <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<dataType></a>* matl_in=NULL,<a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* hFunc_in=NULL,<a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* angFunc_in=NULL) : matl(matl_in) , hFunc(hFunc_in) , angFunc(angFunc_in)
- <a name="l00368"></a>00368 {}
- <a name="l00369"></a>00369
- <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>()
- <a name="l00371"></a>00371 {}
- <a name="l00372"></a>00372
- <a name="l00373"></a><a class="code" href="classfunction2D__matl.html#ae409771e5bd75a596d5ec2343116e2e4">00373</a> <a class="code" href="classfunction2D__matl.html">function2D_matl</a>& <a class="code" href="classfunction2D__matl.html#ae409771e5bd75a596d5ec2343116e2e4">setMaterial</a>(<a class="code" href="classconstituitive.html">constituitive<dataType></a>* matl_in)
- <a name="l00374"></a>00374 {
- <a name="l00375"></a>00375 matl=matl_in;
- <a name="l00376"></a>00376 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00377"></a>00377 }
- <a name="l00378"></a>00378
- <a name="l00379"></a><a class="code" href="classfunction2D__matl.html#af3e5d719633e70253a5b624318c7a19c">00379</a> <a class="code" href="classfunction2D__matl.html">function2D_matl</a>& <a class="code" href="classfunction2D__matl.html#af3e5d719633e70253a5b624318c7a19c">setHFunc</a>(<a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* hFunc_in)
- <a name="l00380"></a>00380 {
- <a name="l00381"></a>00381 hFunc=hFunc_in;
- <a name="l00382"></a>00382 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00383"></a>00383 }
- <a name="l00384"></a>00384
- <a name="l00385"></a><a class="code" href="classfunction2D__matl.html#aad1ec0748e2bc534b5a98825f5df2465">00385</a> <a class="code" href="classfunction2D__matl.html">function2D_matl</a>& <a class="code" href="classfunction2D__matl.html#aad1ec0748e2bc534b5a98825f5df2465">setAngleFunc</a>(<a class="code" href="classfunction2D.html">function2D<dataType,dataType></a>* angFunc_in)
- <a name="l00386"></a>00386 {
- <a name="l00387"></a>00387 angFunc=angFunc_in;
- <a name="l00388"></a>00388 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00389"></a>00389 }
- <a name="l00390"></a>00390
- <a name="l00391"></a><a class="code" href="classfunction2D__matl.html#a958969e2595caddf27c440c20a3eb488">00391</a> <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,6></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)
- <a name="l00392"></a>00392 {
- <a name="l00393"></a>00393 <span class="keywordflow">if</span>(matl==NULL || hFunc==NULL || angFunc==NULL)
- <a name="l00394"></a>00394 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"function2D_matl::getValue2D(): The dependent data has not been set"</span>);
- <a name="l00395"></a>00395 <span class="keywordflow">return</span> matl->matlMatrix(<a class="code" href="classconstituitiveDependent.html">constituitiveDependent<dataType></a>(angFunc-><a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2),hFunc-><a class="code" href="classfunction2D.html#ac48703a8b417ebe6ae34233ee4d81638">getValue2D</a>(at1,at2)));
- <a name="l00396"></a>00396 }
- <a name="l00397"></a>00397 };
- <a name="l00398"></a>00398
- <a name="l00399"></a>00399 <span class="comment">// this class is the post processing interface for the vabs elements</span>
- <a name="l00400"></a>00400 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> strainType>
- <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>
- <a name="l00402"></a>00402 {
- <a name="l00403"></a>00403 <span class="keyword">public</span>:
- <a name="l00404"></a>00404
- <a name="l00405"></a><a class="code" href="classVABSElementInfo.html#a579a5baf15ad22905e942a550d5f7b51">00405</a> <a class="code" href="classVABSElementInfo.html#a579a5baf15ad22905e942a550d5f7b51">VABSElementInfo</a>()
- <a name="l00406"></a>00406 {}
- <a name="l00407"></a>00407
- <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>()
- <a name="l00409"></a>00409 {}
- <a name="l00410"></a>00410
- <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& beamStrain)=0;
- <a name="l00412"></a>00412 };
- <a name="l00413"></a>00413
- <a name="l00414"></a>00414 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> strainType>
- <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><dataType,strainType>
- <a name="l00416"></a>00416 {
- <a name="l00417"></a>00417 <span class="keyword">private</span>:
- <a name="l00418"></a>00418
- <a name="l00419"></a>00419 <a class="code" href="classVABSElementInfo.html">VABSElementInfo<dataType,strainType></a>* pElm;
- <a name="l00420"></a>00420 <span class="keywordtype">bool</span> canDelete;
- <a name="l00421"></a>00421
- <a name="l00422"></a>00422 <span class="keyword">public</span>:
- <a name="l00423"></a>00423
- <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<dataType,strainType></a>* pElm_in=NULL,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : pElm(pElm_in) , canDelete(canDelete_in)
- <a name="l00425"></a>00425 {}
- <a name="l00426"></a>00426
- <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<dataType,strainType></a>& asg) : pElm(asg.pElm) , canDelete(asg.canDelete)
- <a name="l00428"></a>00428 {}
- <a name="l00429"></a>00429
- <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>()
- <a name="l00431"></a>00431 {
- <a name="l00432"></a>00432 <span class="keywordflow">if</span>(canDelete && pElm!=NULL)
- <a name="l00433"></a>00433 <span class="keyword">delete</span> pElm;
- <a name="l00434"></a>00434 }
- <a name="l00435"></a>00435
- <a name="l00436"></a><a class="code" href="classVABSElementInfo__Pntr.html#a35bf0e1211d31585e1bb90e582174638">00436</a> <a class="code" href="classVABSElementInfo__Pntr.html">VABSElementInfo_Pntr<dataType,strainType></a>& <a class="code" href="classVABSElementInfo__Pntr.html#a35bf0e1211d31585e1bb90e582174638">operator=</a>(<span class="keyword">const</span> <a class="code" href="classVABSElementInfo__Pntr.html">VABSElementInfo_Pntr<dataType,strainType></a>& asg)
- <a name="l00437"></a>00437 {
- <a name="l00438"></a>00438 <span class="keywordflow">return</span> this-><a class="code" href="classVABSElementInfo__Pntr.html#a249372b252360cda83e9f78281a9fe2b">setPointer</a>(asg.pElm);
- <a name="l00439"></a>00439 }
- <a name="l00440"></a>00440
- <a name="l00441"></a><a class="code" href="classVABSElementInfo__Pntr.html#a249372b252360cda83e9f78281a9fe2b">00441</a> <a class="code" href="classVABSElementInfo__Pntr.html">VABSElementInfo_Pntr<dataType,strainType></a>& <a class="code" href="classVABSElementInfo__Pntr.html#a249372b252360cda83e9f78281a9fe2b">setPointer</a>(<a class="code" href="classVABSElementInfo.html">VABSElementInfo<dataType,strainType></a>* pElm_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
- <a name="l00442"></a>00442 {
- <a name="l00443"></a>00443 <span class="keywordflow">if</span>(canDelete && pElm!=NULL && pElm_in!=pElm)
- <a name="l00444"></a>00444 <span class="keyword">delete</span> pElm;
- <a name="l00445"></a>00445
- <a name="l00446"></a>00446 pElm=pElm_in;
- <a name="l00447"></a>00447 canDelete=canDelete_in;
- <a name="l00448"></a>00448
- <a name="l00449"></a>00449 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00450"></a>00450 }
- <a name="l00451"></a>00451
- <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& beamStrain)
- <a name="l00453"></a>00453 {
- <a name="l00454"></a>00454 <span class="keywordflow">if</span>(pElm==NULL)
- <a name="l00455"></a>00455 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABSElementInfo_Pntr::fail(): The pointer has not been set"</span>);
- <a name="l00456"></a>00456
- <a name="l00457"></a>00457 <span class="keywordflow">return</span> pElm->fail(s,t,beamStrain);
- <a name="l00458"></a>00458 }
- <a name="l00459"></a>00459 };
- <a name="l00460"></a>00460
- <a name="l00461"></a>00461 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><dataType> , <span class="keyword">public</span> <a class="code" href="classVABSElementInfo.html">VABSElementInfo</a><dataType,matrixStaticVectCol<dataType,4> >
- <a name="l00463"></a>00463 {
- <a name="l00464"></a>00464
- <a name="l00465"></a>00465 <span class="comment">// template<class altType> friend class VABS1_Model_Base; // Debug</span>
- <a name="l00466"></a>00466
- <a name="l00467"></a>00467 <span class="keyword">private</span>:
- <a name="l00468"></a>00468
- <a name="l00470"></a>00470 <span class="comment">// these are the state data objects</span>
- <a name="l00472"></a>00472 <span class="comment"></span>
- <a name="l00473"></a>00473 <span class="comment">// these are the only externally supplied objects</span>
- <a name="l00474"></a>00474 std::vector<VABSNode<dataType>* > nds;
- <a name="l00475"></a>00475 <a class="code" href="classconstituitive.html">constituitive<dataType></a>* matl;
- <a name="l00476"></a>00476 <span class="keywordtype">bool</span> objectsSet;
- <a name="l00477"></a>00477
- <a name="l00479"></a>00479 <span class="comment">// these are the internally created objects</span>
- <a name="l00481"></a>00481 <span class="comment"></span>
- <a name="l00482"></a>00482 <span class="comment">// These are the domain objects</span>
- <a name="l00483"></a>00483 std::vector<function_Lagrange<dataType> > shp1D;
- <a name="l00484"></a>00484 std::vector<function2DD1_product1D<dataType,dataType> > shp2D;
- <a name="l00485"></a>00485 std::vector<isoGrad2D<dataType,dataType> > shpGrad;
- <a name="l00486"></a>00486 <a class="code" href="classisoFunction2D.html">isoFunction2D<dataType,dataType></a> xFunc;
- <a name="l00487"></a>00487 <a class="code" href="classisoFunction2D.html">isoFunction2D<dataType,dataType></a> yFunc;
- <a name="l00488"></a>00488 <a class="code" href="classfunction2D__jacobian.html">function2D_jacobian<dataType></a> jac2D;
- <a name="l00489"></a>00489 <a class="code" href="classnested2D.html">nested2D<dataType,dataType></a> innerJac;
- <a name="l00490"></a>00490 <a class="code" href="classfunction__constant.html">function_constant<dataType,dataType></a> outerJac;
- <a name="l00491"></a>00491
- <a name="l00492"></a>00492 <span class="comment">// These are the material objects</span>
- <a name="l00493"></a>00493 <a class="code" href="classisoFunction2D.html">isoFunction2D<dataType,dataType></a> hFunc;
- <a name="l00494"></a>00494 <a class="code" href="classisoFunction2D.html">isoFunction2D<dataType,dataType></a> angFunc;
- <a name="l00495"></a>00495 <a class="code" href="classfunction2D__matl.html">function2D_matl<dataType></a> matlFunc;
- <a name="l00496"></a>00496
- <a name="l00497"></a>00497 <span class="comment">// important shape and Gamma matrices</span>
- <a name="l00498"></a>00498 <a class="code" href="classfunction2D__Gamma__a.html">function2D_Gamma_a<dataType></a> Gamma_a;
- <a name="l00499"></a>00499 <a class="code" href="classfunction2D__Gamma__e.html">function2D_Gamma_e<dataType></a> Gamma_e;
- <a name="l00500"></a>00500 <a class="code" href="classfunction2D__ShapeDiag.html">function2D_ShapeDiag<dataType></a> shapeDiag;
- <a name="l00501"></a>00501 <span class="comment">// function2D_vabsNull<dataType> vabsNull;</span>
- <a name="l00502"></a>00502
- <a name="l00503"></a>00503 <span class="comment">// e matrix objects</span>
- <a name="l00504"></a>00504 <a class="code" href="classfunction2D__tripleProduct.html">function2D_tripleProduct<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,6></a> > pointEMatrix;
- <a name="l00505"></a>00505 <a class="code" href="classnested2D.html">nested2D<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> innerFuncEMatrix;
- <a name="l00506"></a>00506 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> innerEMatrixInt;
- <a name="l00507"></a>00507 <a class="code" href="classintegralFunction.html">integralFunction<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> outerFuncEMatrix;
- <a name="l00508"></a>00508 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> outerEMatrixInt;
- <a name="l00509"></a>00509
- <a name="l00510"></a>00510 <span class="comment">// these are the objects for Dae</span>
- <a name="l00511"></a>00511 <a class="code" href="classfunction2D__tripleProduct.html">function2D_tripleProduct<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,6></a>,<a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data<dataType,6,4></a> > pointDaeMatrix;
- <a name="l00512"></a>00512 <a class="code" href="classnested2D.html">nested2D<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> innerFuncDaeMatrix;
- <a name="l00513"></a>00513 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> innerDaeMatrixInt;
- <a name="l00514"></a>00514 <a class="code" href="classintegralFunction.html">integralFunction<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> outerFuncDaeMatrix;
- <a name="l00515"></a>00515 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> outerDaeMatrixInt;
- <a name="l00516"></a>00516
- <a name="l00517"></a>00517 <span class="comment">// these are the objects for Dee</span>
- <a name="l00518"></a>00518 <a class="code" href="classfunction2D__tripleProduct.html">function2D_tripleProduct<matrixRdWtStaticSqr_Data<dataType,4></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data<dataType,6,4></a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,6></a> > pointDeeMatrix;
- <a name="l00519"></a>00519 <a class="code" href="classnested2D.html">nested2D<matrixRdWtStaticSqr_Data<dataType,4></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> innerFuncDeeMatrix;
- <a name="l00520"></a>00520 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss<matrixRdWtStaticSqr_Data<dataType,4></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> innerDeeMatrixInt;
- <a name="l00521"></a>00521 <a class="code" href="classintegralFunction.html">integralFunction<matrixRdWtStaticSqr_Data<dataType,4></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> outerFuncDeeMatrix;
- <a name="l00522"></a>00522 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss<matrixRdWtStaticSqr_Data<dataType,4></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> outerDeeMatrixInt;
- <a name="l00523"></a>00523
- <a name="l00524"></a>00524 <span class="comment">// these are the objects for H</span>
- <a name="l00525"></a>00525 <a class="code" href="classfunction2D__doubleProduct.html">function2D_doubleProduct<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> > pointHMatrix;
- <a name="l00526"></a>00526 <a class="code" href="classnested2D.html">nested2D<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> innerFuncHMatrix;
- <a name="l00527"></a>00527 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> innerHMatrixInt;
- <a name="l00528"></a>00528 <a class="code" href="classintegralFunction.html">integralFunction<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> outerFuncHMatrix;
- <a name="l00529"></a>00529 <a class="code" href="classisoIntegral__gauss.html">isoIntegral_gauss<matrixRdWtSz_Data<dataType></a>,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> outerHMatrixInt;
- <a name="l00530"></a>00530
- <a name="l00531"></a>00531 <span class="comment">// these are the objects for Psi</span>
- <a name="l00532"></a>00532 <span class="comment">// function2D_doubleProduct<matrixRdWtSz_Data<dataType>,dataType,matrixRdWtSz_Data<dataType> > pointPsiMatrix;</span>
- <a name="l00533"></a>00533 <span class="comment">// nested2D<matrixRdWtSz_Data<dataType>,dataType> innerFuncPsiMatrix;</span>
- <a name="l00534"></a>00534 <span class="comment">// isoIntegral_gauss<matrixRdWtSz_Data<dataType>,dataType> innerPsiMatrixInt;</span>
- <a name="l00535"></a>00535 <span class="comment">// integralFunction<matrixRdWtSz_Data<dataType>,dataType> outerFuncPsiMatrix;</span>
- <a name="l00536"></a>00536 <span class="comment">// isoIntegral_gauss<matrixRdWtSz_Data<dataType>,dataType> outerPsiMatrixInt;</span>
- <a name="l00537"></a>00537
- <a name="l00538"></a>00538 <span class="comment">// these are the objects for shape function integral</span>
- <a name="l00539"></a>00539 <span class="comment">// nested2D<matrixRdWtSz_Data<dataType>,dataType> innerFuncShape;</span>
- <a name="l00540"></a>00540 <span class="comment">// isoIntegral_gauss<matrixRdWtSz_Data<dataType>,dataType> innerShapeInt;</span>
- <a name="l00541"></a>00541 <span class="comment">// integralFunction<matrixRdWtSz_Data<dataType>,dataType> outerFuncShape;</span>
- <a name="l00542"></a>00542 <span class="comment">// isoIntegral_gauss<matrixRdWtSz_Data<dataType>,dataType> outerShapeInt;</span>
- <a name="l00543"></a>00543
- <a name="l00545"></a>00545 <span class="comment">// these are the output objects</span>
- <a name="l00547"></a>00547 <span class="comment"></span>
- <a name="l00548"></a>00548 <a class="code" href="classmatrixRdWt.html">matrixRdWt<dataType></a>* EMatrix;
- <a name="l00549"></a>00549 <a class="code" href="classmatrixRdWt.html">matrixRdWt<dataType></a>* DaeMatrix;
- <a name="l00550"></a>00550 <a class="code" href="classmatrixRdWt.html">matrixRdWt<dataType></a>* DeeMatrix;
- <a name="l00551"></a>00551 <a class="code" href="classmatrixRdWt.html">matrixRdWt<dataType></a>* HMatrix;
- <a name="l00552"></a>00552 <span class="comment">// matrixRdWt<dataType>* PsiMatrix;</span>
- <a name="l00553"></a>00553
- <a name="l00554"></a>00554 <span class="keywordtype">bool</span> deleteEMatrix;
- <a name="l00555"></a>00555 <span class="keywordtype">bool</span> deleteDaeMatrix;
- <a name="l00556"></a>00556 <span class="keywordtype">bool</span> deleteDeeMatrix;
- <a name="l00557"></a>00557 <span class="keywordtype">bool</span> deleteHMatrix;
- <a name="l00558"></a>00558 <span class="comment">// bool deletePsiMatrix;</span>
- <a name="l00559"></a>00559
- <a name="l00561"></a>00561 <span class="comment">// these are the post-processing objects</span>
- <a name="l00563"></a>00563 <span class="comment"></span>
- <a name="l00564"></a>00564 <span class="comment">// isoFunction2D<matrixRdWtStatic_Data<dataType,3,4>,dataType,matrixStatic<dataType,3,4> > warpFunc;</span>
- <a name="l00565"></a>00565
- <a name="l00566"></a>00566 <span class="keywordtype">void</span> buildObjects()
- <a name="l00567"></a>00567 {
- <a name="l00568"></a>00568 <span class="comment">// set the points for the location function</span>
- <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><4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l00570"></a>00570 {
- <a name="l00571"></a>00571 xFunc.<a class="code" href="classisoFunction2D.html#a8b9cb87d6fb5306d1e0350a243dcf3a1">addPoint</a>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>,&shp2D[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>],&(nds[i]->x()));
- <a name="l00572"></a>00572 yFunc.<a class="code" href="classisoFunction2D.html#a8b9cb87d6fb5306d1e0350a243dcf3a1">addPoint</a>(i,&shp2D[i],&(nds[i]->y()));
- <a name="l00573"></a>00573 hFunc.<a class="code" href="classisoFunction2D.html#a8b9cb87d6fb5306d1e0350a243dcf3a1">addPoint</a>(i,&shp2D[i],&(nds[i]->h()));
- <a name="l00574"></a>00574 angFunc.<a class="code" href="classisoFunction2D.html#a8b9cb87d6fb5306d1e0350a243dcf3a1">addPoint</a>(i,&shp2D[i],&(nds[i]->plyAngle()));
- <a name="l00575"></a>00575 <span class="comment">// warpFunc.addPoint(i,&shp2D[i],&(nds[i]->warping()));</span>
- <a name="l00576"></a>00576 shpGrad[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setSource(&shp2D[i],&xFunc,&yFunc);
- <a name="l00577"></a>00577 }
- <a name="l00578"></a>00578 objectsSet=<span class="keyword">true</span>;
- <a name="l00579"></a>00579 outerFuncEMatrix.<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&innerFuncEMatrix).<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&innerJac);
- <a name="l00580"></a>00580 outerFuncDaeMatrix.<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&innerFuncDaeMatrix).<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&innerJac);
- <a name="l00581"></a>00581 outerFuncDeeMatrix.<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&innerFuncDeeMatrix).<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&innerJac);
- <a name="l00582"></a>00582 outerFuncHMatrix.<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&innerFuncHMatrix).<a class="code" href="classintegralFunction.html#a28621d22cd1a1a5e5ec14032ae3ca96f">addFunction</a>(&innerJac);
- <a name="l00583"></a>00583 <span class="comment">// outerFuncPsiMatrix.addFunction(&innerFuncPsiMatrix).addFunction(&innerJac);</span>
- <a name="l00584"></a>00584 <span class="comment">// outerFuncShape.addFunction(&innerFuncShape).addFunction(&innerJac);</span>
- <a name="l00585"></a>00585 }
- <a name="l00586"></a>00586
- <a name="l00587"></a>00587 <span class="keyword">public</span>:
- <a name="l00588"></a>00588
- <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<dataType></a>* matl_in=NULL) :
- <a name="l00590"></a>00590 <span class="comment">// state data</span>
- <a name="l00591"></a>00591 nds(4,NULL) , matl(matl_in) , objectsSet(false)
- <a name="l00592"></a>00592 <span class="comment">// domain objects</span>
- <a name="l00593"></a>00593 , shp1D(2) , shp2D(4) , shpGrad(4) , xFunc(4) , yFunc(4) , jac2D(&xFunc,&yFunc) , innerJac(&jac2D) , outerJac(1.0)
- <a name="l00594"></a>00594 <span class="comment">// material objects</span>
- <a name="l00595"></a>00595 , hFunc(4) , angFunc(4) , matlFunc(matl_in,&hFunc,&angFunc)
- <a name="l00596"></a>00596 <span class="comment">// These are the Gamma and Shape matrices</span>
- <a name="l00597"></a>00597 , Gamma_a(&shpGrad) , Gamma_e(&xFunc,&yFunc) , shapeDiag(&shpGrad) <span class="comment">// , vabsNull(&xFunc,&yFunc)</span>
- <a name="l00598"></a>00598 <span class="comment">// E matrix objects</span>
- <a name="l00599"></a>00599 , pointEMatrix(&Gamma_a,&matlFunc,&Gamma_a)
- <a name="l00600"></a>00600 , innerFuncEMatrix(&pointEMatrix) , innerEMatrixInt(&innerFuncEMatrix,&innerJac,2)
- <a name="l00601"></a>00601 , outerFuncEMatrix(&innerEMatrixInt) , outerEMatrixInt(&outerFuncEMatrix,&outerJac,2)
- <a name="l00602"></a>00602 <span class="comment">// Dae matrix objects</span>
- <a name="l00603"></a>00603 , pointDaeMatrix(&Gamma_a,&matlFunc,&Gamma_e)
- <a name="l00604"></a>00604 , innerFuncDaeMatrix(&pointDaeMatrix) , innerDaeMatrixInt(&innerFuncDaeMatrix,&innerJac,2)
- <a name="l00605"></a>00605 , outerFuncDaeMatrix(&innerDaeMatrixInt) , outerDaeMatrixInt(&outerFuncDaeMatrix,&outerJac,2)
- <a name="l00606"></a>00606 <span class="comment">// Dee matrix objects</span>
- <a name="l00607"></a>00607 , pointDeeMatrix(&Gamma_e,&matlFunc,&Gamma_e)
- <a name="l00608"></a>00608 , innerFuncDeeMatrix(&pointDeeMatrix) , innerDeeMatrixInt(&innerFuncDeeMatrix,&innerJac,2)
- <a name="l00609"></a>00609 , outerFuncDeeMatrix(&innerDeeMatrixInt) , outerDeeMatrixInt(&outerFuncDeeMatrix,&outerJac,2)
- <a name="l00610"></a>00610 <span class="comment">// H matrix objects</span>
- <a name="l00611"></a>00611 , pointHMatrix(&shapeDiag,&shapeDiag)
- <a name="l00612"></a>00612 , innerFuncHMatrix(&pointHMatrix) , innerHMatrixInt(&innerFuncHMatrix,&innerJac,2)
- <a name="l00613"></a>00613 , outerFuncHMatrix(&innerHMatrixInt) , outerHMatrixInt(&outerFuncHMatrix,&outerJac,2)
- <a name="l00614"></a>00614 <span class="comment">// // Psi matrix objects</span>
- <a name="l00615"></a>00615 <span class="comment">// , pointPsiMatrix(&shapeDiag,&vabsNull)</span>
- <a name="l00616"></a>00616 <span class="comment">// , innerFuncPsiMatrix(&pointPsiMatrix) , innerPsiMatrixInt(&innerFuncPsiMatrix,&innerJac,2)</span>
- <a name="l00617"></a>00617 <span class="comment">// , outerFuncPsiMatrix(&innerPsiMatrixInt) , outerPsiMatrixInt(&outerFuncPsiMatrix,&outerJac,2)</span>
- <a name="l00618"></a>00618 <span class="comment">// These are the output variables</span>
- <a name="l00619"></a>00619 , EMatrix(NULL) , DaeMatrix(NULL) , DeeMatrix(NULL) , HMatrix(NULL) <span class="comment">// , PsiMatrix(NULL)</span>
- <a name="l00620"></a>00620 , deleteEMatrix(false) , deleteDaeMatrix(false) , deleteDeeMatrix(false) , deleteHMatrix(false) <span class="comment">// , deletePsiMatrix(false)</span>
- <a name="l00621"></a>00621 {
- <a name="l00622"></a>00622 std::vector<dataType> locs(2,0.0);
- <a name="l00623"></a>00623 locs[0]=-1.0;
- <a name="l00624"></a>00624 locs[1]=1.0;
- <a name="l00625"></a>00625 shp1D[0].setCoeff(0,locs);
- <a name="l00626"></a>00626 shp1D[1].setCoeff(1,locs);
- <a name="l00627"></a>00627 shp2D[0].setLeft(&shp1D[0]).setRight(&shp1D[0]);
- <a name="l00628"></a>00628 shp2D[1].setLeft(&shp1D[1]).setRight(&shp1D[0]);
- <a name="l00629"></a>00629 shp2D[2].setLeft(&shp1D[1]).setRight(&shp1D[1]);
- <a name="l00630"></a>00630 shp2D[3].setLeft(&shp1D[0]).setRight(&shp1D[1]);
- <a name="l00631"></a>00631 }
- <a name="l00632"></a>00632
- <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>& asg) :
- <a name="l00634"></a>00634 <span class="comment">// state data</span>
- <a name="l00635"></a>00635 nds(4,NULL) , matl(asg.matl) , objectsSet(false)
- <a name="l00636"></a>00636 <span class="comment">// domain objects</span>
- <a name="l00637"></a>00637 , shp1D(2) , shp2D(4) , shpGrad(4) , xFunc(4) , yFunc(4) , jac2D(&xFunc,&yFunc) , innerJac(&jac2D) , outerJac(1.0)
- <a name="l00638"></a>00638 <span class="comment">// material objects</span>
- <a name="l00639"></a>00639 , hFunc(4) , angFunc(4) , matlFunc(matl,&hFunc,&angFunc)
- <a name="l00640"></a>00640 <span class="comment">// These are the Gamma and Shape matrices</span>
- <a name="l00641"></a>00641 , Gamma_a(&shpGrad) , Gamma_e(&xFunc,&yFunc) , shapeDiag(&shpGrad) <span class="comment">// , vabsNull(&xFunc,&yFunc)</span>
- <a name="l00642"></a>00642 <span class="comment">// E matrix objects</span>
- <a name="l00643"></a>00643 , pointEMatrix(&Gamma_a,&matlFunc,&Gamma_a)
- <a name="l00644"></a>00644 , innerFuncEMatrix(&pointEMatrix) , innerEMatrixInt(&innerFuncEMatrix,&innerJac,2)
- <a name="l00645"></a>00645 , outerFuncEMatrix(&innerEMatrixInt) , outerEMatrixInt(&outerFuncEMatrix,&outerJac,2)
- <a name="l00646"></a>00646 <span class="comment">// Dae matrix objects</span>
- <a name="l00647"></a>00647 , pointDaeMatrix(&Gamma_a,&matlFunc,&Gamma_e)
- <a name="l00648"></a>00648 , innerFuncDaeMatrix(&pointDaeMatrix) , innerDaeMatrixInt(&innerFuncDaeMatrix,&innerJac,2)
- <a name="l00649"></a>00649 , outerFuncDaeMatrix(&innerDaeMatrixInt) , outerDaeMatrixInt(&outerFuncDaeMatrix,&outerJac,2)
- <a name="l00650"></a>00650 <span class="comment">// Dee matrix objects</span>
- <a name="l00651"></a>00651 , pointDeeMatrix(&Gamma_e,&matlFunc,&Gamma_e)
- <a name="l00652"></a>00652 , innerFuncDeeMatrix(&pointDeeMatrix) , innerDeeMatrixInt(&innerFuncDeeMatrix,&innerJac,2)
- <a name="l00653"></a>00653 , outerFuncDeeMatrix(&innerDeeMatrixInt) , outerDeeMatrixInt(&outerFuncDeeMatrix,&outerJac,2)
- <a name="l00654"></a>00654 <span class="comment">// H matrix objects</span>
- <a name="l00655"></a>00655 , pointHMatrix(&shapeDiag,&shapeDiag)
- <a name="l00656"></a>00656 , innerFuncHMatrix(&pointHMatrix) , innerHMatrixInt(&innerFuncHMatrix,&innerJac,2)
- <a name="l00657"></a>00657 , outerFuncHMatrix(&innerHMatrixInt) , outerHMatrixInt(&outerFuncHMatrix,&outerJac,2)
- <a name="l00658"></a>00658 <span class="comment">// // Psi matrix objects</span>
- <a name="l00659"></a>00659 <span class="comment">// , pointPsiMatrix(&shapeDiag,&vabsNull)</span>
- <a name="l00660"></a>00660 <span class="comment">// , innerFuncPsiMatrix(&pointPsiMatrix) , innerPsiMatrixInt(&innerFuncPsiMatrix,&innerJac,2)</span>
- <a name="l00661"></a>00661 <span class="comment">// , outerFuncPsiMatrix(&innerPsiMatrixInt) , outerPsiMatrixInt(&outerFuncPsiMatrix,&outerJac,2)</span>
- <a name="l00662"></a>00662 <span class="comment">// These are the output variables</span>
- <a name="l00663"></a>00663 , EMatrix(NULL) , DaeMatrix(NULL) , DeeMatrix(NULL) , HMatrix(NULL) <span class="comment">// , PsiMatrix(NULL)</span>
- <a name="l00664"></a>00664 , deleteEMatrix(false) , deleteDaeMatrix(false) , deleteDeeMatrix(false) , deleteHMatrix(false) <span class="comment">// , deletePsiMatrix(false)</span>
- <a name="l00665"></a>00665 <span class="comment">// now lets initialize the interpolation of the warping</span>
- <a name="l00666"></a>00666 <span class="comment">// , warpFunc(4)</span>
- <a name="l00667"></a>00667 {
- <a name="l00668"></a>00668 std::vector<dataType> locs(2,0.0);
- <a name="l00669"></a>00669 locs[0]=-1.0;
- <a name="l00670"></a>00670 locs[1]=1.0;
- <a name="l00671"></a>00671 shp1D[0].setCoeff(0,locs);
- <a name="l00672"></a>00672 shp1D[1].setCoeff(1,locs);
- <a name="l00673"></a>00673 shp2D[0].setLeft(&shp1D[0]).setRight(&shp1D[0]);
- <a name="l00674"></a>00674 shp2D[1].setLeft(&shp1D[1]).setRight(&shp1D[0]);
- <a name="l00675"></a>00675 shp2D[2].setLeft(&shp1D[1]).setRight(&shp1D[1]);
- <a name="l00676"></a>00676 shp2D[3].setLeft(&shp1D[0]).setRight(&shp1D[1]);
- <a name="l00677"></a>00677 }
- <a name="l00678"></a>00678
- <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>()
- <a name="l00680"></a>00680 {
- <a name="l00681"></a>00681 <span class="keywordflow">if</span>(EMatrix!=NULL && deleteEMatrix)
- <a name="l00682"></a>00682 <span class="keyword">delete</span> EMatrix;
- <a name="l00683"></a>00683 <span class="keywordflow">if</span>(DaeMatrix!=NULL && deleteDaeMatrix)
- <a name="l00684"></a>00684 <span class="keyword">delete</span> DaeMatrix;
- <a name="l00685"></a>00685 <span class="keywordflow">if</span>(DeeMatrix!=NULL && deleteDeeMatrix)
- <a name="l00686"></a>00686 <span class="keyword">delete</span> DeeMatrix;
- <a name="l00687"></a>00687 <span class="keywordflow">if</span>(HMatrix!=NULL && deleteHMatrix)
- <a name="l00688"></a>00688 <span class="keyword">delete</span> HMatrix;
- <a name="l00689"></a>00689 }
- <a name="l00690"></a>00690
- <a name="l00691"></a>00691 <span class="comment">// Initialization </span>
- <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<dataType></a>& <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<dataType></a>* nd_in)
- <a name="l00693"></a>00693 {
- <a name="l00694"></a>00694 nds[at]=nd_in;
- <a name="l00695"></a>00695 objectsSet=<span class="keyword">false</span>;
- <a name="l00696"></a>00696 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00697"></a>00697 }
- <a name="l00698"></a>00698
- <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<dataType></a>& <a class="code" href="classVABS1__MatrixSource__Quad.html#a043d5e9c8c948a17bba496acef3e6226">setMatl</a>(<a class="code" href="classconstituitive.html">constituitive<dataType></a>* matl_in)
- <a name="l00700"></a>00700 {
- <a name="l00701"></a>00701 matl=matl_in;
- <a name="l00702"></a>00702 matlFunc.setMaterial(matl);
- <a name="l00703"></a>00703 objectsSet=<span class="keyword">false</span>;
- <a name="l00704"></a>00704 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00705"></a>00705 }
- <a name="l00706"></a>00706
- <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>& <a class="code" href="classVABS1__MatrixSource__Quad.html#aeef4a1682902d10018e2b76103edde2b">setEMatrix</a>(<a class="code" href="classmatrixRdWt.html">matrixRdWt<dataType></a>* EMatrix_in,<span class="keywordtype">bool</span> deleteEMatrix_in=<span class="keyword">false</span>)
- <a name="l00708"></a>00708 {
- <a name="l00709"></a>00709 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
- <a name="l00710"></a>00710 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
- <a name="l00711"></a>00711 EMatrix_in-><a class="code" href="classmatrix.html#a3a26f3543df8cff3e662e949e8b9234d">size</a>(rCnt,cCnt);
- <a name="l00712"></a>00712 <span class="keywordflow">if</span>(rCnt!=nds.size()*3 || cCnt!=nds.size()*3)
- <a name="l00713"></a>00713 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::setEMatrix(): The output matrix supplied does not have the correct dimensions"</span>);
- <a name="l00714"></a>00714 <span class="keywordflow">if</span>(EMatrix!=NULL && EMatrix!=EMatrix_in && deleteEMatrix)
- <a name="l00715"></a>00715 <span class="keyword">delete</span> EMatrix;
- <a name="l00716"></a>00716 EMatrix=EMatrix_in;
- <a name="l00717"></a>00717 deleteEMatrix=deleteEMatrix_in;
- <a name="l00718"></a>00718 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00719"></a>00719 }
- <a name="l00720"></a>00720
- <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>& <a class="code" href="classVABS1__MatrixSource__Quad.html#a9ed02f112bf1b4f64cd1930c4a09a306">setDeaMatrix</a>(<a class="code" href="classmatrixRdWt.html">matrixRdWt<dataType></a>* DaeMatrix_in,<span class="keywordtype">bool</span> deleteDaeMatrix_in=<span class="keyword">false</span>)
- <a name="l00722"></a>00722 {
- <a name="l00723"></a>00723 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
- <a name="l00724"></a>00724 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
- <a name="l00725"></a>00725 DaeMatrix_in-><a class="code" href="classmatrix.html#a3a26f3543df8cff3e662e949e8b9234d">size</a>(rCnt,cCnt);
- <a name="l00726"></a>00726 <span class="keywordflow">if</span>(rCnt!=nds.size()*3 || cCnt!=4)
- <a name="l00727"></a>00727 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::setDeaMatrix(): The output matrix supplied does not have the correct dimensions"</span>);
- <a name="l00728"></a>00728 <span class="keywordflow">if</span>(DaeMatrix!=NULL && DaeMatrix!=DaeMatrix_in && deleteDaeMatrix)
- <a name="l00729"></a>00729 <span class="keyword">delete</span> DaeMatrix;
- <a name="l00730"></a>00730 DaeMatrix=DaeMatrix_in;
- <a name="l00731"></a>00731 deleteDaeMatrix=deleteDaeMatrix_in;
- <a name="l00732"></a>00732 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00733"></a>00733 }
- <a name="l00734"></a>00734
- <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>& <a class="code" href="classVABS1__MatrixSource__Quad.html#a35d2eaa4a501b4b4f34178282d2272eb">setDeeMatrix</a>(<a class="code" href="classmatrixRdWt.html">matrixRdWt<dataType></a>* DeeMatrix_in,<span class="keywordtype">bool</span> deleteDeeMatrix_in=<span class="keyword">false</span>)
- <a name="l00736"></a>00736 {
- <a name="l00737"></a>00737 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
- <a name="l00738"></a>00738 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
- <a name="l00739"></a>00739 DeeMatrix_in-><a class="code" href="classmatrix.html#a3a26f3543df8cff3e662e949e8b9234d">size</a>(rCnt,cCnt);
- <a name="l00740"></a>00740 <span class="keywordflow">if</span>(rCnt!=4 || cCnt!=4)
- <a name="l00741"></a>00741 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::setDeeMatrix(): The output matrix supplied does not have the correct dimensions"</span>);
- <a name="l00742"></a>00742 <span class="keywordflow">if</span>(DeeMatrix!=NULL && DeeMatrix!=DeeMatrix_in && deleteDeeMatrix)
- <a name="l00743"></a>00743 <span class="keyword">delete</span> DeeMatrix;
- <a name="l00744"></a>00744 DeeMatrix=DeeMatrix_in;
- <a name="l00745"></a>00745 deleteDeeMatrix=deleteDeeMatrix_in;
- <a name="l00746"></a>00746 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00747"></a>00747 }
- <a name="l00748"></a>00748
- <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>& <a class="code" href="classVABS1__MatrixSource__Quad.html#a888d3cd82ba39342e6cb06614457abb5">setHMatrix</a>(<a class="code" href="classmatrixRdWt.html">matrixRdWt<dataType></a>* HMatrix_in,<span class="keywordtype">bool</span> deleteHMatrix_in=<span class="keyword">false</span>)
- <a name="l00750"></a>00750 {
- <a name="l00751"></a>00751 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
- <a name="l00752"></a>00752 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
- <a name="l00753"></a>00753 HMatrix_in-><a class="code" href="classmatrix.html#a3a26f3543df8cff3e662e949e8b9234d">size</a>(rCnt,cCnt);
- <a name="l00754"></a>00754 <span class="keywordflow">if</span>(rCnt!=nds.size()*3 || cCnt!=nds.size()*3)
- <a name="l00755"></a>00755 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::setHMatrix(): The output matrix supplied does not have the correct dimensions"</span>);
- <a name="l00756"></a>00756 <span class="keywordflow">if</span>(HMatrix!=NULL && HMatrix!=HMatrix_in && deleteHMatrix)
- <a name="l00757"></a>00757 <span class="keyword">delete</span> HMatrix;
- <a name="l00758"></a>00758 HMatrix=HMatrix_in;
- <a name="l00759"></a>00759 deleteHMatrix=deleteHMatrix_in;
- <a name="l00760"></a>00760 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l00761"></a>00761 }
- <a name="l00762"></a>00762
- <a name="l00763"></a>00763 <span class="comment">// VABS1_MatrixSource_Quad& setPsiMatrix(matrixRdWt<dataType>* PsiMatrix_in,bool deletePsiMatrix_in=false)</span>
- <a name="l00764"></a>00764 <span class="comment">// {</span>
- <a name="l00765"></a>00765 <span class="comment">// unsigned long rCnt;</span>
- <a name="l00766"></a>00766 <span class="comment">// unsigned long cCnt;</span>
- <a name="l00767"></a>00767 <span class="comment">// PsiMatrix_in->size(rCnt,cCnt);</span>
- <a name="l00768"></a>00768 <span class="comment">// if(rCnt!=nds.size()*3 || cCnt!=4)</span>
- <a name="l00769"></a>00769 <span class="comment">// throw eMsg("VABS1_MatrixSource_Quad::setPsiMatrix(): The output matrix supplied does not have the correct dimensions");</span>
- <a name="l00770"></a>00770 <span class="comment">// if(PsiMatrix!=NULL && PsiMatrix!=PsiMatrix_in && deletePsiMatrix)</span>
- <a name="l00771"></a>00771 <span class="comment">// delete PsiMatrix;</span>
- <a name="l00772"></a>00772 <span class="comment">// PsiMatrix=PsiMatrix_in;</span>
- <a name="l00773"></a>00773 <span class="comment">// deletePsiMatrix=deletePsiMatrix_in;</span>
- <a name="l00774"></a>00774 <span class="comment">// return *this;</span>
- <a name="l00775"></a>00775 <span class="comment">// }</span>
- <a name="l00776"></a>00776
- <a name="l00777"></a>00777 <span class="comment">// output functions:</span>
- <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>()
- <a name="l00779"></a>00779 {
- <a name="l00780"></a>00780 <span class="keywordflow">if</span>(!objectsSet)
- <a name="l00781"></a>00781 buildObjects();
- <a name="l00782"></a>00782 <span class="keywordflow">if</span>(EMatrix==NULL)
- <a name="l00783"></a>00783 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::addE(): The E matrix has not been set"</span>);
- <a name="l00784"></a>00784 *EMatrix+=outerEMatrixInt.<a class="code" href="classisoIntegral__gauss.html#a74c899ddc289b4b134cc3cca69213621">getValue</a>();
- <a name="l00785"></a>00785 }
- <a name="l00786"></a>00786
- <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>()
- <a name="l00788"></a>00788 {
- <a name="l00789"></a>00789 <span class="keywordflow">if</span>(!objectsSet)
- <a name="l00790"></a>00790 buildObjects();
- <a name="l00791"></a>00791 <span class="keywordflow">if</span>(DaeMatrix==NULL)
- <a name="l00792"></a>00792 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::addDee(): The Dee matrix has not been set"</span>);
- <a name="l00793"></a>00793 *DaeMatrix+=outerDaeMatrixInt.<a class="code" href="classisoIntegral__gauss.html#a74c899ddc289b4b134cc3cca69213621">getValue</a>();
- <a name="l00794"></a>00794 }
- <a name="l00795"></a>00795
- <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>()
- <a name="l00797"></a>00797 {
- <a name="l00798"></a>00798 <span class="keywordflow">if</span>(!objectsSet)
- <a name="l00799"></a>00799 buildObjects();
- <a name="l00800"></a>00800 <span class="keywordflow">if</span>(DeeMatrix==NULL)
- <a name="l00801"></a>00801 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::addDae(): The Dae matrix has not been set"</span>);
- <a name="l00802"></a>00802 *DeeMatrix+=outerDeeMatrixInt.<a class="code" href="classisoIntegral__gauss.html#a74c899ddc289b4b134cc3cca69213621">getValue</a>();
- <a name="l00803"></a>00803 }
- <a name="l00804"></a>00804
- <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>()
- <a name="l00806"></a>00806 {
- <a name="l00807"></a>00807 <span class="keywordflow">if</span>(!objectsSet)
- <a name="l00808"></a>00808 buildObjects();
- <a name="l00809"></a>00809 <span class="keywordflow">if</span>(HMatrix==NULL)
- <a name="l00810"></a>00810 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::addH(): The H matrix has not been set"</span>);
- <a name="l00811"></a>00811 *HMatrix+=outerHMatrixInt.<a class="code" href="classisoIntegral__gauss.html#a74c899ddc289b4b134cc3cca69213621">getValue</a>();
- <a name="l00812"></a>00812 }
- <a name="l00813"></a>00813
- <a name="l00814"></a>00814 <span class="comment">// void addPsi()</span>
- <a name="l00815"></a>00815 <span class="comment">// {</span>
- <a name="l00816"></a>00816 <span class="comment">// if(!objectsSet)</span>
- <a name="l00817"></a>00817 <span class="comment">// buildObjects();</span>
- <a name="l00818"></a>00818 <span class="comment">// if(PsiMatrix==NULL)</span>
- <a name="l00819"></a>00819 <span class="comment">// throw eMsg("VABS1_MatrixSource_Quad::addPsi(): The H matrix has not been set");</span>
- <a name="l00820"></a>00820 <span class="comment">// *PsiMatrix+=outerPsiMatrixInt.getValue();</span>
- <a name="l00821"></a>00821 <span class="comment">// }</span>
- <a name="l00822"></a>00822
- <a name="l00823"></a>00823 <span class="preprocessor">#ifdef SAVE_INTERMEDIATES</span>
- <a name="l00824"></a>00824 <span class="preprocessor"></span>
- <a name="l00825"></a>00825 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> Gamma_aVal;
- <a name="l00826"></a>00826 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> Gamma_eVal;
- <a name="l00827"></a>00827 <a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data<dataType,12,4></a> warpingValues;
- <a name="l00828"></a>00828 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data<dataType,6></a> strain;
- <a name="l00829"></a>00829 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data<dataType,4></a> beamStrainValues;
- <a name="l00830"></a>00830 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> myFail;
- <a name="l00831"></a>00831
- <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>
- <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<dataType,4></a>& beamStrain)
- <a name="l00834"></a>00834 {
- <a name="l00835"></a>00835 <span class="keywordflow">if</span>(matl==NULL)
- <a name="l00836"></a>00836 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::fail(): The material has not been defined"</span>);
- <a name="l00837"></a>00837 <span class="keywordflow">if</span>(s<-1.0 || s>1.0 || t<-1.0 || t>1.0)
- <a name="l00838"></a>00838 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::fail(): The element is not defined at the specified location"</span>);
- <a name="l00839"></a>00839
- <a name="l00840"></a>00840 <span class="comment">// build a vector based on the nodal values</span>
- <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><4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l00842"></a>00842 {
- <a name="l00843"></a>00843 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> r=0;r<3;r++)
- <a name="l00844"></a>00844 {
- <a name="l00845"></a>00845 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> c=0;c<4;c++)
- <a name="l00846"></a>00846 {
- <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>]->warping().data().entry(r,c);
- <a name="l00848"></a>00848 }
- <a name="l00849"></a>00849 }
- <a name="l00850"></a>00850 }
- <a name="l00851"></a>00851
- <a name="l00852"></a>00852 Gamma_aVal=Gamma_a.getValue2D(s,t);
- <a name="l00853"></a>00853 Gamma_eVal=Gamma_e.getValue2D(s,t);
- <a name="l00854"></a>00854 beamStrainValues=beamStrain;
- <a name="l00855"></a>00855 strain=(Gamma_aVal*warpingValues+Gamma_eVal)*beamStrainValues;
- <a name="l00856"></a>00856
- <a name="l00857"></a>00857 <span class="comment">// if(printStrain)</span>
- <a name="l00858"></a>00858 <span class="comment">// {</span>
- <a name="l00859"></a>00859 <span class="comment">// std::cout << "This is the 3-D strain" << std::endl;</span>
- <a name="l00860"></a>00860 <span class="comment">// printMatrix(strain);</span>
- <a name="l00861"></a>00861 <span class="comment">// }</span>
- <a name="l00862"></a>00862 myFail=matl->failure(strain,<a class="code" href="classconstituitiveDependent.html">constituitiveDependent<double></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)));
- <a name="l00863"></a>00863
- <a name="l00864"></a>00864 <span class="keywordflow">return</span> myFail;
- <a name="l00865"></a>00865 }
- <a name="l00866"></a>00866
- <a name="l00867"></a>00867 <span class="preprocessor">#else</span>
- <a name="l00868"></a>00868 <span class="preprocessor"></span>
- <a name="l00869"></a>00869 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
- <a name="l00870"></a>00870 <span class="preprocessor"></span> <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data<dataType,4></a> beamStrainValues;
- <a name="l00871"></a>00871 <span class="preprocessor">#endif</span>
- <a name="l00872"></a>00872 <span class="preprocessor"></span>
- <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>
- <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<dataType,4></a>& beamStrain)
- <a name="l00875"></a>00875 {
- <a name="l00876"></a>00876 <span class="keywordflow">if</span>(matl==NULL)
- <a name="l00877"></a>00877 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::fail(): The material has not been defined"</span>);
- <a name="l00878"></a>00878 <span class="keywordflow">if</span>(s<-1.0 || s>1.0 || t<-1.0 || t>1.0)
- <a name="l00879"></a>00879 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::fail(): The element is not defined at the specified location"</span>);
- <a name="l00880"></a>00880
- <a name="l00881"></a>00881 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
- <a name="l00882"></a>00882 <span class="preprocessor"></span> beamStrainValues=beamStrain;
- <a name="l00883"></a>00883 <span class="preprocessor">#endif</span>
- <a name="l00884"></a>00884 <span class="preprocessor"></span>
- <a name="l00885"></a>00885 <span class="comment">// build a vector based on the nodal values</span>
- <a name="l00886"></a>00886 <a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data<dataType,12,4></a> warpingValues;
- <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><4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l00888"></a>00888 {
- <a name="l00889"></a>00889 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> r=0;r<3;r++)
- <a name="l00890"></a>00890 {
- <a name="l00891"></a>00891 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> c=0;c<4;c++)
- <a name="l00892"></a>00892 {
- <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>]->warping().data().entry(r,c);
- <a name="l00894"></a>00894 }
- <a name="l00895"></a>00895 }
- <a name="l00896"></a>00896 }
- <a name="l00897"></a>00897
- <a name="l00898"></a>00898 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data<dataType,6></a> strain=((Gamma_a.getValue2D(s,t))*warpingValues+Gamma_e.getValue2D(s,t))*beamStrain;
- <a name="l00899"></a>00899
- <a name="l00900"></a>00900 <span class="comment">// if(printStrain)</span>
- <a name="l00901"></a>00901 <span class="comment">// {</span>
- <a name="l00902"></a>00902 <span class="comment">// std::cout << "This is the 3-D strain" << std::endl;</span>
- <a name="l00903"></a>00903 <span class="comment">// printMatrix(strain);</span>
- <a name="l00904"></a>00904 <span class="comment">// }</span>
- <a name="l00905"></a>00905
- <a name="l00906"></a>00906 <span class="keywordflow">return</span> matl->failure(strain,<a class="code" href="classconstituitiveDependent.html">constituitiveDependent<double></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)));
- <a name="l00907"></a>00907 }
- <a name="l00908"></a>00908
- <a name="l00909"></a>00909 <span class="preprocessor">#endif</span>
- <a name="l00910"></a>00910 <span class="preprocessor"></span>
- <a name="l00911"></a>00911 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
- <a name="l00912"></a>00912 <span class="preprocessor"></span>
- <a name="l00913"></a>00913 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></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)
- <a name="l00914"></a>00914 {
- <a name="l00915"></a>00915 <span class="keywordflow">return</span> Gamma_a.getValue2D(s,t);
- <a name="l00916"></a>00916 }
- <a name="l00917"></a>00917
- <a name="l00918"></a>00918 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></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)
- <a name="l00919"></a>00919 {
- <a name="l00920"></a>00920 <span class="keywordflow">return</span> Gamma_e.getValue2D(s,t);
- <a name="l00921"></a>00921 }
- <a name="l00922"></a>00922
- <a name="l00923"></a>00923 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data<dataType,6></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<dataType,4></a>& beamStrain)
- <a name="l00924"></a>00924 {
- <a name="l00925"></a>00925 <span class="keywordflow">if</span>(matl==NULL)
- <a name="l00926"></a>00926 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::fail(): The material has not been defined"</span>);
- <a name="l00927"></a>00927 <span class="keywordflow">if</span>(s<-1.0 || s>1.0 || t<-1.0 || t>1.0)
- <a name="l00928"></a>00928 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_MatrixSource_Quad::fail(): The element is not defined at the specified location"</span>);
- <a name="l00929"></a>00929
- <a name="l00930"></a>00930 <span class="comment">// build a vector based on the nodal values</span>
- <a name="l00931"></a>00931 <a class="code" href="classmatrixRdWtStatic__Data.html">matrixRdWtStatic_Data<dataType,12,4></a> warpingValues;
- <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><4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l00933"></a>00933 {
- <a name="l00934"></a>00934 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> r=0;r<3;r++)
- <a name="l00935"></a>00935 {
- <a name="l00936"></a>00936 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> c=0;c<4;c++)
- <a name="l00937"></a>00937 {
- <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>]->warping().data().entry(r,c);
- <a name="l00939"></a>00939 }
- <a name="l00940"></a>00940 }
- <a name="l00941"></a>00941 }
- <a name="l00942"></a>00942
- <a name="l00943"></a>00943 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data<dataType,6></a> strain=((Gamma_a.getValue2D(s,t))*warpingValues+Gamma_e.getValue2D(s,t))*beamStrain;
- <a name="l00944"></a>00944
- <a name="l00945"></a>00945 <span class="keywordflow">return</span> strain;
- <a name="l00946"></a>00946 }
- <a name="l00947"></a>00947
- <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<dataType,6></a> strain)
- <a name="l00949"></a>00949 {
- <a name="l00950"></a>00950 <span class="keywordflow">return</span> matl->failure(strain,<a class="code" href="classconstituitiveDependent.html">constituitiveDependent<double></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)));
- <a name="l00951"></a>00951 }
- <a name="l00952"></a>00952
- <a name="l00953"></a>00953 <span class="preprocessor">#endif</span>
- <a name="l00954"></a>00954 <span class="preprocessor"></span>
- <a name="l00955"></a>00955 };
- <a name="l00956"></a>00956
- <a name="l00957"></a>00957 <span class="comment">// this is a class for collecting failure information...</span>
- <a name="l00958"></a>00958 <span class="comment">// a list is generated that contains all the failure results...</span>
- <a name="l00959"></a>00959 <span class="comment">// template<class dataType></span>
- <a name="l00960"></a>00960 <span class="comment">// class failPoint</span>
- <a name="l00961"></a>00961 <span class="comment">// {</span>
- <a name="l00962"></a>00962 <span class="comment">// public:</span>
- <a name="l00963"></a>00963 <span class="comment">// </span>
- <a name="l00964"></a>00964 <span class="comment">// dataType fail; // 1 and greater indacates failer</span>
- <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>
- <a name="l00966"></a>00966 <span class="comment">// dataType t;</span>
- <a name="l00967"></a>00967 <span class="comment">// unsigned long elmID; // this is the element</span>
- <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>
- <a name="l00969"></a>00969 <span class="comment">// bool meshIDSet; // this is a flag the tells whether the mesh ID has been set</span>
- <a name="l00970"></a>00970 <span class="comment">// </span>
- <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>
- <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>
- <a name="l00973"></a>00973 <span class="comment">// {}</span>
- <a name="l00974"></a>00974 <span class="comment">// </span>
- <a name="l00975"></a>00975 <span class="comment">// failPoint(const failPoint<dataType>& asg) : fail(asg.fail) , s(asg.s) , t(asg.t) , elmID(asg.elmID) , meshID(asg.meshID) , meshIDSet(asg.meshIDSet)</span>
- <a name="l00976"></a>00976 <span class="comment">// {}</span>
- <a name="l00977"></a>00977 <span class="comment">// </span>
- <a name="l00978"></a>00978 <span class="comment">// virtual ~failPoint()</span>
- <a name="l00979"></a>00979 <span class="comment">// {}</span>
- <a name="l00980"></a>00980 <span class="comment">// </span>
- <a name="l00981"></a>00981 <span class="comment">// failPoint<dataType>& operator=(const failPoint<dataType>& asg)</span>
- <a name="l00982"></a>00982 <span class="comment">// {</span>
- <a name="l00983"></a>00983 <span class="comment">// this->fail=asg.fail;</span>
- <a name="l00984"></a>00984 <span class="comment">// this->s=asg.s;</span>
- <a name="l00985"></a>00985 <span class="comment">// this->t=asg.t;</span>
- <a name="l00986"></a>00986 <span class="comment">// this->elmID=asg.elmID;</span>
- <a name="l00987"></a>00987 <span class="comment">// this->meshID=asg.meshID;</span>
- <a name="l00988"></a>00988 <span class="comment">// this->meshIDSet=asg.meshIDSet;</span>
- <a name="l00989"></a>00989 <span class="comment">// </span>
- <a name="l00990"></a>00990 <span class="comment">// return *this;</span>
- <a name="l00991"></a>00991 <span class="comment">// }</span>
- <a name="l00992"></a>00992 <span class="comment">// };</span>
- <a name="l00993"></a>00993
- <a name="l00994"></a>00994 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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>
- <a name="l00996"></a>00996 {
- <a name="l00997"></a>00997 <span class="keyword">public</span>:
- <a name="l00998"></a>00998
- <a name="l00999"></a><a class="code" href="classVABSModelInput.html#afcae6babe46baa259b50efa164b32fdb">00999</a> <a class="code" href="classVABSModelInput.html#afcae6babe46baa259b50efa164b32fdb">VABSModelInput</a>()
- <a name="l01000"></a>01000 {}
- <a name="l01001"></a>01001
- <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>()
- <a name="l01003"></a>01003 {}
- <a name="l01004"></a>01004
- <a name="l01005"></a>01005 <span class="comment">// This is a function that provides the mesh to the vabs model</span>
- <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<dataType></a>* cxMesh_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)=0;
- <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;
- <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;
- <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;
- <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;
- <a name="l01011"></a>01011 };
- <a name="l01012"></a>01012
- <a name="l01013"></a>01013 <span class="comment">// beamMtxType is matrixRdWtStaticSqr_Data<dataType,4> for Bernoulli type</span>
- <a name="l01014"></a>01014 <span class="comment">// is matrixRdWtStaticSqr_Data<dataType,6> for Timoshenko type</span>
- <a name="l01015"></a>01015 <span class="keyword">template</span><<span class="keyword">class</span> beamMtxType>
- <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>
- <a name="l01017"></a>01017 {
- <a name="l01018"></a>01018 <span class="keyword">public</span>:
- <a name="l01019"></a>01019
- <a name="l01020"></a><a class="code" href="classVABSModelBeamMatrix.html#aebe1a6aee7fd6588a6df182a942eb305">01020</a> <a class="code" href="classVABSModelBeamMatrix.html#aebe1a6aee7fd6588a6df182a942eb305">VABSModelBeamMatrix</a>()
- <a name="l01021"></a>01021 {}
- <a name="l01022"></a>01022
- <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>()
- <a name="l01024"></a>01024 {}
- <a name="l01025"></a>01025
- <a name="l01026"></a>01026 <span class="comment">//This retrieve the beam matrix</span>
- <a name="l01027"></a>01027 <span class="keyword">virtual</span> beamMtxType <a class="code" href="classVABSModelBeamMatrix.html#ad74f2717ec4415b3603ba49f42403b0c">beamMatrix</a>()=0;
- <a name="l01028"></a>01028 };
- <a name="l01029"></a>01029
- <a name="l01030"></a>01030 <span class="keyword">template</span><<span class="keyword">class</span> elmPostType>
- <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>
- <a name="l01032"></a>01032 {
- <a name="l01033"></a>01033 <span class="keyword">public</span>:
- <a name="l01034"></a>01034
- <a name="l01035"></a><a class="code" href="classVABSModelPost.html#ab1bd45cfe293a9e588f7e0491ae2717a">01035</a> <a class="code" href="classVABSModelPost.html#ab1bd45cfe293a9e588f7e0491ae2717a">VABSModelPost</a>()
- <a name="l01036"></a>01036 {}
- <a name="l01037"></a>01037
- <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>()
- <a name="l01039"></a>01039 {}
- <a name="l01040"></a>01040
- <a name="l01041"></a>01041 <span class="comment">// A method that informs the post process module about the number of elements</span>
- <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;
- <a name="l01043"></a>01043 <span class="comment">// This is an access method to perform post processing</span>
- <a name="l01044"></a>01044 <span class="keyword">virtual</span> <a class="code" href="classautoPntr.html">autoPntr<elmPostType></a> <a class="code" href="classVABSModelPost.html#ab22c953c94473d150d7b45b30833969d">getElement</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)=0;
- <a name="l01045"></a>01045 };
- <a name="l01046"></a>01046
- <a name="l01047"></a>01047 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> beamMtxType,<span class="keyword">class</span> elmPostType>
- <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><dataType> , <span class="keyword">public</span> <a class="code" href="classVABSModelBeamMatrix.html">VABSModelBeamMatrix</a><beamMtxType> , <span class="keyword">public</span> <a class="code" href="classVABSModelPost.html">VABSModelPost</a><elmPostType>
- <a name="l01049"></a>01049 {
- <a name="l01050"></a>01050 <span class="keyword">public</span>:
- <a name="l01051"></a>01051
- <a name="l01052"></a><a class="code" href="classVABSModel.html#a49f45824951a0a80eb6fc0190c7c5cd5">01052</a> <a class="code" href="classVABSModel.html#a49f45824951a0a80eb6fc0190c7c5cd5">VABSModel</a>()
- <a name="l01053"></a>01053 {}
- <a name="l01054"></a>01054
- <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>()
- <a name="l01056"></a>01056 {}
- <a name="l01057"></a>01057 };
- <a name="l01058"></a>01058
- <a name="l01059"></a>01059 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><dataType,matrixRdWtStaticSqr_Data<dataType,4>,VABSElementInfo<dataType,matrixStaticVectCol<dataType,4> > >
- <a name="l01061"></a>01061 {
- <a name="l01062"></a>01062 <span class="keyword">private</span>:
- <a name="l01063"></a>01063
- <a name="l01064"></a>01064 <span class="comment">// Input data used to build the constituitive matrix</span>
- <a name="l01065"></a>01065 <a class="code" href="classmesh.html">mesh<dataType></a>* cxMesh;
- <a name="l01066"></a>01066 <span class="keywordtype">bool</span> matrixBuilt;
- <a name="l01067"></a>01067
- <a name="l01068"></a>01068 <span class="comment">// These are the fem objects </span>
- <a name="l01069"></a>01069 std::vector<VABSNode_common<dataType> > commonNodes;
- <a name="l01070"></a>01070 std::vector<std::vector<VABSNode_element<dataType> > > elementNodes;
- <a name="l01071"></a>01071 std::vector<VABS1_MatrixSource_Quad<dataType> > elements;
- <a name="l01072"></a>01072
- <a name="l01073"></a>01073 <span class="comment">// these are the matrices</span>
- <a name="l01074"></a>01074
- <a name="l01075"></a>01075 <span class="comment">// matrixRdWtSz_Data<dataType> Psi;</span>
- <a name="l01076"></a>01076 <span class="comment">// matrixRdWtSz_Data<dataType> E; // delete me</span>
- <a name="l01077"></a>01077
- <a name="l01078"></a>01078 <span class="comment">// this is the solver</span>
- <a name="l01079"></a>01079 <span class="preprocessor">#ifdef SVD_BASED_VABS_SOLUTION</span>
- <a name="l01080"></a>01080 <span class="preprocessor"></span> <a class="code" href="classvabsSvdSolver.html">vabsSvdSolver</a> solver;
- <a name="l01081"></a>01081 <span class="preprocessor">#else</span>
- <a name="l01082"></a>01082 <span class="preprocessor"></span> <a class="code" href="classmatrixMatrixSolver.html">matrixMatrixSolver</a> solver;
- <a name="l01083"></a>01083 <span class="preprocessor">#endif</span>
- <a name="l01084"></a>01084 <span class="preprocessor"></span>
- <a name="l01085"></a>01085 <span class="comment">// This is the matrix that is returned as a result</span>
- <a name="l01086"></a>01086 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> result;
- <a name="l01087"></a>01087
- <a name="l01088"></a>01088 <span class="comment">// state data on the model</span>
- <a name="l01089"></a>01089 <span class="keywordtype">bool</span> isBuilt;
- <a name="l01090"></a>01090 <span class="keywordtype">bool</span> isSolved;
- <a name="l01091"></a>01091 <span class="keywordtype">bool</span> canDelete;
- <a name="l01092"></a>01092
- <a name="l01093"></a>01093 <span class="preprocessor">#if defined(SAVE_INTERMEDIATES) || defined(ADJOINT_VABS)</span>
- <a name="l01094"></a>01094 <span class="preprocessor"></span> <span class="keyword">public</span>:
- <a name="l01095"></a>01095 <span class="comment">// matrixRdWtSzSqr_Data<dataType> ET;</span>
- <a name="l01096"></a>01096 <a class="code" href="classmatrixRdWtSzSqr__Data.html">matrixRdWtSzSqr_Data<dataType></a> ETDyad;
- <a name="l01097"></a>01097 <span class="preprocessor">#endif</span>
- <a name="l01098"></a>01098 <span class="preprocessor"></span> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> Dae;
- <a name="l01099"></a>01099 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> Dee;
- <a name="l01100"></a>01100 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> H;
- <a name="l01101"></a>01101 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> v;
- <a name="l01102"></a>01102 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l01103"></a>01103 <span class="preprocessor"></span> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> Psi;
- <a name="l01104"></a>01104 <span class="preprocessor">#endif</span>
- <a name="l01105"></a>01105 <span class="preprocessor"></span><span class="preprocessor">#if defined(SAVE_INTERMEDIATES) || defined(ADJOINT_VABS)</span>
- <a name="l01106"></a>01106 <span class="preprocessor"></span> <span class="keyword">private</span>:
- <a name="l01107"></a>01107 <span class="preprocessor">#endif</span>
- <a name="l01108"></a>01108 <span class="preprocessor"></span>
- <a name="l01109"></a>01109 <span class="preprocessor">#if defined(SAVE_INTERMEDIATES) || defined(ADJOINT_VABS)</span>
- <a name="l01110"></a>01110 <span class="preprocessor"></span>
- <a name="l01111"></a>01111 <span class="keyword">public</span>:
- <a name="l01112"></a>01112
- <a name="l01113"></a>01113 <span class="keyword">static</span> <span class="keywordtype">bool</span> gradientMode;
- <a name="l01114"></a>01114 <span class="keyword">static</span> <span class="keywordtype">bool</span> highCalc;
- <a name="l01115"></a>01115 <span class="keyword">static</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> step;
- <a name="l01116"></a>01116 <span class="keyword">static</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> atS;
- <a name="l01117"></a>01117 <span class="keyword">static</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> atT;
- <a name="l01118"></a>01118 <span class="keyword">static</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> beamLocation;
- <a name="l01119"></a>01119 <span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> maxElm;
- <a name="l01120"></a>01120 <span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> maxCX;
- <a name="l01121"></a>01121
- <a name="l01122"></a>01122 <span class="keyword">static</span> std::vector<VABS1Model_Base*> vabsList;
- <a name="l01123"></a>01123
- <a name="l01124"></a>01124 <span class="keyword">private</span>:
- <a name="l01125"></a>01125
- <a name="l01126"></a>01126 <span class="preprocessor">#endif</span>
- <a name="l01127"></a>01127 <span class="preprocessor"></span>
- <a name="l01128"></a>01128 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
- <a name="l01129"></a>01129 <span class="preprocessor"></span>
- <a name="l01130"></a>01130 <span class="keyword">private</span>:
- <a name="l01131"></a>01131
- <a name="l01132"></a>01132 <span class="comment">// this is the meshes</span>
- <a name="l01133"></a>01133 <a class="code" href="classmesh.html">mesh<dataType></a>* cxMeshHigh;
- <a name="l01134"></a>01134 <a class="code" href="classmesh.html">mesh<dataType></a>* cxMeshLow;
- <a name="l01135"></a>01135
- <a name="l01136"></a>01136 <span class="comment">// These are the fem objects </span>
- <a name="l01137"></a>01137 std::vector<VABSNode_common<dataType> > commonNodesHigh;
- <a name="l01138"></a>01138 std::vector<std::vector<VABSNode_element<dataType> > > elementNodesHigh;
- <a name="l01139"></a>01139 std::vector<VABS1_MatrixSource_Quad<dataType> > elementsHigh;
- <a name="l01140"></a>01140
- <a name="l01141"></a>01141 <span class="comment">// These are the fem objects </span>
- <a name="l01142"></a>01142 std::vector<VABSNode_common<dataType> > commonNodesLow;
- <a name="l01143"></a>01143 std::vector<std::vector<VABSNode_element<dataType> > > elementNodesLow;
- <a name="l01144"></a>01144 std::vector<VABS1_MatrixSource_Quad<dataType> > elementsLow;
- <a name="l01145"></a>01145
- <a name="l01146"></a>01146 <span class="keyword">public</span>:
- <a name="l01147"></a>01147
- <a name="l01148"></a>01148 <a class="code" href="classmatrixRdWtSzSqr__Data.html">matrixRdWtSzSqr_Data<dataType></a> N;
- <a name="l01149"></a>01149 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> vStar_adjoint;
- <a name="l01150"></a>01150 <span class="comment">// matrixRdWtSz_Data<dataType> vStar_adjointLow;</span>
- <a name="l01151"></a>01151 <span class="comment">// matrixRdWtSz_Data<dataType> vStar_adjointHigh;</span>
- <a name="l01152"></a>01152
- <a name="l01153"></a>01153 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> dDae_dy;
- <a name="l01154"></a>01154 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> dN_dy;
- <a name="l01155"></a>01155 <span class="comment">// matrixRdWtSz_Data<dataType> dH_dy;</span>
- <a name="l01156"></a>01156 <span class="comment">// matrixRdWtSz_Data<dataType> dPsi_dy;</span>
- <a name="l01157"></a>01157 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> dDee_dy;
- <a name="l01158"></a>01158 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> dE_dy;
- <a name="l01159"></a>01159
- <a name="l01160"></a>01160 <span class="comment">// these are the low matrices</span>
- <a name="l01161"></a>01161 <a class="code" href="classmatrixRdWtSzSqr__Data.html">matrixRdWtSzSqr_Data<dataType></a> ELow;
- <a name="l01162"></a>01162 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> DaeLow;
- <a name="l01163"></a>01163 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> DeeLow;
- <a name="l01164"></a>01164 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> NLow;
- <a name="l01165"></a>01165 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> HLow;
- <a name="l01166"></a>01166 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l01167"></a>01167 <span class="preprocessor"></span> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> PsiLow;
- <a name="l01168"></a>01168 <span class="preprocessor">#endif</span>
- <a name="l01169"></a>01169 <span class="preprocessor"></span>
- <a name="l01170"></a>01170 <span class="comment">// these are the high matrices</span>
- <a name="l01171"></a>01171 <a class="code" href="classmatrixRdWtSzSqr__Data.html">matrixRdWtSzSqr_Data<dataType></a> EHigh;
- <a name="l01172"></a>01172 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> DaeHigh;
- <a name="l01173"></a>01173 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> DeeHigh;
- <a name="l01174"></a>01174 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> NHigh;
- <a name="l01175"></a>01175 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> HHigh;
- <a name="l01176"></a>01176 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l01177"></a>01177 <span class="preprocessor"></span> <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> PsiHigh;
- <a name="l01178"></a>01178 <span class="preprocessor">#endif</span>
- <a name="l01179"></a>01179 <span class="preprocessor"></span>
- <a name="l01180"></a>01180 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> dC_dy;
- <a name="l01181"></a>01181
- <a name="l01182"></a>01182 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> adjointFail;
- <a name="l01183"></a>01183
- <a name="l01184"></a>01184 <span class="keywordtype">void</span> buildHighMatrix(<a class="code" href="classmesh.html">mesh<dataType></a>* cxMeshHigh_in)
- <a name="l01185"></a>01185 {
- <a name="l01186"></a>01186
- <a name="l01187"></a>01187 cxMeshHigh=cxMeshHigh_in;
- <a name="l01188"></a>01188
- <a name="l01189"></a>01189 <span class="keywordflow">if</span>(cxMeshHigh==NULL)
- <a name="l01190"></a>01190 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::buildHighLowMatrix(): The mesh has not been specified"</span>);
- <a name="l01191"></a>01191
- <a name="l01192"></a>01192 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l01193"></a>01193 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a4a19abf94aa1abd08eb8b6fdd2f4662e">TIMEALG::vabsMeshLinkStart</a>();
- <a name="l01194"></a>01194 <span class="preprocessor">#endif</span>
- <a name="l01195"></a>01195 <span class="preprocessor"></span>
- <a name="l01196"></a>01196 <span class="comment">// retrieve the size</span>
- <a name="l01197"></a>01197 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> ndCnt;
- <a name="l01198"></a>01198 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> elmCnt;
- <a name="l01199"></a>01199 cxMeshHigh->size(ndCnt,elmCnt);
- <a name="l01200"></a>01200
- <a name="l01201"></a>01201 <span class="comment">// size all the matrices</span>
- <a name="l01202"></a>01202 EHigh.resize(ndCnt*3);
- <a name="l01203"></a>01203 DaeHigh.resize(ndCnt*3,4);
- <a name="l01204"></a>01204 HHigh.resize(ndCnt*3,ndCnt*3);
- <a name="l01205"></a>01205 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l01206"></a>01206 <span class="preprocessor"></span> PsiHigh.resize(ndCnt*3,4);
- <a name="l01207"></a>01207 <span class="preprocessor">#endif</span>
- <a name="l01208"></a>01208 <span class="preprocessor"></span>
- <a name="l01209"></a>01209 <span class="comment">// create all the nodes and elements</span>
- <a name="l01210"></a>01210 commonNodesHigh.resize(ndCnt);
- <a name="l01211"></a>01211 elementNodesHigh.resize(ndCnt);
- <a name="l01212"></a>01212 elementsHigh.resize(elmCnt);
- <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><ndCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01214"></a>01214 {
- <a name="l01215"></a>01215 commonNodesHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setX(cxMeshHigh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).x);
- <a name="l01216"></a>01216 commonNodesHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setY(cxMeshHigh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).y);
- <a name="l01217"></a>01217 <span class="comment">// for(unsigned long j=0;j<3;j++)</span>
- <a name="l01218"></a>01218 <span class="comment">// {</span>
- <a name="l01219"></a>01219 <span class="comment">// for(unsigned long k=0;k<4;k++)</span>
- <a name="l01220"></a>01220 <span class="comment">// commonNodesHigh[i].setWarping(j,k,&(vHigh.entry(i*3+j,k)));</span>
- <a name="l01221"></a>01221 <span class="comment">// }</span>
- <a name="l01222"></a>01222 elementNodesHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].resize(cxMeshHigh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData.size());
- <a name="l01223"></a>01223 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<elementNodesHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].size();j++)
- <a name="l01224"></a>01224 elementNodesHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>][j].setH(cxMeshHigh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData[j].h_over_H).setAng(cxMeshHigh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData[j].angle).setCommon(&(commonNodesHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]));
- <a name="l01225"></a>01225 }
- <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><elmCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01227"></a>01227 {
- <a name="l01228"></a>01228 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();j++)
- <a name="l01229"></a>01229 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setNode(j,&(elementNodesHigh[cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID][cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].dataID]));
- <a name="l01230"></a>01230 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setMatl(cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).material);
- <a name="l01231"></a>01231 }
- <a name="l01232"></a>01232
- <a name="l01233"></a>01233 <span class="comment">// set all the matrices in the elements</span>
- <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><elmCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01235"></a>01235 {
- <a name="l01236"></a>01236 <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData<dataType></a>* EMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData<dataType></a>(cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3);
- <a name="l01237"></a>01237 <span class="keywordflow">if</span>(EMatrix==NULL)
- <a name="l01238"></a>01238 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::buildMatrix(): Failed to allocate memory for EMatrix"</span>);
- <a name="l01239"></a>01239 <a class="code" href="classmatrixRdWt__pData.html">matrixRdWt_pData<dataType></a>* DaeMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWt__pData.html">matrixRdWt_pData<dataType></a>(cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3,4);
- <a name="l01240"></a>01240 <span class="keywordflow">if</span>(DaeMatrix==NULL)
- <a name="l01241"></a>01241 {
- <a name="l01242"></a>01242 <span class="keyword">delete</span> EMatrix;
- <a name="l01243"></a>01243 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::buildMatrix(): Failed to allocate memory for DaeMatrix"</span>);
- <a name="l01244"></a>01244 }
- <a name="l01245"></a>01245 <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData<dataType></a>* HMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData<dataType></a>(cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3);
- <a name="l01246"></a>01246 <span class="keywordflow">if</span>(HMatrix==NULL)
- <a name="l01247"></a>01247 {
- <a name="l01248"></a>01248 <span class="keyword">delete</span> EMatrix;
- <a name="l01249"></a>01249 <span class="keyword">delete</span> DaeMatrix;
- <a name="l01250"></a>01250 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::buildMatrix(): Failed to allocate memory for HMatrix"</span>);
- <a name="l01251"></a>01251 }
- <a name="l01252"></a>01252 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();j++)
- <a name="l01253"></a>01253 {
- <a name="l01254"></a>01254 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k<cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();k++)
- <a name="l01255"></a>01255 {
- <a name="l01256"></a>01256 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> m=0;m<3;m++)
- <a name="l01257"></a>01257 {
- <a name="l01258"></a>01258 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> n=0;n<3;n++)
- <a name="l01259"></a>01259 {
- <a name="l01260"></a>01260 EMatrix-><a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,k*3+n,&(EHigh.entry(cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,cxMeshHigh->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>
- <a name="l01261"></a>01261 HMatrix-><a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,k*3+n,&(HHigh.entry(cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[k].nodeID*3+n)),<span class="keyword">false</span>);
- <a name="l01262"></a>01262 }
- <a name="l01263"></a>01263 }
- <a name="l01264"></a>01264 }
- <a name="l01265"></a>01265 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> m=0;m<3;m++)
- <a name="l01266"></a>01266 {
- <a name="l01267"></a>01267 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> n=0;n<4;n++)
- <a name="l01268"></a>01268 {
- <a name="l01269"></a>01269 DaeMatrix-><a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,n,&(DaeHigh.entry(cxMeshHigh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,n)),<span class="keyword">false</span>);
- <a name="l01270"></a>01270 <span class="comment">// PsiMatrix->setPointer(j*3+m,n,&(Psi.entry(cxMesh->getElement(i).nodeHndl[j].nodeID*3+m,n)),false);</span>
- <a name="l01271"></a>01271 }
- <a name="l01272"></a>01272 }
- <a name="l01273"></a>01273 }
- <a name="l01274"></a>01274 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setEMatrix(EMatrix,<span class="keyword">true</span>);
- <a name="l01275"></a>01275 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setDeaMatrix(DaeMatrix,<span class="keyword">true</span>);
- <a name="l01276"></a>01276 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setHMatrix(HMatrix,<span class="keyword">true</span>);
- <a name="l01277"></a>01277 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setDeeMatrix(&DeeHigh);
- <a name="l01278"></a>01278 <span class="comment">// elements[i].setPsiMatrix(PsiMatrix);</span>
- <a name="l01279"></a>01279 }
- <a name="l01280"></a>01280
- <a name="l01281"></a>01281 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l01282"></a>01282 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a19a22177645e1866a8cb9217ad98b726">TIMEALG::vabsMeshLinkStop</a>();
- <a name="l01283"></a>01283 <a class="code" href="namespaceTIMEALG.html#a47cb7df0449fa5c03c285d3e92d3aa2d">TIMEALG::vabsMtxCalcStart</a>();
- <a name="l01284"></a>01284 <span class="preprocessor">#endif</span>
- <a name="l01285"></a>01285 <span class="preprocessor"></span>
- <a name="l01286"></a>01286 <span class="comment">// initialize the matrices</span>
- <a name="l01287"></a>01287 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
- <a name="l01288"></a>01288 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
- <a name="l01289"></a>01289 HHigh.size(rCnt,cCnt);
- <a name="l01290"></a>01290 HHigh=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l01291"></a>01291 DaeHigh.size(rCnt,cCnt);
- <a name="l01292"></a>01292 DaeHigh=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l01293"></a>01293 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l01294"></a>01294 <span class="preprocessor"></span> PsiHigh.size(rCnt,cCnt);
- <a name="l01295"></a>01295 PsiHigh=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l01296"></a>01296 <span class="preprocessor">#endif</span>
- <a name="l01297"></a>01297 <span class="preprocessor"></span> cCnt=rCnt=DeeHigh.size();
- <a name="l01298"></a>01298 DeeHigh=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l01299"></a>01299 cCnt=rCnt=EHigh.size();
- <a name="l01300"></a>01300 EHigh=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l01301"></a>01301
- <a name="l01302"></a>01302 <span class="comment">// Create the matrices</span>
- <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><elementsHigh.size();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01304"></a>01304 {
- <a name="l01305"></a>01305 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addE();
- <a name="l01306"></a>01306 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addDee();
- <a name="l01307"></a>01307 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addDae();
- <a name="l01308"></a>01308 elementsHigh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addH();
- <a name="l01309"></a>01309 }
- <a name="l01310"></a>01310
- <a name="l01311"></a>01311 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l01312"></a>01312 <span class="preprocessor"></span> <span class="comment">// create the Psi matrix</span>
- <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));
- <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><ndCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01315"></a>01315 {
- <a name="l01316"></a>01316 PsiHigh.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3,0)=one;
- <a name="l01317"></a>01317 PsiHigh.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1,1)=one;
- <a name="l01318"></a>01318 PsiHigh.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2,2)=one;
- <a name="l01319"></a>01319 PsiHigh.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1,3)=cxMeshHigh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).y;
- <a name="l01320"></a>01320 PsiHigh.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2,3)=-cxMeshHigh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).x;
- <a name="l01321"></a>01321 }
- <a name="l01322"></a>01322 <span class="preprocessor">#endif</span>
- <a name="l01323"></a>01323 <span class="preprocessor"></span>
- <a name="l01324"></a>01324 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l01325"></a>01325 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#abb3dfe1409ead9ab389b11970c1ed9bb">TIMEALG::vabsMtxCalcStop</a>();
- <a name="l01326"></a>01326 <a class="code" href="namespaceTIMEALG.html#a64fad33a25509725cf641d6f6d9c6f63">TIMEALG::vabsNCalcStart</a>();
- <a name="l01327"></a>01327 <span class="preprocessor">#endif</span>
- <a name="l01328"></a>01328 <span class="preprocessor"></span>
- <a name="l01329"></a>01329 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> PsiTHPsi=PsiHigh.<a class="code" href="classmatrixRdWtStaticSqr__Data.html#a3db65c97e3f5de1fe52b5f0831e11176">T</a>()*HHigh*PsiHigh;
- <a name="l01330"></a>01330 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> PsiTHPsi_Inverse=PsiTHPsi.<a class="code" href="classmatrixSqr.html#a991ebad568b11587f75c85cc3b8da408">inverse</a>();
- <a name="l01331"></a>01331 NHigh=(<a class="code" href="classmatrix.html">matrix<dataType>::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>();
- <a name="l01332"></a>01332
- <a name="l01333"></a>01333 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l01334"></a>01334 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a294dfa8c6f83f364d880655b35f8531f">TIMEALG::vabsNCalcStop</a>();
- <a name="l01335"></a>01335 <span class="preprocessor">#endif</span>
- <a name="l01336"></a>01336 <span class="preprocessor"></span>
- <a name="l01337"></a>01337 <span class="comment">// matrixRdWtSz_Data<dataType> vStarSource=-NHigh.T()*DaeHigh;</span>
- <a name="l01338"></a>01338 <span class="comment">// solver.A()=EHigh;</span>
- <a name="l01339"></a>01339 <span class="comment">// matrixRdWtSz_Data<dataType> PsiDyad=PsiHigh*PsiHigh.T();</span>
- <a name="l01340"></a>01340 <span class="comment">// dataType tracePsi=0.0;</span>
- <a name="l01341"></a>01341 <span class="comment">// dataType traceE=0.0;</span>
- <a name="l01342"></a>01342 <span class="comment">// for(unsigned long i=0;i<rCnt;i++)</span>
- <a name="l01343"></a>01343 <span class="comment">// {</span>
- <a name="l01344"></a>01344 <span class="comment">// tracePsi+=PsiDyad.entry(i,i);</span>
- <a name="l01345"></a>01345 <span class="comment">// traceE+=solver.A().entry(i,i);</span>
- <a name="l01346"></a>01346 <span class="comment">// }</span>
- <a name="l01347"></a>01347 <span class="comment">// solver.A()+=(traceE/tracePsi)*PsiDyad;</span>
- <a name="l01348"></a>01348 <span class="comment">// solver.B()=vStarSource;</span>
- <a name="l01349"></a>01349 <span class="comment">// solver.solve();</span>
- <a name="l01350"></a>01350 <span class="comment">// </span>
- <a name="l01351"></a>01351 <span class="comment">// vStar_adjointHigh=solver.B();</span>
- <a name="l01352"></a>01352
- <a name="l01353"></a>01353 }
- <a name="l01354"></a>01354
- <a name="l01355"></a>01355 <span class="keywordtype">void</span> buildLowMatrix(<a class="code" href="classmesh.html">mesh<dataType></a>* cxMeshLow_in)
- <a name="l01356"></a>01356 {
- <a name="l01357"></a>01357
- <a name="l01358"></a>01358 cxMeshLow=cxMeshLow_in;
- <a name="l01359"></a>01359
- <a name="l01360"></a>01360 <span class="keywordflow">if</span>(cxMeshLow==NULL)
- <a name="l01361"></a>01361 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::buildHighLowMatrix(): The mesh has not been specified"</span>);
- <a name="l01362"></a>01362
- <a name="l01363"></a>01363 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l01364"></a>01364 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a4a19abf94aa1abd08eb8b6fdd2f4662e">TIMEALG::vabsMeshLinkStart</a>();
- <a name="l01365"></a>01365 <span class="preprocessor">#endif</span>
- <a name="l01366"></a>01366 <span class="preprocessor"></span>
- <a name="l01367"></a>01367 <span class="comment">// retrieve the size</span>
- <a name="l01368"></a>01368 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> ndCnt;
- <a name="l01369"></a>01369 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> elmCnt;
- <a name="l01370"></a>01370 cxMeshLow->size(ndCnt,elmCnt);
- <a name="l01371"></a>01371
- <a name="l01372"></a>01372 <span class="comment">// size all the matrices</span>
- <a name="l01373"></a>01373 ELow.resize(ndCnt*3);
- <a name="l01374"></a>01374 DaeLow.resize(ndCnt*3,4);
- <a name="l01375"></a>01375 HLow.resize(ndCnt*3,ndCnt*3);
- <a name="l01376"></a>01376 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l01377"></a>01377 <span class="preprocessor"></span> PsiLow.resize(ndCnt*3,4);
- <a name="l01378"></a>01378 <span class="preprocessor">#endif</span>
- <a name="l01379"></a>01379 <span class="preprocessor"></span>
- <a name="l01380"></a>01380 <span class="comment">// create all the nodes and elements</span>
- <a name="l01381"></a>01381 commonNodesLow.resize(ndCnt);
- <a name="l01382"></a>01382 elementNodesLow.resize(ndCnt);
- <a name="l01383"></a>01383 elementsLow.resize(elmCnt);
- <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><ndCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01385"></a>01385 {
- <a name="l01386"></a>01386 commonNodesLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setX(cxMeshLow->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).x);
- <a name="l01387"></a>01387 commonNodesLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setY(cxMeshLow->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).y);
- <a name="l01388"></a>01388 <span class="comment">// for(unsigned long j=0;j<3;j++)</span>
- <a name="l01389"></a>01389 <span class="comment">// {</span>
- <a name="l01390"></a>01390 <span class="comment">// for(unsigned long k=0;k<4;k++)</span>
- <a name="l01391"></a>01391 <span class="comment">// commonNodesLow[i].setWarping(j,k,&(vLow.entry(i*3+j,k)));</span>
- <a name="l01392"></a>01392 <span class="comment">// }</span>
- <a name="l01393"></a>01393 elementNodesLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].resize(cxMeshLow->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData.size());
- <a name="l01394"></a>01394 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<elementNodesLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].size();j++)
- <a name="l01395"></a>01395 elementNodesLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>][j].setH(cxMeshLow->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData[j].h_over_H).setAng(cxMeshLow->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData[j].angle).setCommon(&(commonNodesLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]));
- <a name="l01396"></a>01396 }
- <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><elmCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01398"></a>01398 {
- <a name="l01399"></a>01399 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();j++)
- <a name="l01400"></a>01400 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setNode(j,&(elementNodesLow[cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID][cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].dataID]));
- <a name="l01401"></a>01401 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setMatl(cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).material);
- <a name="l01402"></a>01402 }
- <a name="l01403"></a>01403
- <a name="l01404"></a>01404 <span class="comment">// set all the matrices in the elements</span>
- <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><elmCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01406"></a>01406 {
- <a name="l01407"></a>01407 <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData<dataType></a>* EMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData<dataType></a>(cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3);
- <a name="l01408"></a>01408 <span class="keywordflow">if</span>(EMatrix==NULL)
- <a name="l01409"></a>01409 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::buildMatrix(): Failed to allocate memory for EMatrix"</span>);
- <a name="l01410"></a>01410 <a class="code" href="classmatrixRdWt__pData.html">matrixRdWt_pData<dataType></a>* DaeMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWt__pData.html">matrixRdWt_pData<dataType></a>(cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3,4);
- <a name="l01411"></a>01411 <span class="keywordflow">if</span>(DaeMatrix==NULL)
- <a name="l01412"></a>01412 {
- <a name="l01413"></a>01413 <span class="keyword">delete</span> EMatrix;
- <a name="l01414"></a>01414 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::buildMatrix(): Failed to allocate memory for DaeMatrix"</span>);
- <a name="l01415"></a>01415 }
- <a name="l01416"></a>01416 <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData<dataType></a>* HMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData<dataType></a>(cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3);
- <a name="l01417"></a>01417 <span class="keywordflow">if</span>(HMatrix==NULL)
- <a name="l01418"></a>01418 {
- <a name="l01419"></a>01419 <span class="keyword">delete</span> EMatrix;
- <a name="l01420"></a>01420 <span class="keyword">delete</span> DaeMatrix;
- <a name="l01421"></a>01421 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::buildMatrix(): Failed to allocate memory for HMatrix"</span>);
- <a name="l01422"></a>01422 }
- <a name="l01423"></a>01423 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();j++)
- <a name="l01424"></a>01424 {
- <a name="l01425"></a>01425 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k<cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();k++)
- <a name="l01426"></a>01426 {
- <a name="l01427"></a>01427 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> m=0;m<3;m++)
- <a name="l01428"></a>01428 {
- <a name="l01429"></a>01429 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> n=0;n<3;n++)
- <a name="l01430"></a>01430 {
- <a name="l01431"></a>01431 EMatrix-><a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,k*3+n,&(ELow.entry(cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,cxMeshLow->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>
- <a name="l01432"></a>01432 HMatrix-><a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,k*3+n,&(HLow.entry(cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[k].nodeID*3+n)),<span class="keyword">false</span>);
- <a name="l01433"></a>01433 }
- <a name="l01434"></a>01434 }
- <a name="l01435"></a>01435 }
- <a name="l01436"></a>01436 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> m=0;m<3;m++)
- <a name="l01437"></a>01437 {
- <a name="l01438"></a>01438 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> n=0;n<4;n++)
- <a name="l01439"></a>01439 {
- <a name="l01440"></a>01440 DaeMatrix-><a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,n,&(DaeLow.entry(cxMeshLow->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,n)),<span class="keyword">false</span>);
- <a name="l01441"></a>01441 <span class="comment">// PsiMatrix->setPointer(j*3+m,n,&(Psi.entry(cxMesh->getElement(i).nodeHndl[j].nodeID*3+m,n)),false);</span>
- <a name="l01442"></a>01442 }
- <a name="l01443"></a>01443 }
- <a name="l01444"></a>01444 }
- <a name="l01445"></a>01445 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setEMatrix(EMatrix,<span class="keyword">true</span>);
- <a name="l01446"></a>01446 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setDeaMatrix(DaeMatrix,<span class="keyword">true</span>);
- <a name="l01447"></a>01447 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setHMatrix(HMatrix,<span class="keyword">true</span>);
- <a name="l01448"></a>01448 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setDeeMatrix(&DeeLow);
- <a name="l01449"></a>01449 <span class="comment">// elements[i].setPsiMatrix(PsiMatrix);</span>
- <a name="l01450"></a>01450 }
- <a name="l01451"></a>01451
- <a name="l01452"></a>01452 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l01453"></a>01453 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a19a22177645e1866a8cb9217ad98b726">TIMEALG::vabsMeshLinkStop</a>();
- <a name="l01454"></a>01454 <a class="code" href="namespaceTIMEALG.html#a47cb7df0449fa5c03c285d3e92d3aa2d">TIMEALG::vabsMtxCalcStart</a>();
- <a name="l01455"></a>01455 <span class="preprocessor">#endif</span>
- <a name="l01456"></a>01456 <span class="preprocessor"></span>
- <a name="l01457"></a>01457 <span class="comment">// initialize the matrices</span>
- <a name="l01458"></a>01458 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
- <a name="l01459"></a>01459 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
- <a name="l01460"></a>01460 HLow.size(rCnt,cCnt);
- <a name="l01461"></a>01461 HLow=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l01462"></a>01462 DaeLow.size(rCnt,cCnt);
- <a name="l01463"></a>01463 DaeLow=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l01464"></a>01464 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l01465"></a>01465 <span class="preprocessor"></span> PsiLow.size(rCnt,cCnt);
- <a name="l01466"></a>01466 PsiLow=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l01467"></a>01467 <span class="preprocessor">#endif</span>
- <a name="l01468"></a>01468 <span class="preprocessor"></span> cCnt=rCnt=DeeLow.size();
- <a name="l01469"></a>01469 DeeLow=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l01470"></a>01470 cCnt=rCnt=ELow.size();
- <a name="l01471"></a>01471 ELow=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l01472"></a>01472
- <a name="l01473"></a>01473 <span class="comment">// Create the matrices</span>
- <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><elementsLow.size();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01475"></a>01475 {
- <a name="l01476"></a>01476 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addE();
- <a name="l01477"></a>01477 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addDee();
- <a name="l01478"></a>01478 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addDae();
- <a name="l01479"></a>01479 elementsLow[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addH();
- <a name="l01480"></a>01480 }
- <a name="l01481"></a>01481
- <a name="l01482"></a>01482 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l01483"></a>01483 <span class="preprocessor"></span><span class="comment">// // create the Psi matrix</span>
- <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));
- <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><ndCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01486"></a>01486 {
- <a name="l01487"></a>01487 PsiLow.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3,0)=one;
- <a name="l01488"></a>01488 PsiLow.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1,1)=one;
- <a name="l01489"></a>01489 PsiLow.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2,2)=one;
- <a name="l01490"></a>01490 PsiLow.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1,3)=cxMeshLow->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).y;
- <a name="l01491"></a>01491 PsiLow.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2,3)=-cxMeshLow->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).x;
- <a name="l01492"></a>01492 }
- <a name="l01493"></a>01493 <span class="preprocessor">#endif</span>
- <a name="l01494"></a>01494 <span class="preprocessor"></span>
- <a name="l01495"></a>01495 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l01496"></a>01496 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#abb3dfe1409ead9ab389b11970c1ed9bb">TIMEALG::vabsMtxCalcStop</a>();
- <a name="l01497"></a>01497 <a class="code" href="namespaceTIMEALG.html#a64fad33a25509725cf641d6f6d9c6f63">TIMEALG::vabsNCalcStart</a>();
- <a name="l01498"></a>01498 <span class="preprocessor">#endif</span>
- <a name="l01499"></a>01499 <span class="preprocessor"></span>
- <a name="l01500"></a>01500 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> PsiTHPsi=PsiLow.<a class="code" href="classmatrixRdWtStaticSqr__Data.html#a3db65c97e3f5de1fe52b5f0831e11176">T</a>()*HLow*PsiLow;
- <a name="l01501"></a>01501 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> PsiTHPsi_Inverse=PsiTHPsi.<a class="code" href="classmatrixSqr.html#a991ebad568b11587f75c85cc3b8da408">inverse</a>();
- <a name="l01502"></a>01502 NLow=(<a class="code" href="classmatrix.html">matrix<dataType>::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>();
- <a name="l01503"></a>01503
- <a name="l01504"></a>01504 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l01505"></a>01505 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a294dfa8c6f83f364d880655b35f8531f">TIMEALG::vabsNCalcStop</a>();
- <a name="l01506"></a>01506 <span class="preprocessor">#endif</span>
- <a name="l01507"></a>01507 <span class="preprocessor"></span>
- <a name="l01508"></a>01508 <span class="comment">// matrixRdWtSz_Data<dataType> vStarSource=-NLow.T()*DaeLow;</span>
- <a name="l01509"></a>01509 <span class="comment">// solver.A()=ELow;</span>
- <a name="l01510"></a>01510 <span class="comment">// matrixRdWtSz_Data<dataType> PsiDyad=PsiLow*PsiLow.T();</span>
- <a name="l01511"></a>01511 <span class="comment">// dataType tracePsi=0.0;</span>
- <a name="l01512"></a>01512 <span class="comment">// dataType traceE=0.0;</span>
- <a name="l01513"></a>01513 <span class="comment">// for(unsigned long i=0;i<rCnt;i++)</span>
- <a name="l01514"></a>01514 <span class="comment">// {</span>
- <a name="l01515"></a>01515 <span class="comment">// tracePsi+=PsiDyad.entry(i,i);</span>
- <a name="l01516"></a>01516 <span class="comment">// traceE+=solver.A().entry(i,i);</span>
- <a name="l01517"></a>01517 <span class="comment">// }</span>
- <a name="l01518"></a>01518 <span class="comment">// solver.A()+=(traceE/tracePsi)*PsiDyad;</span>
- <a name="l01519"></a>01519 <span class="comment">// solver.B()=vStarSource;</span>
- <a name="l01520"></a>01520 <span class="comment">// solver.solve();</span>
- <a name="l01521"></a>01521 <span class="comment">// </span>
- <a name="l01522"></a>01522 <span class="comment">// vStar_adjointLow=solver.B();</span>
- <a name="l01523"></a>01523
- <a name="l01524"></a>01524
- <a name="l01525"></a>01525 }
- <a name="l01526"></a>01526
- <a name="l01527"></a>01527 <span class="keywordtype">void</span> matrixGradients(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> step)
- <a name="l01528"></a>01528 {
- <a name="l01529"></a>01529 <span class="preprocessor">#ifdef TIME_ADJOINT_CALCULATION</span>
- <a name="l01530"></a>01530 <span class="preprocessor"></span>
- <a name="l01531"></a>01531 <a class="code" href="classTIMER_1_1timer.html">TIMER::timer</a> tmp;
- <a name="l01532"></a>01532
- <a name="l01533"></a>01533 tmp.<a class="code" href="classTIMER_1_1timer.html#ae4e539468242134aee07316d713d1200">start</a>();
- <a name="l01534"></a>01534
- <a name="l01535"></a>01535 <span class="preprocessor">#endif</span>
- <a name="l01536"></a>01536 <span class="preprocessor"></span>
- <a name="l01537"></a>01537 dDae_dy=(DaeHigh-DaeLow)*(1.0/(2.0*step));
- <a name="l01538"></a>01538 <span class="comment">// dH_dy=(HHigh-HLow)*(1.0/(2.0*step));</span>
- <a name="l01539"></a>01539 <span class="comment">// dPsi_dy=(PsiHigh-PsiLow)*(1.0/(2.0*step));</span>
- <a name="l01540"></a>01540 dDee_dy=(DeeHigh-DeeLow)*(1.0/(2.0*step));
- <a name="l01541"></a>01541 dE_dy=(EHigh-ELow)*(1.0/(2.0*step));
- <a name="l01542"></a>01542 dN_dy=(NHigh-NLow)*(1.0/(2.0*step));
- <a name="l01543"></a>01543
- <a name="l01544"></a>01544 <span class="preprocessor">#ifdef TIME_ADJOINT_CALCULATION</span>
- <a name="l01545"></a>01545 <span class="preprocessor"></span>
- <a name="l01546"></a>01546 tmp.<a class="code" href="classTIMER_1_1timer.html#afc79eeb3c824bcffc5f4d351407dd32f">stop</a>();
- <a name="l01547"></a>01547 std::cout << <span class="stringliteral">"Time for matrix gradients: "</span> << tmp.<a class="code" href="classTIMER_1_1timer.html#a438889a9c3d0ad0e730a3b54452a964c">microSeconds</a>() << std::endl;
- <a name="l01548"></a>01548
- <a name="l01549"></a>01549 <span class="preprocessor">#endif</span>
- <a name="l01550"></a>01550 <span class="preprocessor"></span>
- <a name="l01551"></a>01551 }
- <a name="l01552"></a>01552
- <a name="l01553"></a>01553
- <a name="l01554"></a>01554
- <a name="l01555"></a>01555
- <a name="l01556"></a>01556
- <a name="l01557"></a>01557
- <a name="l01558"></a>01558
- <a name="l01559"></a>01559
- <a name="l01560"></a>01560
- <a name="l01561"></a>01561
- <a name="l01562"></a>01562
- <a name="l01563"></a>01563
- <a name="l01564"></a>01564
- <a name="l01565"></a>01565
- <a name="l01566"></a>01566
- <a name="l01567"></a>01567
- <a name="l01568"></a>01568 <span class="keywordtype">void</span> calcGradient()
- <a name="l01569"></a>01569 {
- <a name="l01570"></a>01570
- <a name="l01571"></a>01571 <span class="preprocessor">#ifdef TIME_ADJOINT_CALCULATION</span>
- <a name="l01572"></a>01572 <span class="preprocessor"></span>
- <a name="l01573"></a>01573 <a class="code" href="classTIMER_1_1timer.html">TIMER::timer</a> tmp;
- <a name="l01574"></a>01574
- <a name="l01575"></a>01575 tmp.<a class="code" href="classTIMER_1_1timer.html#ae4e539468242134aee07316d713d1200">start</a>();
- <a name="l01576"></a>01576
- <a name="l01577"></a>01577 <span class="preprocessor">#endif</span>
- <a name="l01578"></a>01578 <span class="preprocessor"></span>
- <a name="l01579"></a>01579 <span class="comment">// unsigned long rCnt;</span>
- <a name="l01580"></a>01580 <span class="comment">// unsigned long cCnt;</span>
- <a name="l01581"></a>01581 <span class="comment">// </span>
- <a name="l01582"></a>01582 <span class="comment">// H.size(rCnt,cCnt);</span>
- <a name="l01583"></a>01583
- <a name="l01584"></a>01584 <span class="comment">// matrixRdWtStaticSqr_Data<dataType,4> inv=Psi.T()*H*Psi;</span>
- <a name="l01585"></a>01585 <span class="comment">// inv=inv.inverse();</span>
- <a name="l01586"></a>01586 <span class="comment">// </span>
- <a name="l01587"></a>01587 <span class="comment">// tmp.stop();</span>
- <a name="l01588"></a>01588 <span class="comment">// std::cout << "Time for inverse: " << tmp.microSeconds() << std::endl;</span>
- <a name="l01589"></a>01589 <span class="comment">// tmp.reset();</span>
- <a name="l01590"></a>01590 <span class="comment">// tmp.start();</span>
- <a name="l01591"></a>01591 <span class="comment">// </span>
- <a name="l01592"></a>01592 <span class="comment">// matrixRdWtSz_Data<dataType> outerProduct=Psi*inv*Psi.T();</span>
- <a name="l01593"></a>01593 <span class="comment">// </span>
- <a name="l01594"></a>01594 <span class="comment">// tmp.stop();</span>
- <a name="l01595"></a>01595 <span class="comment">// std::cout << "Time for outer product: " << tmp.microSeconds() << std::endl;</span>
- <a name="l01596"></a>01596 <span class="comment">// tmp.reset();</span>
- <a name="l01597"></a>01597 <span class="comment">// tmp.start();</span>
- <a name="l01598"></a>01598 <span class="comment">// </span>
- <a name="l01599"></a>01599 <span class="comment">// matrixRdWtSz_Data<dataType> N=-outerProduct*H;</span>
- <a name="l01600"></a>01600 <span class="comment">// </span>
- <a name="l01601"></a>01601 <span class="comment">// tmp.stop();</span>
- <a name="l01602"></a>01602 <span class="comment">// std::cout << "Time for N=-outerProduct*H: " << tmp.microSeconds() << std::endl;</span>
- <a name="l01603"></a>01603 <span class="comment">// tmp.reset();</span>
- <a name="l01604"></a>01604 <span class="comment">// tmp.start();</span>
- <a name="l01605"></a>01605 <span class="comment">// </span>
- <a name="l01606"></a>01606 <span class="comment">// for(unsigned long i=0;i<rCnt;i++)</span>
- <a name="l01607"></a>01607 <span class="comment">// N.entry(i,i)+=1.0;</span>
- <a name="l01608"></a>01608 <span class="comment">// // matrixRdWtSz_Data<dataType> N=matrix<dataType>::identityMatrix(rCnt)-outerProduct*H;</span>
- <a name="l01609"></a>01609 <span class="comment">// </span>
- <a name="l01610"></a>01610 <span class="comment">// tmp.stop();</span>
- <a name="l01611"></a>01611 <span class="comment">// std::cout << "Time for N+I: " << tmp.microSeconds() << std::endl;</span>
- <a name="l01612"></a>01612 <span class="comment">// tmp.reset();</span>
- <a name="l01613"></a>01613 <span class="comment">// tmp.start();</span>
- <a name="l01614"></a>01614 <span class="comment">// </span>
- <a name="l01615"></a>01615 <span class="comment">// matrixRdWtSz_Data<dataType> innerPrime=dPsi_dy.T()*H*Psi;</span>
- <a name="l01616"></a>01616 <span class="comment">// innerPrime=innerPrime+innerPrime.T();</span>
- <a name="l01617"></a>01617 <span class="comment">// </span>
- <a name="l01618"></a>01618 <span class="comment">// tmp.stop();</span>
- <a name="l01619"></a>01619 <span class="comment">// std::cout << "Time for innerPrime: " << tmp.microSeconds() << std::endl;</span>
- <a name="l01620"></a>01620 <span class="comment">// tmp.reset();</span>
- <a name="l01621"></a>01621 <span class="comment">// tmp.start();</span>
- <a name="l01622"></a>01622 <span class="comment">// </span>
- <a name="l01623"></a>01623 <span class="comment">// matrixRdWtSz_Data<dataType> outerPrime=dPsi_dy*inv*Psi.T();</span>
- <a name="l01624"></a>01624 <span class="comment">// outerPrime=outerPrime+outerPrime.T();</span>
- <a name="l01625"></a>01625 <span class="comment">// </span>
- <a name="l01626"></a>01626 <span class="comment">// tmp.stop();</span>
- <a name="l01627"></a>01627 <span class="comment">// std::cout << "Time for outerPrime: " << tmp.microSeconds() << std::endl;</span>
- <a name="l01628"></a>01628 <span class="comment">// tmp.reset();</span>
- <a name="l01629"></a>01629 <span class="comment">// tmp.start();</span>
- <a name="l01630"></a>01630 <span class="comment">// </span>
- <a name="l01631"></a>01631 <span class="comment">// dN_dy.T()=</span>
- <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>
- <a name="l01633"></a>01633 <span class="comment">// </span>
- <a name="l01634"></a>01634 <span class="comment">// // dN_dy=</span>
- <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>
- <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>
- <a name="l01637"></a>01637 <span class="comment">// </span>
- <a name="l01638"></a>01638 <span class="comment">// tmp.stop();</span>
- <a name="l01639"></a>01639 <span class="comment">// std::cout << "Time for dN_dy: " << tmp.microSeconds() << std::endl;</span>
- <a name="l01640"></a>01640 <span class="comment">// tmp.reset();</span>
- <a name="l01641"></a>01641 <span class="comment">// tmp.start();</span>
- <a name="l01642"></a>01642
- <a name="l01643"></a>01643 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> crossTerm=Dae.T()*dN_dy*vStar_adjoint+dDae_dy.T()*N*vStar_adjoint;
- <a name="l01644"></a>01644 crossTerm=crossTerm+crossTerm.<a class="code" href="classmatrixRdWtSz__Data.html#ae1c7af296930751d1ceaf95429e9bb57">T</a>();
- <a name="l01645"></a>01645
- <a name="l01646"></a>01646 <span class="preprocessor">#ifdef TIME_ADJOINT_CALCULATION</span>
- <a name="l01647"></a>01647 <span class="preprocessor"></span>
- <a name="l01648"></a>01648 tmp.<a class="code" href="classTIMER_1_1timer.html#afc79eeb3c824bcffc5f4d351407dd32f">stop</a>();
- <a name="l01649"></a>01649 std::cout << <span class="stringliteral">"Time for cross-term: "</span> << tmp.<a class="code" href="classTIMER_1_1timer.html#a438889a9c3d0ad0e730a3b54452a964c">microSeconds</a>() << std::endl;
- <a name="l01650"></a>01650 tmp.<a class="code" href="classTIMER_1_1timer.html#aa557185a3e966e14014b76e40727784f">reset</a>();
- <a name="l01651"></a>01651 tmp.<a class="code" href="classTIMER_1_1timer.html#ae4e539468242134aee07316d713d1200">start</a>();
- <a name="l01652"></a>01652
- <a name="l01653"></a>01653 <span class="preprocessor">#endif</span>
- <a name="l01654"></a>01654 <span class="preprocessor"></span> dC_dy=vStar_adjoint.T()*dE_dy*vStar_adjoint+dDee_dy+crossTerm;
- <a name="l01655"></a>01655
- <a name="l01656"></a>01656 <span class="comment">// dC_dy=</span>
- <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>
- <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>
- <a name="l01659"></a>01659
- <a name="l01660"></a>01660 <span class="preprocessor">#ifdef TIME_ADJOINT_CALCULATION</span>
- <a name="l01661"></a>01661 <span class="preprocessor"></span>
- <a name="l01662"></a>01662 tmp.<a class="code" href="classTIMER_1_1timer.html#afc79eeb3c824bcffc5f4d351407dd32f">stop</a>();
- <a name="l01663"></a>01663 std::cout << <span class="stringliteral">"Time for dC_dy: "</span> << tmp.<a class="code" href="classTIMER_1_1timer.html#a438889a9c3d0ad0e730a3b54452a964c">microSeconds</a>() << std::endl;
- <a name="l01664"></a>01664 tmp.<a class="code" href="classTIMER_1_1timer.html#aa557185a3e966e14014b76e40727784f">reset</a>();
- <a name="l01665"></a>01665 tmp.<a class="code" href="classTIMER_1_1timer.html#ae4e539468242134aee07316d713d1200">start</a>();
- <a name="l01666"></a>01666
- <a name="l01667"></a>01667 <span class="preprocessor">#endif</span>
- <a name="l01668"></a>01668 <span class="preprocessor"></span>
- <a name="l01669"></a>01669 }
- <a name="l01670"></a>01670
- <a name="l01671"></a>01671 <span class="comment">// matrixRdWtSz_Data<dataType> getFailAdjointSource(matrix<dataType>& Gamma_a)</span>
- <a name="l01672"></a>01672 <span class="comment">// {</span>
- <a name="l01673"></a>01673 <span class="comment">// unsigned long rCnt;</span>
- <a name="l01674"></a>01674 <span class="comment">// unsigned long cCnt;</span>
- <a name="l01675"></a>01675 <span class="comment">// </span>
- <a name="l01676"></a>01676 <span class="comment">// H.size(rCnt,cCnt);</span>
- <a name="l01677"></a>01677 <span class="comment">// cCnt=6;</span>
- <a name="l01678"></a>01678 <span class="comment">// </span>
- <a name="l01679"></a>01679 <span class="comment">// matrixRdWtSz_Data<dataType> mtx(rCnt,cCnt);</span>
- <a name="l01680"></a>01680 <span class="comment">// </span>
- <a name="l01681"></a>01681 <span class="comment">// for(unsigned long i=0;i<rCnt;i++)</span>
- <a name="l01682"></a>01682 <span class="comment">// {</span>
- <a name="l01683"></a>01683 <span class="comment">// for(unsigned long j=0;j<cCnt;j++)</span>
- <a name="l01684"></a>01684 <span class="comment">// {</span>
- <a name="l01685"></a>01685 <span class="comment">// mtx.entry(i,j)=0.0;</span>
- <a name="l01686"></a>01686 <span class="comment">// }</span>
- <a name="l01687"></a>01687 <span class="comment">// }</span>
- <a name="l01688"></a>01688 <span class="comment">// </span>
- <a name="l01689"></a>01689 <span class="comment">// for(unsigned long i=0;i<4;i++)</span>
- <a name="l01690"></a>01690 <span class="comment">// {</span>
- <a name="l01691"></a>01691 <span class="comment">// for(unsigned long j=0;j<3;j++)</span>
- <a name="l01692"></a>01692 <span class="comment">// {</span>
- <a name="l01693"></a>01693 <span class="comment">// unsigned long col=i*3+j;</span>
- <a name="l01694"></a>01694 <span class="comment">// unsigned long row=cxMesh->getElement(maxElm).nodeHndl[i].nodeID*3+j;</span>
- <a name="l01695"></a>01695 <span class="comment">// for(unsigned long k=0;k<cCnt;k++)</span>
- <a name="l01696"></a>01696 <span class="comment">// mtx.entry(row,k)=Gamma_a.entry(k,col);</span>
- <a name="l01697"></a>01697 <span class="comment">// }</span>
- <a name="l01698"></a>01698 <span class="comment">// }</span>
- <a name="l01699"></a>01699 <span class="comment">// </span>
- <a name="l01700"></a>01700 <span class="comment">// mtx=N.T()*mtx;</span>
- <a name="l01701"></a>01701 <span class="comment">// </span>
- <a name="l01702"></a>01702 <span class="comment">// return mtx;</span>
- <a name="l01703"></a>01703 <span class="comment">// }</span>
- <a name="l01704"></a>01704
- <a name="l01705"></a>01705 <span class="keywordtype">void</span> getFailAdjoint(<a class="code" href="classmatrix.html">matrix<dataType></a>& Gamma_a)
- <a name="l01706"></a>01706 {
- <a name="l01707"></a>01707 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
- <a name="l01708"></a>01708 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
- <a name="l01709"></a>01709
- <a name="l01710"></a>01710 H.size(rCnt,cCnt);
- <a name="l01711"></a>01711 cCnt=6;
- <a name="l01712"></a>01712
- <a name="l01713"></a>01713 <a class="code" href="classmatrixMatrixSolver.html">matrixMatrixSolver</a> slvr(rCnt,cCnt);
- <a name="l01714"></a>01714 slvr.<a class="code" href="classmatrixMatrixSolver.html#a06093225d93b903dc93612fb23ddadf2">A</a>()=ETDyad;
- <a name="l01715"></a>01715
- <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><rCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01717"></a>01717 {
- <a name="l01718"></a>01718 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<cCnt;j++)
- <a name="l01719"></a>01719 {
- <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;
- <a name="l01721"></a>01721 }
- <a name="l01722"></a>01722 }
- <a name="l01723"></a>01723
- <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><4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01725"></a>01725 {
- <a name="l01726"></a>01726 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<3;j++)
- <a name="l01727"></a>01727 {
- <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;
- <a name="l01729"></a>01729 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> row=cxMesh->getElement(maxElm).nodeHndl[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].nodeID*3+j;
- <a name="l01730"></a>01730 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k<cCnt;k++)
- <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);
- <a name="l01732"></a>01732 }
- <a name="l01733"></a>01733 }
- <a name="l01734"></a>01734
- <a name="l01735"></a>01735 <span class="comment">// matrixRdWtStaticSqr_Data<dataType,4> PsiTHPsi=Psi.T()*H*Psi;</span>
- <a name="l01736"></a>01736 <span class="comment">// matrixRdWtStaticSqr_Data<dataType,4> PsiTHPsi_Inverse=PsiTHPsi.inverse();</span>
- <a name="l01737"></a>01737 <span class="comment">// matrixRdWtSzSqr_Data<dataType> prePostMatrix=matrix<dataType>::identityMatrix(rCnt)-H*Psi*PsiTHPsi_Inverse*Psi.T();</span>
- <a name="l01738"></a>01738 <span class="comment">// N=prePostMatrix.T();</span>
- <a name="l01739"></a>01739
- <a name="l01740"></a>01740 <span class="comment">// std::cout << "This is N" << std::endl;</span>
- <a name="l01741"></a>01741 <span class="comment">// printMatrix(N);</span>
- <a name="l01742"></a>01742
- <a name="l01743"></a>01743 <span class="comment">// std::cout << "This is ET" << std::endl;</span>
- <a name="l01744"></a>01744 <span class="comment">// printMatrix(ET);</span>
- <a name="l01745"></a>01745
- <a name="l01746"></a>01746 <span class="comment">// std::cout << "This is gamma" << std::endl;</span>
- <a name="l01747"></a>01747 <span class="comment">// printMatrix(Gamma_a);</span>
- <a name="l01748"></a>01748
- <a name="l01749"></a>01749 <span class="comment">// std::cout << "This is nulled source" << std::endl;</span>
- <a name="l01750"></a>01750 <span class="comment">// printMatrix(slvr.B());</span>
- <a name="l01751"></a>01751
- <a name="l01752"></a>01752 <span class="comment">// std::cout << "This is N.T()*B" << std::endl;</span>
- <a name="l01753"></a>01753 <span class="comment">// printMatrix(N.T()*slvr.B());</span>
- <a name="l01754"></a>01754
- <a name="l01755"></a>01755
- <a name="l01756"></a>01756 <span class="comment">// vabsSvdSolver svdSolve(rCnt,rCnt);</span>
- <a name="l01757"></a>01757
- <a name="l01758"></a>01758 <span class="comment">// unsigned long a,b;</span>
- <a name="l01759"></a>01759 <span class="comment">// </span>
- <a name="l01760"></a>01760 <span class="comment">// std::cout << "Hey 1" << std::endl;</span>
- <a name="l01761"></a>01761 <span class="comment">// std::cout << rCnt << " " << cCnt << std::endl;</span>
- <a name="l01762"></a>01762 <span class="comment">// svdSolve.A().size(a,b);</span>
- <a name="l01763"></a>01763 <span class="comment">// std::cout << a << " " << b << std::endl;</span>
- <a name="l01764"></a>01764 <span class="comment">// a=b=ET.size();</span>
- <a name="l01765"></a>01765 <span class="comment">// std::cout << a << " " << b << std::endl;</span>
- <a name="l01766"></a>01766 <span class="comment">// svdSolve.A()=ET;</span>
- <a name="l01767"></a>01767 <span class="comment">// std::cout << "Hey 2" << std::endl;</span>
- <a name="l01768"></a>01768 <span class="comment">// svdSolve.solve();</span>
- <a name="l01769"></a>01769 <span class="comment">// </span>
- <a name="l01770"></a>01770 <span class="comment">// std::cout << "Hey 3" << std::endl;</span>
- <a name="l01771"></a>01771
- <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>();
- <a name="l01773"></a>01773
- <a name="l01774"></a>01774 <span class="comment">// std::cout << "Hey 4" << std::endl;</span>
- <a name="l01775"></a>01775 <span class="comment">// matrixRdWtSz_Data<dataType> src=slvr.B();</span>
- <a name="l01776"></a>01776 <span class="comment">// std::cout << "Hey 4" << std::endl;</span>
- <a name="l01777"></a>01777
- <a name="l01778"></a>01778 <span class="comment">// matrixRdWtSz_Data<double> src=slvr.B();</span>
- <a name="l01779"></a>01779
- <a name="l01780"></a>01780 <span class="comment">// std::cout << "Here is the ET projection" << std::endl;</span>
- <a name="l01781"></a>01781 <span class="comment">// printMatrix(Psi.T()*ET);</span>
- <a name="l01782"></a>01782
- <a name="l01783"></a>01783 <span class="comment">// std::cout << "Here is the source projection" << std::endl;</span>
- <a name="l01784"></a>01784 <span class="comment">// printMatrix(Psi.T()*slvr.B());</span>
- <a name="l01785"></a>01785
- <a name="l01786"></a>01786 <span class="comment">// std::cout << "Here is the source" << std::endl;</span>
- <a name="l01787"></a>01787 <span class="comment">// printMatrix(slvr.B());</span>
- <a name="l01788"></a>01788
- <a name="l01789"></a>01789 slvr.<a class="code" href="classmatrixMatrixSolver.html#a91ec4089eb228ec89bbe390eeeb899f4">solve</a>();
- <a name="l01790"></a>01790
- <a name="l01791"></a>01791 <span class="comment">// std::cout << "Hey 5" << std::endl;</span>
- <a name="l01792"></a>01792 <span class="comment">// </span>
- <a name="l01793"></a>01793 <span class="comment">// std::cout << "Here is the difference between the svd and the solve" << std::endl;</span>
- <a name="l01794"></a>01794 <span class="comment">// printMatrix(svdSolve.inverse()*src-slvr.B());</span>
- <a name="l01795"></a>01795 <span class="comment">// </span>
- <a name="l01796"></a>01796 <span class="comment">// std::cout << "Hey 6" << std::endl;</span>
- <a name="l01797"></a>01797 <span class="comment">// </span>
- <a name="l01798"></a>01798 <span class="comment">// std::cout << "Here is the dyad solution" << std::endl;</span>
- <a name="l01799"></a>01799 <span class="comment">// printMatrix(slvr.B());</span>
- <a name="l01800"></a>01800 <span class="comment">// </span>
- <a name="l01801"></a>01801 <span class="comment">// std::cout << "Hey 7" << std::endl;</span>
- <a name="l01802"></a>01802 <span class="comment">// </span>
- <a name="l01803"></a>01803 <span class="comment">// std::cout << "Here is the svd solution" << std::endl;</span>
- <a name="l01804"></a>01804 <span class="comment">// printMatrix(svdSolve.inverse()*src);</span>
- <a name="l01805"></a>01805 <span class="comment">// </span>
- <a name="l01806"></a>01806 <span class="comment">// std::cout << "Hey 8" << std::endl;</span>
- <a name="l01807"></a>01807
- <a name="l01808"></a>01808 <span class="comment">// std::cout << "Here is the accuracy" << std::endl;</span>
- <a name="l01809"></a>01809 <span class="comment">// printMatrix(ET*slvr.B()-src);</span>
- <a name="l01810"></a>01810
- <a name="l01811"></a>01811 <span class="comment">// std::cout << "Here is the solution" << std::endl;</span>
- <a name="l01812"></a>01812 <span class="comment">// printMatrix(slvr.B());</span>
- <a name="l01813"></a>01813
- <a name="l01814"></a>01814 adjointFail=N*slvr.<a class="code" href="classmatrixMatrixSolver.html#a3d4eb5a5c9b8a11961f29cf94c0c64d7">B</a>();
- <a name="l01815"></a>01815
- <a name="l01816"></a>01816 <span class="comment">// std::cout << "Here is the adjointFail projection" << std::endl;</span>
- <a name="l01817"></a>01817 <span class="comment">// printMatrix(Psi.T()*adjointFail);</span>
- <a name="l01818"></a>01818
- <a name="l01819"></a>01819 <span class="comment">// std::cout << "Here is the adjointFail" << std::endl;</span>
- <a name="l01820"></a>01820 <span class="comment">// printMatrix(adjointFail);</span>
- <a name="l01821"></a>01821 }
- <a name="l01822"></a>01822
- <a name="l01823"></a>01823 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> elementPermuation(<a class="code" href="classmatrix.html">matrix<dataType></a>& mtx)
- <a name="l01824"></a>01824 {
- <a name="l01825"></a>01825 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt, cCnt;
- <a name="l01826"></a>01826 mtx.<a class="code" href="classmatrix.html#a3a26f3543df8cff3e662e949e8b9234d">size</a>(rCnt,cCnt);
- <a name="l01827"></a>01827
- <a name="l01828"></a>01828 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> retVal(12,cCnt);
- <a name="l01829"></a>01829
- <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><4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01831"></a>01831 {
- <a name="l01832"></a>01832 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<3;j++)
- <a name="l01833"></a>01833 {
- <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;
- <a name="l01835"></a>01835 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> inRow=cxMesh->getElement(maxElm).nodeHndl[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].nodeID*3+j;
- <a name="l01836"></a>01836 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k<cCnt;k++)
- <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);
- <a name="l01838"></a>01838 }
- <a name="l01839"></a>01839 }
- <a name="l01840"></a>01840 <span class="keywordflow">return</span> retVal;
- <a name="l01841"></a>01841 }
- <a name="l01842"></a>01842
- <a name="l01843"></a>01843 <span class="comment">// matrixRdWtSz_Data<dataType> r()</span>
- <a name="l01844"></a>01844 <span class="comment">// {</span>
- <a name="l01845"></a>01845 <span class="comment">// matrixRdWtSz_Data<dataType> retVal;</span>
- <a name="l01846"></a>01846 <span class="comment">// retVal=ET.T()*vStar_adjoint+N.T()*Dae;</span>
- <a name="l01847"></a>01847 <span class="comment">// return retVal;</span>
- <a name="l01848"></a>01848 <span class="comment">// }</span>
- <a name="l01849"></a>01849 <span class="comment">// </span>
- <a name="l01850"></a>01850 <span class="comment">// matrixRdWtSz_Data<dataType> rHigh()</span>
- <a name="l01851"></a>01851 <span class="comment">// {</span>
- <a name="l01852"></a>01852 <span class="comment">// matrixRdWtSz_Data<dataType> retVal;</span>
- <a name="l01853"></a>01853 <span class="comment">// retVal=EHigh*vStar_adjoint+NHigh.T()*DaeHigh;</span>
- <a name="l01854"></a>01854 <span class="comment">// return retVal;</span>
- <a name="l01855"></a>01855 <span class="comment">// }</span>
- <a name="l01856"></a>01856 <span class="comment">// </span>
- <a name="l01857"></a>01857 <span class="comment">// matrixRdWtSz_Data<dataType> rLow()</span>
- <a name="l01858"></a>01858 <span class="comment">// {</span>
- <a name="l01859"></a>01859 <span class="comment">// matrixRdWtSz_Data<dataType> retVal;</span>
- <a name="l01860"></a>01860 <span class="comment">// retVal=ELow*vStar_adjoint+NLow.T()*DaeLow;</span>
- <a name="l01861"></a>01861 <span class="comment">// return retVal;</span>
- <a name="l01862"></a>01862 <span class="comment">// }</span>
- <a name="l01863"></a>01863
- <a name="l01864"></a>01864
- <a name="l01865"></a>01865
- <a name="l01866"></a>01866
- <a name="l01867"></a>01867
- <a name="l01868"></a>01868
- <a name="l01869"></a>01869
- <a name="l01870"></a>01870
- <a name="l01871"></a>01871
- <a name="l01872"></a>01872
- <a name="l01873"></a>01873
- <a name="l01874"></a>01874
- <a name="l01875"></a>01875
- <a name="l01876"></a>01876
- <a name="l01877"></a>01877
- <a name="l01878"></a>01878
- <a name="l01879"></a>01879
- <a name="l01880"></a>01880
- <a name="l01881"></a>01881
- <a name="l01882"></a>01882
- <a name="l01883"></a>01883
- <a name="l01884"></a>01884 <span class="keyword">private</span>:
- <a name="l01885"></a>01885
- <a name="l01886"></a>01886 <span class="preprocessor">#endif</span>
- <a name="l01887"></a>01887 <span class="preprocessor"></span>
- <a name="l01888"></a>01888 <span class="keywordtype">void</span> buildMatrix()
- <a name="l01889"></a>01889 {
- <a name="l01890"></a>01890 <span class="keywordflow">if</span>(cxMesh==NULL)
- <a name="l01891"></a>01891 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::buildMatrix(): The mesh has not been specified"</span>);
- <a name="l01892"></a>01892
- <a name="l01893"></a>01893 <span class="comment">// retrieve the size</span>
- <a name="l01894"></a>01894 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> ndCnt;
- <a name="l01895"></a>01895 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> elmCnt;
- <a name="l01896"></a>01896 cxMesh->size(ndCnt,elmCnt);
- <a name="l01897"></a>01897
- <a name="l01898"></a>01898 <span class="comment">// size all the matrices</span>
- <a name="l01899"></a>01899 <span class="preprocessor">#ifdef SVD_BASED_VABS_SOLUTION</span>
- <a name="l01900"></a>01900 <span class="preprocessor"></span> solver.<a class="code" href="classmatrixMatrixSolver.html#ae0588f3a74c5876048a02226fc49c9af">resize</a>(ndCnt*3,ndCnt*3);
- <a name="l01901"></a>01901 <span class="preprocessor">#else</span>
- <a name="l01902"></a>01902 <span class="preprocessor"></span> solver.<a class="code" href="classmatrixMatrixSolver.html#ae0588f3a74c5876048a02226fc49c9af">resize</a>(ndCnt*3,4);
- <a name="l01903"></a>01903 <span class="preprocessor">#endif</span>
- <a name="l01904"></a>01904 <span class="preprocessor"></span> Dae.resize(ndCnt*3,4);
- <a name="l01905"></a>01905 H.resize(ndCnt*3,ndCnt*3);
- <a name="l01906"></a>01906 v.resize(ndCnt*3,4);
- <a name="l01907"></a>01907 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l01908"></a>01908 <span class="preprocessor"></span> Psi.resize(ndCnt*3,4);
- <a name="l01909"></a>01909 <span class="preprocessor">#endif</span>
- <a name="l01910"></a>01910 <span class="preprocessor"></span>
- <a name="l01911"></a>01911 <span class="comment">// create all the nodes and elements</span>
- <a name="l01912"></a>01912 commonNodes.resize(ndCnt);
- <a name="l01913"></a>01913 elementNodes.resize(ndCnt);
- <a name="l01914"></a>01914 elements.resize(elmCnt);
- <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><ndCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01916"></a>01916 {
- <a name="l01917"></a>01917 commonNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setX(cxMesh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).x);
- <a name="l01918"></a>01918 commonNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setY(cxMesh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).y);
- <a name="l01919"></a>01919 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<3;j++)
- <a name="l01920"></a>01920 {
- <a name="l01921"></a>01921 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k<4;k++)
- <a name="l01922"></a>01922 commonNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setWarping(j,k,&(v.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+j,k)));
- <a name="l01923"></a>01923 }
- <a name="l01924"></a>01924 elementNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].resize(cxMesh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData.size());
- <a name="l01925"></a>01925 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<elementNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].size();j++)
- <a name="l01926"></a>01926 elementNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>][j].setH(cxMesh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData[j].h_over_H).setAng(cxMesh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeData[j].angle).setCommon(&(commonNodes[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]));
- <a name="l01927"></a>01927 }
- <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><elmCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01929"></a>01929 {
- <a name="l01930"></a>01930 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();j++)
- <a name="l01931"></a>01931 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setNode(j,&(elementNodes[cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID][cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].dataID]));
- <a name="l01932"></a>01932 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setMatl(cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).material);
- <a name="l01933"></a>01933 }
- <a name="l01934"></a>01934
- <a name="l01935"></a>01935 <span class="comment">// set all the matrices in the elements</span>
- <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><elmCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l01937"></a>01937 {
- <a name="l01938"></a>01938 <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData<dataType></a>* EMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData<dataType></a>(cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3);
- <a name="l01939"></a>01939 <span class="keywordflow">if</span>(EMatrix==NULL)
- <a name="l01940"></a>01940 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::buildMatrix(): Failed to allocate memory for EMatrix"</span>);
- <a name="l01941"></a>01941 <a class="code" href="classmatrixRdWt__pData.html">matrixRdWt_pData<dataType></a>* DaeMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWt__pData.html">matrixRdWt_pData<dataType></a>(cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3,4);
- <a name="l01942"></a>01942 <span class="keywordflow">if</span>(DaeMatrix==NULL)
- <a name="l01943"></a>01943 {
- <a name="l01944"></a>01944 <span class="keyword">delete</span> EMatrix;
- <a name="l01945"></a>01945 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::buildMatrix(): Failed to allocate memory for DaeMatrix"</span>);
- <a name="l01946"></a>01946 }
- <a name="l01947"></a>01947 <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData<dataType></a>* HMatrix=<span class="keyword">new</span> <a class="code" href="classmatrixRdWtSqr__pData.html">matrixRdWtSqr_pData<dataType></a>(cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size()*3);
- <a name="l01948"></a>01948 <span class="keywordflow">if</span>(HMatrix==NULL)
- <a name="l01949"></a>01949 {
- <a name="l01950"></a>01950 <span class="keyword">delete</span> EMatrix;
- <a name="l01951"></a>01951 <span class="keyword">delete</span> DaeMatrix;
- <a name="l01952"></a>01952 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::buildMatrix(): Failed to allocate memory for HMatrix"</span>);
- <a name="l01953"></a>01953 }
- <a name="l01954"></a>01954 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();j++)
- <a name="l01955"></a>01955 {
- <a name="l01956"></a>01956 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> k=0;k<cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl.size();k++)
- <a name="l01957"></a>01957 {
- <a name="l01958"></a>01958 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> m=0;m<3;m++)
- <a name="l01959"></a>01959 {
- <a name="l01960"></a>01960 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> n=0;n<3;n++)
- <a name="l01961"></a>01961 {
- <a name="l01962"></a>01962 EMatrix-><a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,k*3+n,&(solver.<a class="code" href="classmatrixMatrixSolver.html#a06093225d93b903dc93612fb23ddadf2">A</a>().<a class="code" href="classmatrixRdWt.html#a85aaa63333c688527b5e62dbce69cb61">entry</a>(cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,cxMesh->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>
- <a name="l01963"></a>01963 HMatrix-><a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,k*3+n,&(H.entry(cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[k].nodeID*3+n)),<span class="keyword">false</span>);
- <a name="l01964"></a>01964 }
- <a name="l01965"></a>01965 }
- <a name="l01966"></a>01966 }
- <a name="l01967"></a>01967 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> m=0;m<3;m++)
- <a name="l01968"></a>01968 {
- <a name="l01969"></a>01969 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> n=0;n<4;n++)
- <a name="l01970"></a>01970 {
- <a name="l01971"></a>01971 DaeMatrix-><a class="code" href="classpDataMatrixRdWt.html#a5ae3e12b9c9a47a2dc9dc6b0f1265bf1">setPointer</a>(j*3+m,n,&(Dae.entry(cxMesh->getElement(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).nodeHndl[j].nodeID*3+m,n)),<span class="keyword">false</span>);
- <a name="l01972"></a>01972 <span class="comment">// PsiMatrix->setPointer(j*3+m,n,&(Psi.entry(cxMesh->getElement(i).nodeHndl[j].nodeID*3+m,n)),false);</span>
- <a name="l01973"></a>01973 }
- <a name="l01974"></a>01974 }
- <a name="l01975"></a>01975 }
- <a name="l01976"></a>01976 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setEMatrix(EMatrix,<span class="keyword">true</span>);
- <a name="l01977"></a>01977 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setDeaMatrix(DaeMatrix,<span class="keyword">true</span>);
- <a name="l01978"></a>01978 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setHMatrix(HMatrix,<span class="keyword">true</span>);
- <a name="l01979"></a>01979 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].setDeeMatrix(&Dee);
- <a name="l01980"></a>01980 <span class="comment">// elements[i].setPsiMatrix(PsiMatrix);</span>
- <a name="l01981"></a>01981 }
- <a name="l01982"></a>01982 isBuilt=<span class="keyword">true</span>;
- <a name="l01983"></a>01983 }
- <a name="l01984"></a>01984
- <a name="l01985"></a>01985 <span class="keywordtype">void</span> initSVDMatrix()
- <a name="l01986"></a>01986 {
- <a name="l01987"></a>01987 <span class="keywordflow">if</span>(!isBuilt)
- <a name="l01988"></a>01988 {
- <a name="l01989"></a>01989 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l01990"></a>01990 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a4a19abf94aa1abd08eb8b6fdd2f4662e">TIMEALG::vabsMeshLinkStart</a>();
- <a name="l01991"></a>01991 <span class="preprocessor">#endif</span>
- <a name="l01992"></a>01992 <span class="preprocessor"></span>
- <a name="l01993"></a>01993 buildMatrix();
- <a name="l01994"></a>01994
- <a name="l01995"></a>01995 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l01996"></a>01996 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a19a22177645e1866a8cb9217ad98b726">TIMEALG::vabsMeshLinkStop</a>();
- <a name="l01997"></a>01997 <span class="preprocessor">#endif</span>
- <a name="l01998"></a>01998 <span class="preprocessor"></span> }
- <a name="l01999"></a>01999
- <a name="l02000"></a>02000 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l02001"></a>02001 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a47cb7df0449fa5c03c285d3e92d3aa2d">TIMEALG::vabsMtxCalcStart</a>();
- <a name="l02002"></a>02002 <span class="preprocessor">#endif</span>
- <a name="l02003"></a>02003 <span class="preprocessor"></span>
- <a name="l02004"></a>02004 <span class="comment">// initialize the matrices</span>
- <a name="l02005"></a>02005 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
- <a name="l02006"></a>02006 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
- <a name="l02007"></a>02007 H.size(rCnt,cCnt);
- <a name="l02008"></a>02008 H=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l02009"></a>02009 Dae.size(rCnt,cCnt);
- <a name="l02010"></a>02010 Dae=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l02011"></a>02011 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l02012"></a>02012 <span class="preprocessor"></span> Psi.size(rCnt,cCnt);
- <a name="l02013"></a>02013 Psi=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l02014"></a>02014 <span class="preprocessor">#endif</span>
- <a name="l02015"></a>02015 <span class="preprocessor"></span> cCnt=rCnt=Dee.<a class="code" href="classmatrixSqr.html#a5149ddb5fb5dfb239bf782472bda2793">size</a>();
- <a name="l02016"></a>02016 Dee=<a class="code" href="classmatrix.html">matrix<dataType>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l02017"></a>02017 <span class="preprocessor">#ifdef SVD_BASED_VABS_SOLUTION</span>
- <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);
- <a name="l02019"></a>02019 <span class="preprocessor">#else</span>
- <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>();
- <a name="l02021"></a>02021 <span class="preprocessor">#endif</span>
- <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<double>::zeroMatrix</a>(rCnt,cCnt);
- <a name="l02023"></a>02023
- <a name="l02024"></a>02024 <span class="comment">// Create the matrices</span>
- <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><elements.size();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l02026"></a>02026 {
- <a name="l02027"></a>02027 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addE();
- <a name="l02028"></a>02028 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addDee();
- <a name="l02029"></a>02029 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addDae();
- <a name="l02030"></a>02030 elements[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>].addH();
- <a name="l02031"></a>02031 <span class="comment">// elements[i].addPsi();</span>
- <a name="l02032"></a>02032 }
- <a name="l02033"></a>02033
- <a name="l02034"></a>02034 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l02035"></a>02035 <span class="preprocessor"></span><span class="comment">// // create the Psi matrix</span>
- <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));
- <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><rCnt/3;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l02038"></a>02038 {
- <a name="l02039"></a>02039 Psi.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3,0)=one;
- <a name="l02040"></a>02040 Psi.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1,1)=one;
- <a name="l02041"></a>02041 Psi.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2,2)=one;
- <a name="l02042"></a>02042 Psi.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+1,3)=cxMesh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).y;
- <a name="l02043"></a>02043 Psi.entry(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>*3+2,3)=-cxMesh->getNode(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>).x;
- <a name="l02044"></a>02044 }
- <a name="l02045"></a>02045 <span class="comment">// dataType L=0.0;</span>
- <a name="l02046"></a>02046 <span class="comment">// for(unsigned long i=0;i<rCnt*3;i++)</span>
- <a name="l02047"></a>02047 <span class="comment">// {</span>
- <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>
- <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>
- <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>
- <a name="l02051"></a>02051 <span class="comment">// }</span>
- <a name="l02052"></a>02052 <span class="comment">// L=sqrt(L);</span>
- <a name="l02053"></a>02053 <span class="comment">// for(unsigned long i=0;i<rCnt*3;i++)</span>
- <a name="l02054"></a>02054 <span class="comment">// {</span>
- <a name="l02055"></a>02055 <span class="comment">// mtxSlvr.B().entry(i*3+1,3)/=L;</span>
- <a name="l02056"></a>02056 <span class="comment">// mtxSlvr.B().entry(i*3+2,3)/=L;</span>
- <a name="l02057"></a>02057 <span class="comment">// }</span>
- <a name="l02058"></a>02058 <span class="comment">// // mtxSlvr.solve();</span>
- <a name="l02059"></a>02059 <span class="comment">// Psi=mtxSlvr.B();</span>
- <a name="l02060"></a>02060 <span class="preprocessor">#endif</span>
- <a name="l02061"></a>02061 <span class="preprocessor"></span>
- <a name="l02062"></a>02062 <span class="comment">// Psi.size(rCnt,cCnt);</span>
- <a name="l02063"></a>02063 <span class="comment">// matrixMatrixSolver mtxSlvr(rCnt,cCnt);</span>
- <a name="l02064"></a>02064 <span class="comment">// mtxSlvr.A()=H;</span>
- <a name="l02065"></a>02065 <span class="comment">// mtxSlvr.B()=matrix<double>::zeroMatrix(rCnt,cCnt);</span>
- <a name="l02066"></a>02066 <span class="comment">// double dot1=0.0;</span>
- <a name="l02067"></a>02067 <span class="comment">// double dot2=0.0;</span>
- <a name="l02068"></a>02068 <span class="comment">// double one=1.0/sqrt(double(rCnt));</span>
- <a name="l02069"></a>02069 <span class="comment">// for(unsigned long i=0;i<rCnt/3;i++)</span>
- <a name="l02070"></a>02070 <span class="comment">// {</span>
- <a name="l02071"></a>02071 <span class="comment">// mtxSlvr.B().entry(i*3,0)=one;</span>
- <a name="l02072"></a>02072 <span class="comment">// mtxSlvr.B().entry(i*3+1,1)=one;</span>
- <a name="l02073"></a>02073 <span class="comment">// mtxSlvr.B().entry(i*3+2,2)=one;</span>
- <a name="l02074"></a>02074 <span class="comment">// mtxSlvr.B().entry(i*3+1,3)=cxMesh->getNode(i).y;</span>
- <a name="l02075"></a>02075 <span class="comment">// mtxSlvr.B().entry(i*3+2,3)=-cxMesh->getNode(i).x;</span>
- <a name="l02076"></a>02076 <span class="comment">// dot1-=cxMesh->getNode(i).y*one;</span>
- <a name="l02077"></a>02077 <span class="comment">// dot2+=cxMesh->getNode(i).x*one;</span>
- <a name="l02078"></a>02078 <span class="comment">// }</span>
- <a name="l02079"></a>02079 <span class="comment">// double L=0.0;</span>
- <a name="l02080"></a>02080 <span class="comment">// for(unsigned long i=0;i<rCnt/3;i++)</span>
- <a name="l02081"></a>02081 <span class="comment">// {</span>
- <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>
- <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>
- <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>
- <a name="l02085"></a>02085 <span class="comment">// }</span>
- <a name="l02086"></a>02086 <span class="comment">// L=sqrt(L);</span>
- <a name="l02087"></a>02087 <span class="comment">// for(unsigned long i=0;i<rCnt/3;i++)</span>
- <a name="l02088"></a>02088 <span class="comment">// {</span>
- <a name="l02089"></a>02089 <span class="comment">// mtxSlvr.B().entry(i*3+1,3)/=L;</span>
- <a name="l02090"></a>02090 <span class="comment">// mtxSlvr.B().entry(i*3+2,3)/=L;</span>
- <a name="l02091"></a>02091 <span class="comment">// }</span>
- <a name="l02092"></a>02092 <span class="comment">// mtxSlvr.solve();</span>
- <a name="l02093"></a>02093 <span class="comment">// Psi=mtxSlvr.B();</span>
- <a name="l02094"></a>02094
- <a name="l02095"></a>02095 <span class="comment">// E=solver.A();</span>
- <a name="l02096"></a>02096 <span class="comment">// std::cout << "This is Psi" << std::endl;</span>
- <a name="l02097"></a>02097 <span class="comment">// printMatrix(Psi);</span>
- <a name="l02098"></a>02098 <span class="comment">// for(unsigned long i=0;i<(rCnt/3);i++)</span>
- <a name="l02099"></a>02099 <span class="comment">// {</span>
- <a name="l02100"></a>02100 <span class="comment">// dataType div=Psi.entry(i*3,0);</span>
- <a name="l02101"></a>02101 <span class="comment">// std::cout << div << std::endl;</span>
- <a name="l02102"></a>02102 <span class="comment">// for(unsigned long j=0;j<3;j++)</span>
- <a name="l02103"></a>02103 <span class="comment">// {</span>
- <a name="l02104"></a>02104 <span class="comment">// for(unsigned long k=0;k<4;k++)</span>
- <a name="l02105"></a>02105 <span class="comment">// {</span>
- <a name="l02106"></a>02106 <span class="comment">// Psi.entry(i*3+j,k)/=div;</span>
- <a name="l02107"></a>02107 <span class="comment">// }</span>
- <a name="l02108"></a>02108 <span class="comment">// }</span>
- <a name="l02109"></a>02109 <span class="comment">// }</span>
- <a name="l02110"></a>02110 <span class="comment">// std::cout << "This is Psi" << std::endl;</span>
- <a name="l02111"></a>02111 <span class="comment">// printMatrix(Psi);</span>
- <a name="l02112"></a>02112 <span class="comment">// std::cout << "This is E*Psi" << std::endl;</span>
- <a name="l02113"></a>02113 <span class="comment">// printMatrix(solver.A()*Psi);</span>
- <a name="l02114"></a>02114
- <a name="l02115"></a>02115 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l02116"></a>02116 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#abb3dfe1409ead9ab389b11970c1ed9bb">TIMEALG::vabsMtxCalcStop</a>();
- <a name="l02117"></a>02117 <span class="preprocessor">#endif</span>
- <a name="l02118"></a>02118 <span class="preprocessor"></span>
- <a name="l02119"></a>02119 }
- <a name="l02120"></a>02120
- <a name="l02121"></a>02121 <span class="keywordtype">void</span> solveSVDMatrix()
- <a name="l02122"></a>02122 {
- <a name="l02123"></a>02123 <span class="preprocessor">#ifdef SVD_BASED_VABS_SOLUTION</span>
- <a name="l02124"></a>02124 <span class="preprocessor"></span>
- <a name="l02125"></a>02125 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l02126"></a>02126 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a3ceb53d2150ae4680275daf80a03cab2">TIMEALG::vabsSolveStart</a>();
- <a name="l02127"></a>02127 <span class="preprocessor">#endif</span>
- <a name="l02128"></a>02128 <span class="preprocessor"></span>
- <a name="l02129"></a>02129 <span class="comment">// perform the SVD</span>
- <a name="l02130"></a>02130 <span class="keywordflow">if</span>(!solver.<a class="code" href="classmatrixMatrixSolver.html#a91ec4089eb228ec89bbe390eeeb899f4">solve</a>())
- <a name="l02131"></a>02131 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1_Model_Base::solveMatrix(): Failed to perform the SVD"</span>);
- <a name="l02132"></a>02132
- <a name="l02133"></a>02133 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l02134"></a>02134 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#aa949ffb65130aaa897589e2cb68b2bee">TIMEALG::vabsSolveStop</a>();
- <a name="l02135"></a>02135 <span class="preprocessor">#endif</span>
- <a name="l02136"></a>02136 <span class="preprocessor"></span>
- <a name="l02137"></a>02137 <span class="preprocessor">#endif</span>
- <a name="l02138"></a>02138 <span class="preprocessor"></span> }
- <a name="l02139"></a>02139
- <a name="l02140"></a>02140 <span class="keywordtype">void</span> finalizeSVDSolution()
- <a name="l02141"></a>02141 {
- <a name="l02142"></a>02142
- <a name="l02143"></a>02143
- <a name="l02144"></a>02144
- <a name="l02145"></a>02145 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> rCnt;
- <a name="l02146"></a>02146 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> cCnt;
- <a name="l02147"></a>02147 H.size(rCnt,cCnt);
- <a name="l02148"></a>02148
- <a name="l02149"></a>02149 <span class="preprocessor">#ifdef SVD_BASED_VABS_SOLUTION</span>
- <a name="l02150"></a>02150 <span class="preprocessor"></span>
- <a name="l02151"></a>02151 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l02152"></a>02152 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a64fad33a25509725cf641d6f6d9c6f63">TIMEALG::vabsNCalcStart</a>();
- <a name="l02153"></a>02153 <span class="preprocessor">#endif</span>
- <a name="l02154"></a>02154 <span class="preprocessor"></span>
- <a name="l02155"></a>02155 <span class="comment">// perform all the algebra for the solution</span>
- <a name="l02156"></a>02156 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> PsiTHPsi=solver.Psi().T()*H*solver.Psi();
- <a name="l02157"></a>02157 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> PsiTHPsi_Inverse=PsiTHPsi.<a class="code" href="classmatrixSqr.html#a991ebad568b11587f75c85cc3b8da408">inverse</a>();
- <a name="l02158"></a>02158 <a class="code" href="classmatrixRdWtSzSqr__Data.html">matrixRdWtSzSqr_Data<dataType></a> prePostMatrix=<a class="code" href="classmatrix.html">matrix<dataType>::identityMatrix</a>(rCnt)-H*solver.Psi()*PsiTHPsi_Inverse*solver.Psi().T();
- <a name="l02159"></a>02159
- <a name="l02160"></a>02160 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
- <a name="l02161"></a>02161 <span class="preprocessor"></span> N=prePostMatrix.<a class="code" href="classmatrixRdWtSzSqr__Data.html#a0aaafd5034f44c778cd2a793c992e5e9">T</a>();
- <a name="l02162"></a>02162 <span class="preprocessor">#endif</span>
- <a name="l02163"></a>02163 <span class="preprocessor"></span>
- <a name="l02164"></a>02164 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l02165"></a>02165 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a294dfa8c6f83f364d880655b35f8531f">TIMEALG::vabsNCalcStop</a>();
- <a name="l02166"></a>02166 <a class="code" href="namespaceTIMEALG.html#a3ceb53d2150ae4680275daf80a03cab2">TIMEALG::vabsSolveStart</a>();
- <a name="l02167"></a>02167 <span class="preprocessor">#endif</span>
- <a name="l02168"></a>02168 <span class="preprocessor"></span>
- <a name="l02169"></a>02169 <span class="comment">// Now lets build the matrix expression that will be used to solve V*</span>
- <a name="l02170"></a>02170 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> vStarSource=-prePostMatrix*Dae;
- <a name="l02171"></a>02171 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> vStar=solver.inverse()*vStarSource;
- <a name="l02172"></a>02172 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
- <a name="l02173"></a>02173 <span class="preprocessor"></span> vStar_adjoint=vStar;
- <a name="l02174"></a>02174 <span class="preprocessor">#endif</span>
- <a name="l02175"></a>02175 <span class="preprocessor"></span>
- <a name="l02176"></a>02176 <span class="comment">// now lets solve the actual v</span>
- <a name="l02177"></a>02177 v=prePostMatrix.<a class="code" href="classmatrixRdWtSzSqr__Data.html#a0aaafd5034f44c778cd2a793c992e5e9">T</a>()*vStar;
- <a name="l02178"></a>02178
- <a name="l02179"></a>02179 <span class="comment">// now we can solve the actual matrix</span>
- <a name="l02180"></a>02180 result=v.T()*Dae+Dee;
- <a name="l02181"></a>02181
- <a name="l02182"></a>02182 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l02183"></a>02183 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#aa949ffb65130aaa897589e2cb68b2bee">TIMEALG::vabsSolveStop</a>();
- <a name="l02184"></a>02184 <span class="preprocessor">#endif</span>
- <a name="l02185"></a>02185 <span class="preprocessor"></span>
- <a name="l02186"></a>02186 <span class="preprocessor">#endif</span>
- <a name="l02187"></a>02187 <span class="preprocessor"></span>
- <a name="l02188"></a>02188 <span class="comment">// ##################################################</span>
- <a name="l02189"></a>02189 <span class="comment">// this is the test version based on Psi</span>
- <a name="l02190"></a>02190 <span class="comment">// ##################################################</span>
- <a name="l02191"></a>02191
- <a name="l02192"></a>02192 <span class="comment">// // This is just a test version</span>
- <a name="l02193"></a>02193 <span class="comment">// matrixRdWtStaticSqr_Data<dataType,4> PsiTHPsi_tmp=Psi.T()*H*Psi;</span>
- <a name="l02194"></a>02194 <span class="comment">// matrixRdWtStaticSqr_Data<dataType,4> PsiTHPsi_Inverse_tmp=PsiTHPsi_tmp.inverse();</span>
- <a name="l02195"></a>02195 <span class="comment">// matrixRdWtSzSqr_Data<dataType> prePostMatrix_tmp=matrix<dataType>::identityMatrix(rCnt)-H*Psi*PsiTHPsi_Inverse_tmp*Psi.T();</span>
- <a name="l02196"></a>02196 <span class="comment">// </span>
- <a name="l02197"></a>02197 <span class="comment">// // Now lets build the matrix expression that will be used to solve V*</span>
- <a name="l02198"></a>02198 <span class="comment">// matrixRdWtSz_Data<dataType> vStarSource_tmp=-prePostMatrix_tmp*Dae;</span>
- <a name="l02199"></a>02199 <span class="comment">// matrixRdWtSz_Data<dataType> vStar_tmp=solver.inverse()*vStarSource_tmp;</span>
- <a name="l02200"></a>02200 <span class="comment">// </span>
- <a name="l02201"></a>02201 <span class="comment">// // now lets solve the actual v</span>
- <a name="l02202"></a>02202 <span class="comment">// matrixRdWtSz_Data<dataType> v_tmp=prePostMatrix_tmp.T()*vStar_tmp;</span>
- <a name="l02203"></a>02203 <span class="comment">// </span>
- <a name="l02204"></a>02204 <span class="comment">// // now we can solve the actual matrix</span>
- <a name="l02205"></a>02205 <span class="comment">// matrixRdWtSz_Data<dataType> result_tmp=v_tmp.T()*Dae+Dee;</span>
- <a name="l02206"></a>02206
- <a name="l02207"></a>02207 <span class="comment">// ##################################################</span>
- <a name="l02208"></a>02208 <span class="comment">// this is the test version based on Psi and the linear solve</span>
- <a name="l02209"></a>02209 <span class="comment">// ##################################################</span>
- <a name="l02210"></a>02210
- <a name="l02211"></a>02211 <span class="preprocessor">#ifndef SVD_BASED_VABS_SOLUTION</span>
- <a name="l02212"></a>02212 <span class="preprocessor"></span>
- <a name="l02213"></a>02213 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l02214"></a>02214 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a64fad33a25509725cf641d6f6d9c6f63">TIMEALG::vabsNCalcStart</a>();
- <a name="l02215"></a>02215 <span class="preprocessor">#endif</span>
- <a name="l02216"></a>02216 <span class="preprocessor"></span>
- <a name="l02217"></a>02217 <span class="comment">// build the source matrix and nullifier</span>
- <a name="l02218"></a>02218 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> PsiTHPsi=Psi.T()*H*Psi;
- <a name="l02219"></a>02219 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> PsiTHPsi_Inverse=PsiTHPsi.<a class="code" href="classmatrixSqr.html#a991ebad568b11587f75c85cc3b8da408">inverse</a>();
- <a name="l02220"></a>02220 <a class="code" href="classmatrixRdWtSzSqr__Data.html">matrixRdWtSzSqr_Data<dataType></a> prePostMatrix=<a class="code" href="classmatrix.html">matrix<dataType>::identityMatrix</a>(rCnt)-H*Psi*PsiTHPsi_Inverse*Psi.<a class="code" href="classmatrixRdWtStaticSqr__Data.html#a3db65c97e3f5de1fe52b5f0831e11176">T</a>();
- <a name="l02221"></a>02221 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
- <a name="l02222"></a>02222 <span class="preprocessor"></span> N=prePostMatrix.<a class="code" href="classmatrixRdWtSzSqr__Data.html#a0aaafd5034f44c778cd2a793c992e5e9">T</a>();
- <a name="l02223"></a>02223 <span class="preprocessor">#endif</span>
- <a name="l02224"></a>02224 <span class="preprocessor"></span>
- <a name="l02225"></a>02225 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l02226"></a>02226 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a294dfa8c6f83f364d880655b35f8531f">TIMEALG::vabsNCalcStop</a>();
- <a name="l02227"></a>02227 <a class="code" href="namespaceTIMEALG.html#a3ceb53d2150ae4680275daf80a03cab2">TIMEALG::vabsSolveStart</a>();
- <a name="l02228"></a>02228 <span class="preprocessor">#endif</span>
- <a name="l02229"></a>02229 <span class="preprocessor"></span>
- <a name="l02230"></a>02230 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> vStarSource=-prePostMatrix*Dae;
- <a name="l02231"></a>02231
- <a name="l02232"></a>02232 <span class="comment">// The solve operator</span>
- <a name="l02233"></a>02233 <a class="code" href="classmatrixRdWtSz__Data.html">matrixRdWtSz_Data<dataType></a> PsiDyad=Psi*Psi.<a class="code" href="classmatrixRdWtSz__Data.html#ae1c7af296930751d1ceaf95429e9bb57">T</a>();
- <a name="l02234"></a>02234 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> tracePsi=0.0;
- <a name="l02235"></a>02235 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> traceE=0.0;
- <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><rCnt;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l02237"></a>02237 {
- <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>);
- <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>);
- <a name="l02240"></a>02240 }
- <a name="l02241"></a>02241 <span class="comment">// #ifdef ADJOINT_VABS</span>
- <a name="l02242"></a>02242 <span class="comment">// ET=solver.A().T();</span>
- <a name="l02243"></a>02243 <span class="comment">// #endif</span>
- <a name="l02244"></a>02244 solver.<a class="code" href="classmatrixMatrixSolver.html#a06093225d93b903dc93612fb23ddadf2">A</a>()+=(traceE/tracePsi)*PsiDyad;
- <a name="l02245"></a>02245
- <a name="l02246"></a>02246 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
- <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>();
- <a name="l02248"></a>02248 <span class="preprocessor">#endif</span>
- <a name="l02249"></a>02249 <span class="preprocessor"></span>
- <a name="l02250"></a>02250 solver.<a class="code" href="classmatrixMatrixSolver.html#a3d4eb5a5c9b8a11961f29cf94c0c64d7">B</a>()=vStarSource;
- <a name="l02251"></a>02251 solver.<a class="code" href="classmatrixMatrixSolver.html#a91ec4089eb228ec89bbe390eeeb899f4">solve</a>();
- <a name="l02252"></a>02252
- <a name="l02253"></a>02253 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
- <a name="l02254"></a>02254 <span class="preprocessor"></span> vStar_adjoint=solver.<a class="code" href="classmatrixMatrixSolver.html#a3d4eb5a5c9b8a11961f29cf94c0c64d7">B</a>();
- <a name="l02255"></a>02255 <span class="preprocessor">#endif</span>
- <a name="l02256"></a>02256 <span class="preprocessor"></span>
- <a name="l02257"></a>02257 <span class="comment">// now lets solve the actual v</span>
- <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>();
- <a name="l02259"></a>02259 <span class="comment">// now we can solve the actual matrix</span>
- <a name="l02260"></a>02260 result=v.T()*Dae+Dee;
- <a name="l02261"></a>02261
- <a name="l02262"></a>02262 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l02263"></a>02263 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#aa949ffb65130aaa897589e2cb68b2bee">TIMEALG::vabsSolveStop</a>();
- <a name="l02264"></a>02264 <span class="preprocessor">#endif</span>
- <a name="l02265"></a>02265 <span class="preprocessor"></span>
- <a name="l02266"></a>02266 <span class="preprocessor">#endif</span>
- <a name="l02267"></a>02267 <span class="preprocessor"></span>
- <a name="l02268"></a>02268 <span class="comment">// std::cout << "This is v_tmp-v" << std::endl;</span>
- <a name="l02269"></a>02269 <span class="comment">// printMatrix(v_tmp-v);</span>
- <a name="l02270"></a>02270 <span class="comment">// std::cout << "This is result_tmp-result" << std::endl;</span>
- <a name="l02271"></a>02271 <span class="comment">// printMatrix(result_tmp-result);</span>
- <a name="l02272"></a>02272 <span class="comment">// std::cout << "This is result_lin-result" << std::endl;</span>
- <a name="l02273"></a>02273 <span class="comment">// printMatrix(result_lin-result);</span>
- <a name="l02274"></a>02274 <span class="comment">// std::cout << "This is the result" << std::endl;</span>
- <a name="l02275"></a>02275 <span class="comment">// printMatrix(result);</span>
- <a name="l02276"></a>02276 <span class="comment">// std::cout << "This is solver.Psi^T*Psi" << std::endl;</span>
- <a name="l02277"></a>02277 <span class="comment">// printMatrix(solver.Psi().T()*Psi);</span>
- <a name="l02278"></a>02278 <span class="comment">// std::cout << "This is solver.Psi" << std::endl;</span>
- <a name="l02279"></a>02279 <span class="comment">// printMatrix(solver.Psi());</span>
- <a name="l02280"></a>02280 <span class="comment">// std::cout << "This is E*solver.Psi" << std::endl;</span>
- <a name="l02281"></a>02281 <span class="comment">// printMatrix(E*solver.Psi());</span>
- <a name="l02282"></a>02282 <span class="comment">// std::cout << "This is position" << std::endl;</span>
- <a name="l02283"></a>02283 <span class="comment">// unsigned long ndCnt;</span>
- <a name="l02284"></a>02284 <span class="comment">// unsigned long elmCnt;</span>
- <a name="l02285"></a>02285 <span class="comment">// cxMesh->size(ndCnt,elmCnt);</span>
- <a name="l02286"></a>02286 <span class="comment">// std::streamsize prec=std::cout.precision(16);</span>
- <a name="l02287"></a>02287 <span class="comment">// for(unsigned long i=0;i<ndCnt;i++)</span>
- <a name="l02288"></a>02288 <span class="comment">// std::cout << cxMesh->getNode(i).x << '\t' << cxMesh->getNode(i).y << std::endl;</span>
- <a name="l02289"></a>02289 <span class="comment">// std::cout.precision(prec);</span>
- <a name="l02290"></a>02290
- <a name="l02291"></a>02291 isSolved=<span class="keyword">true</span>;
- <a name="l02292"></a>02292
- <a name="l02293"></a>02293 }
- <a name="l02294"></a>02294
- <a name="l02295"></a>02295 <span class="keywordtype">void</span> solveMatrix()
- <a name="l02296"></a>02296 {
- <a name="l02297"></a>02297 initSVDMatrix();
- <a name="l02298"></a>02298 solveSVDMatrix();
- <a name="l02299"></a>02299 finalizeSVDSolution();
- <a name="l02300"></a>02300 }
- <a name="l02301"></a>02301
- <a name="l02302"></a>02302 <span class="keyword">public</span>:
- <a name="l02303"></a>02303
- <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<dataType></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)
- <a name="l02305"></a>02305 {
- <a name="l02306"></a>02306 <span class="preprocessor">#if defined(SAVE_INTERMEDIATES) || defined(ADJOINT_VABS)</span>
- <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;
- <a name="l02308"></a>02308
- <a name="l02309"></a>02309 vabsList.resize(<span class="keywordtype">id</span>+1);
- <a name="l02310"></a>02310 vabsList[id]=<span class="keyword">this</span>;
- <a name="l02311"></a>02311 <span class="keywordtype">id</span>++;
- <a name="l02312"></a>02312 <span class="preprocessor">#endif</span>
- <a name="l02313"></a>02313 <span class="preprocessor"></span> }
- <a name="l02314"></a>02314
- <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>()
- <a name="l02316"></a>02316 {
- <a name="l02317"></a>02317 <span class="keywordflow">if</span>(canDelete && cxMesh!=NULL)
- <a name="l02318"></a>02318 <span class="keyword">delete</span> cxMesh;
- <a name="l02319"></a>02319 }
- <a name="l02320"></a>02320
- <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<dataType></a>* cxMesh_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
- <a name="l02322"></a>02322 {
- <a name="l02323"></a>02323 <span class="keywordflow">if</span>(canDelete && cxMesh!=NULL && cxMesh_in!=cxMesh)
- <a name="l02324"></a>02324 <span class="keyword">delete</span> cxMesh;
- <a name="l02325"></a>02325 cxMesh=cxMesh_in;
- <a name="l02326"></a>02326 canDelete=canDelete_in;
- <a name="l02327"></a>02327 isBuilt=<span class="keyword">false</span>;
- <a name="l02328"></a>02328 isSolved=<span class="keyword">false</span>;
- <a name="l02329"></a>02329 }
- <a name="l02330"></a>02330
- <a name="l02331"></a><a class="code" href="classVABS1Model__Base.html#a8363f050c3d8cf35423f6f843ad8f66a">02331</a> <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> <a class="code" href="classVABS1Model__Base.html#a8363f050c3d8cf35423f6f843ad8f66a">beamMatrix</a>()
- <a name="l02332"></a>02332 {
- <a name="l02333"></a>02333 <span class="keywordflow">if</span>(!isSolved)
- <a name="l02334"></a>02334 this->solveMatrix();
- <a name="l02335"></a>02335
- <a name="l02336"></a>02336 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
- <a name="l02337"></a>02337 <span class="preprocessor"></span> <span class="keywordflow">if</span>(gradientMode)
- <a name="l02338"></a>02338 {
- <a name="l02339"></a>02339 <span class="keywordflow">if</span>(highCalc)
- <a name="l02340"></a>02340 <span class="keywordflow">return</span> result+dC_dy*step;
- <a name="l02341"></a>02341 <span class="keywordflow">else</span>
- <a name="l02342"></a>02342 <span class="keywordflow">return</span> result-dC_dy*step;
- <a name="l02343"></a>02343 }
- <a name="l02344"></a>02344 <span class="preprocessor">#endif</span>
- <a name="l02345"></a>02345 <span class="preprocessor"></span>
- <a name="l02346"></a>02346 <span class="keywordflow">return</span> result;
- <a name="l02347"></a>02347 }
- <a name="l02348"></a>02348
- <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>()
- <a name="l02350"></a>02350 {
- <a name="l02351"></a>02351 initSVDMatrix();
- <a name="l02352"></a>02352 }
- <a name="l02353"></a>02353
- <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>()
- <a name="l02355"></a>02355 {
- <a name="l02356"></a>02356 solveSVDMatrix();
- <a name="l02357"></a>02357 }
- <a name="l02358"></a>02358
- <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>()
- <a name="l02360"></a>02360 {
- <a name="l02361"></a>02361 finalizeSVDSolution();
- <a name="l02362"></a>02362 }
- <a name="l02363"></a>02363
- <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>()
- <a name="l02365"></a>02365 {
- <a name="l02366"></a>02366 <span class="keywordflow">if</span>(!isSolved)
- <a name="l02367"></a>02367 this->solveMatrix();
- <a name="l02368"></a>02368 }
- <a name="l02369"></a>02369
- <a name="l02370"></a>02370 <span class="comment">// A method that informs the post process module about the number of elements</span>
- <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>()
- <a name="l02372"></a>02372 {
- <a name="l02373"></a>02373 <span class="keywordflow">return</span> elements.size();
- <a name="l02374"></a>02374 }
- <a name="l02375"></a>02375
- <a name="l02376"></a>02376 <span class="comment">// This is an access method to perform post processing</span>
- <a name="l02377"></a><a class="code" href="classVABS1Model__Base.html#aacac281ad0abf6c05900163e6ef9479a">02377</a> <a class="code" href="classautoPntr.html">autoPntr<VABSElementInfo<dataType,matrixStaticVectCol<dataType,4></a> > > <a class="code" href="classVABS1Model__Base.html#aacac281ad0abf6c05900163e6ef9479a">getElement</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)
- <a name="l02378"></a>02378 {
- <a name="l02379"></a>02379 <span class="keywordflow">if</span>(at>=elements.size())
- <a name="l02380"></a>02380 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS1Model_Base::getElement(): Cannot retrieve element because it does not exist"</span>);
- <a name="l02381"></a>02381
- <a name="l02382"></a>02382 <span class="keywordflow">return</span> <a class="code" href="classautoPntr.html">autoPntr<VABSElementInfo<dataType,matrixStaticVectCol<dataType,4></a> > >(<span class="keyword">new</span> <a class="code" href="classVABSElementInfo__Pntr.html">VABSElementInfo_Pntr<dataType,matrixStaticVectCol<dataType,4></a> >(&elements[at]));
- <a name="l02383"></a>02383 }
- <a name="l02384"></a>02384
- <a name="l02385"></a>02385
- <a name="l02386"></a>02386 <span class="preprocessor">#if defined(SAVE_INTERMEDIATES) || defined(ADJOINT_VABS)</span>
- <a name="l02387"></a>02387 <span class="preprocessor"></span>
- <a name="l02388"></a>02388 <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad<dataType></a>& getMaxElm()
- <a name="l02389"></a>02389 {
- <a name="l02390"></a>02390 <span class="keywordflow">return</span> elements[maxElm];
- <a name="l02391"></a>02391 }
- <a name="l02392"></a>02392
- <a name="l02393"></a>02393 <span class="preprocessor">#endif</span>
- <a name="l02394"></a>02394 <span class="preprocessor"></span>
- <a name="l02395"></a>02395 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
- <a name="l02396"></a>02396 <span class="preprocessor"></span>
- <a name="l02397"></a>02397 <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad<dataType></a>& getMaxElmLow()
- <a name="l02398"></a>02398 {
- <a name="l02399"></a>02399 <span class="keywordflow">return</span> elementsLow[maxElm];
- <a name="l02400"></a>02400 }
- <a name="l02401"></a>02401
- <a name="l02402"></a>02402 <a class="code" href="classVABS1__MatrixSource__Quad.html">VABS1_MatrixSource_Quad<dataType></a>& getMaxElmHigh()
- <a name="l02403"></a>02403 {
- <a name="l02404"></a>02404 <span class="keywordflow">return</span> elementsHigh[maxElm];
- <a name="l02405"></a>02405 }
- <a name="l02406"></a>02406
- <a name="l02407"></a>02407 <span class="preprocessor">#endif</span>
- <a name="l02408"></a>02408 <span class="preprocessor"></span>
- <a name="l02409"></a>02409 <span class="comment">// void getFailList(const matrixStaticVectCol<dataType>& beamStrain, std::list<failPoint<dataType> >& failList)</span>
- <a name="l02410"></a>02410 <span class="comment">// {</span>
- <a name="l02411"></a>02411 <span class="comment">// dataType max=0;</span>
- <a name="l02412"></a>02412 <span class="comment">// dataType tmp;</span>
- <a name="l02413"></a>02413 <span class="comment">// dataType div=pow(2.0,-dataType(sweepN));</span>
- <a name="l02414"></a>02414 <span class="comment">// unsigned long cnt=(1 << sweepN);</span>
- <a name="l02415"></a>02415 <span class="comment">// </span>
- <a name="l02416"></a>02416 <span class="comment">// for(unsigned long i=0;i<elements.size();i++)</span>
- <a name="l02417"></a>02417 <span class="comment">// {</span>
- <a name="l02418"></a>02418 <span class="comment">// dataType s=div-dataType(1.0);</span>
- <a name="l02419"></a>02419 <span class="comment">// for(unsigned long j=0;j<=cnt;j++)</span>
- <a name="l02420"></a>02420 <span class="comment">// {</span>
- <a name="l02421"></a>02421 <span class="comment">// dataType t=div-dataType(1.0);</span>
- <a name="l02422"></a>02422 <span class="comment">// for(unsigned long k=0;k<=cnt;k++)</span>
- <a name="l02423"></a>02423 <span class="comment">// {</span>
- <a name="l02424"></a>02424 <span class="comment">// tmp=elements[i].fail(s,t,beamStrain);</span>
- <a name="l02425"></a>02425 <span class="comment">// failList.push_back(failPoint<dataType>(tmp,s,t,i));</span>
- <a name="l02426"></a>02426 <span class="comment">// }</span>
- <a name="l02427"></a>02427 <span class="comment">// s+=div;</span>
- <a name="l02428"></a>02428 <span class="comment">// }</span>
- <a name="l02429"></a>02429 <span class="comment">// }</span>
- <a name="l02430"></a>02430 <span class="comment">// }</span>
- <a name="l02431"></a>02431
- <a name="l02432"></a>02432 <span class="comment">// dataType getMaxFail(const matrixStaticVectCol<dataType>& beamStrain,unsigned long n=0)</span>
- <a name="l02433"></a>02433 <span class="comment">// {</span>
- <a name="l02434"></a>02434 <span class="comment">// dataType max=0;</span>
- <a name="l02435"></a>02435 <span class="comment">// dataType tmp;</span>
- <a name="l02436"></a>02436 <span class="comment">// dataType div=pow(2.0,-dataType(n));</span>
- <a name="l02437"></a>02437 <span class="comment">// unsigned long cnt=(1 << n);</span>
- <a name="l02438"></a>02438 <span class="comment">// </span>
- <a name="l02439"></a>02439 <span class="comment">// for(unsigned long i=0;i<elements.size();i++)</span>
- <a name="l02440"></a>02440 <span class="comment">// {</span>
- <a name="l02441"></a>02441 <span class="comment">// dataType s=dataType(1.0)-div;</span>
- <a name="l02442"></a>02442 <span class="comment">// for(unsigned long j=0;j<=cnt;j++)</span>
- <a name="l02443"></a>02443 <span class="comment">// {</span>
- <a name="l02444"></a>02444 <span class="comment">// dataType t=dataType(1.0)-div;</span>
- <a name="l02445"></a>02445 <span class="comment">// for(unsigned long k=0;k<=cnt;k++)</span>
- <a name="l02446"></a>02446 <span class="comment">// {</span>
- <a name="l02447"></a>02447 <span class="comment">// tmp=elements[i].fail(s,t,beamStrain);</span>
- <a name="l02448"></a>02448 <span class="comment">// if(max<tmp)</span>
- <a name="l02449"></a>02449 <span class="comment">// max=tmp;</span>
- <a name="l02450"></a>02450 <span class="comment">// t+=div;</span>
- <a name="l02451"></a>02451 <span class="comment">// }</span>
- <a name="l02452"></a>02452 <span class="comment">// s+=div;</span>
- <a name="l02453"></a>02453 <span class="comment">// }</span>
- <a name="l02454"></a>02454 <span class="comment">// }</span>
- <a name="l02455"></a>02455 <span class="comment">// </span>
- <a name="l02456"></a>02456 <span class="comment">// return max;</span>
- <a name="l02457"></a>02457 <span class="comment">// }</span>
- <a name="l02458"></a>02458 };
- <a name="l02459"></a>02459
- <a name="l02460"></a>02460 <span class="preprocessor">#if defined(SAVE_INTERMEDIATES) || defined(ADJOINT_VABS)</span>
- <a name="l02461"></a>02461 <span class="preprocessor"></span>
- <a name="l02462"></a>02462 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <a name="l02463"></a>02463 std::vector<VABS1Model_Base<dataType>*> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base<dataType>::vabsList</a>;
- <a name="l02464"></a>02464
- <a name="l02465"></a>02465 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <a name="l02466"></a>02466 <span class="keywordtype">bool</span> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base<dataType>::gradientMode</a>=<span class="keyword">false</span>;
- <a name="l02467"></a>02467
- <a name="l02468"></a>02468 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <a name="l02469"></a>02469 <span class="keywordtype">bool</span> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base<dataType>::highCalc</a>=<span class="keyword">false</span>;
- <a name="l02470"></a>02470
- <a name="l02471"></a>02471 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <a name="l02472"></a>02472 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base<dataType>::step</a>=0.0001;
- <a name="l02473"></a>02473
- <a name="l02474"></a>02474 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <a name="l02475"></a>02475 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base<dataType>::maxElm</a>=0;
- <a name="l02476"></a>02476
- <a name="l02477"></a>02477 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <a name="l02478"></a>02478 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base<dataType>::maxCX</a>=0;
- <a name="l02479"></a>02479
- <a name="l02480"></a>02480 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <a name="l02481"></a>02481 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base<dataType>::atS</a>=0.0;
- <a name="l02482"></a>02482
- <a name="l02483"></a>02483 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <a name="l02484"></a>02484 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base<dataType>::atT</a>=0.0;
- <a name="l02485"></a>02485
- <a name="l02486"></a>02486 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <a name="l02487"></a>02487 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> <a class="code" href="classVABS1Model__Base.html">VABS1Model_Base<dataType>::beamLocation</a>=0.0;
- <a name="l02488"></a>02488
- <a name="l02489"></a>02489 <span class="preprocessor">#endif</span>
- <a name="l02490"></a>02490 <span class="preprocessor"></span>
- <a name="l02491"></a>02491 <span class="comment">// This version was used befor the realization the only difference is one type.</span>
- <a name="l02492"></a>02492 <span class="comment">// Thus it is better the differentiation is made between template parameters</span>
- <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>
- <a name="l02494"></a>02494 <span class="comment">// // template<class dataType,class failType></span>
- <a name="l02495"></a>02495 <span class="comment">// // class VABS2Model</span>
- <a name="l02496"></a>02496 <span class="comment">// // {</span>
- <a name="l02497"></a>02497 <span class="comment">// // public:</span>
- <a name="l02498"></a>02498 <span class="comment">// // </span>
- <a name="l02499"></a>02499 <span class="comment">// // VABS2Model()</span>
- <a name="l02500"></a>02500 <span class="comment">// // {}</span>
- <a name="l02501"></a>02501 <span class="comment">// // </span>
- <a name="l02502"></a>02502 <span class="comment">// // virtual ~VABS2Model()</span>
- <a name="l02503"></a>02503 <span class="comment">// // {}</span>
- <a name="l02504"></a>02504 <span class="comment">// // </span>
- <a name="l02505"></a>02505 <span class="comment">// // // This is a function that provides the mesh to the vabs model</span>
- <a name="l02506"></a>02506 <span class="comment">// // virtual void setMesh(mesh<dataType>* cxMesh_in,bool canDelete_in=false)=0;</span>
- <a name="l02507"></a>02507 <span class="comment">// // // this is teh method that provides the timoshenko beam model</span>
- <a name="l02508"></a>02508 <span class="comment">// // virtual matrixRdWtStaticSqr_Data<dataType,6> beamMatrix()=0;</span>
- <a name="l02509"></a>02509 <span class="comment">// // // this is the method that collects a set of failure statistics</span>
- <a name="l02510"></a>02510 <span class="comment">// // virtual void getFailList(const matrixStaticVectCol<dataType>& beamStrain, std::list<failType>& failList)=0;</span>
- <a name="l02511"></a>02511 <span class="comment">// // };</span>
- <a name="l02512"></a>02512
- <a name="l02513"></a>02513 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><dataType,matrixStaticVectCol<dataType,6> >
- <a name="l02515"></a>02515 {
- <a name="l02516"></a>02516 <span class="keyword">private</span>:
- <a name="l02517"></a>02517
- <a name="l02518"></a>02518 <a class="code" href="classVABSElementInfo.html">VABSElementInfo<dataType,matrixStaticVectCol<dataType,4></a> >* vabs1Elm;
- <a name="l02519"></a>02519 <span class="keywordtype">bool</span> canDelete;
- <a name="l02520"></a>02520
- <a name="l02521"></a>02521 <span class="keyword">public</span>:
- <a name="l02522"></a>02522
- <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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol<dataType,4></a> >* vabs1Elm_in=NULL,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : vabs1Elm(vabs1Elm_in) , canDelete(canDelete_in)
- <a name="l02524"></a>02524 {}
- <a name="l02525"></a>02525
- <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<dataType></a>& asg) : vabs1Elm(asg.vabs1Elm) , canDelete(false)
- <a name="l02527"></a>02527 {}
- <a name="l02528"></a>02528
- <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>()
- <a name="l02530"></a>02530 {
- <a name="l02531"></a>02531 <span class="keywordflow">if</span>(canDelete && vabs1Elm!=NULL)
- <a name="l02532"></a>02532 <span class="keyword">delete</span> vabs1Elm;
- <a name="l02533"></a>02533 }
- <a name="l02534"></a>02534
- <a name="l02535"></a><a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#a130856510b8c96e68504dc880ff769bc">02535</a> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html">VABS2ElmInfo_fromVABS1ElmInfo<dataType></a>& <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#a130856510b8c96e68504dc880ff769bc">operator=</a>(<span class="keyword">const</span> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html">VABS2ElmInfo_fromVABS1ElmInfo<dataType></a>& asg)
- <a name="l02536"></a>02536 {
- <a name="l02537"></a>02537 this->vabs1Elm=asg.vabs1Elm;
- <a name="l02538"></a>02538 this->canDelete=<span class="keyword">false</span>;
- <a name="l02539"></a>02539 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l02540"></a>02540 }
- <a name="l02541"></a>02541
- <a name="l02542"></a><a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#a5cec266f790a45ffe1e94c067c95f7f2">02542</a> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html">VABS2ElmInfo_fromVABS1ElmInfo<dataType></a>& <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html#a5cec266f790a45ffe1e94c067c95f7f2">setVABSElementInfo</a>(<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol<dataType,4></a> >* vabs1Elm_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
- <a name="l02543"></a>02543 {
- <a name="l02544"></a>02544 vabs1Elm=vabs1Elm_in;
- <a name="l02545"></a>02545 canDelete=canDelete_in;
- <a name="l02546"></a>02546 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l02547"></a>02547 }
- <a name="l02548"></a>02548
- <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<dataType,6></a>& beamStrain)
- <a name="l02550"></a>02550 {
- <a name="l02551"></a>02551 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data<dataType,4></a> bernoulliStrain;
- <a name="l02552"></a>02552
- <a name="l02553"></a>02553 <span class="keywordflow">if</span>(vabs1Elm==NULL)
- <a name="l02554"></a>02554 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS2ElmInfo_fromVABS1ElmInfo::fail(): The vabs1 element has not been set"</span>);
- <a name="l02555"></a>02555
- <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);
- <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);
- <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);
- <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);
- <a name="l02560"></a>02560
- <a name="l02561"></a>02561 <span class="keywordflow">return</span> vabs1Elm-><a class="code" href="classVABSElementInfo.html#a20130a423f8b19120fbf4be6361283f7">fail</a>(s,t,bernoulliStrain);
- <a name="l02562"></a>02562 }
- <a name="l02563"></a>02563
- <a name="l02564"></a>02564 };
- <a name="l02565"></a>02565
- <a name="l02566"></a>02566 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><dataType,matrixRdWtStaticSqr_Data<dataType,6>,VABSElementInfo<dataType,matrixStaticVectCol<dataType,6> > >
- <a name="l02568"></a>02568 {
- <a name="l02569"></a>02569 <span class="keyword">private</span>:
- <a name="l02570"></a>02570
- <a name="l02571"></a>02571 <a class="code" href="classVABSModel.html">VABSModel<dataType,matrixRdWtStaticSqr_Data<dataType,4></a>,<a class="code" href="classVABSElementInfo.html">VABSElementInfo<dataType,matrixStaticVectCol<dataType,4></a> > >* vabs1;
- <a name="l02572"></a>02572 <span class="keywordtype">bool</span> canDelete;
- <a name="l02573"></a>02573
- <a name="l02574"></a>02574 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> shearConstant;
- <a name="l02575"></a>02575
- <a name="l02576"></a>02576 <span class="keyword">public</span>:
- <a name="l02577"></a>02577
- <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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a>,<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol<dataType,4></a> > >* vabs1_in=NULL,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>) : vabs1(vabs1_in) , canDelete(canDelete_in) , shearConstant(shearConstant_in)
- <a name="l02579"></a>02579 {}
- <a name="l02580"></a>02580
- <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>()
- <a name="l02582"></a>02582 {
- <a name="l02583"></a>02583 <span class="keywordflow">if</span>(canDelete && vabs1!=NULL)
- <a name="l02584"></a>02584 <span class="keyword">delete</span> vabs1;
- <a name="l02585"></a>02585 }
- <a name="l02586"></a>02586
- <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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a>,<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol<dataType,4></a> > >* vabs1_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
- <a name="l02588"></a>02588 {
- <a name="l02589"></a>02589 <span class="keywordflow">if</span>(vabs1_in==vabs1)
- <a name="l02590"></a>02590 {
- <a name="l02591"></a>02591 canDelete=canDelete_in;
- <a name="l02592"></a>02592 <span class="keywordflow">return</span>;
- <a name="l02593"></a>02593 }
- <a name="l02594"></a>02594 <span class="keywordflow">if</span>(canDelete && vabs1!=NULL)
- <a name="l02595"></a>02595 <span class="keyword">delete</span> vabs1;
- <a name="l02596"></a>02596 vabs1=vabs1_in;
- <a name="l02597"></a>02597 canDelete=canDelete_in;
- <a name="l02598"></a>02598 }
- <a name="l02599"></a>02599
- <a name="l02600"></a>02600 <span class="comment">// This is a function that provides the mesh to the vabs model</span>
- <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<dataType></a>* cxMesh_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
- <a name="l02602"></a>02602 {
- <a name="l02603"></a>02603 <span class="keywordflow">if</span>(vabs1==NULL)
- <a name="l02604"></a>02604 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS2Model_fromVABS1Model::setMesh(): The vabs 1 model has not been set"</span>);
- <a name="l02605"></a>02605 vabs1-><a class="code" href="classVABSModelInput.html#a34bb1d411f8b8303d932e0a1503fba25">setMesh</a>(cxMesh_in,canDelete_in);
- <a name="l02606"></a>02606 }
- <a name="l02607"></a>02607
- <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>()
- <a name="l02609"></a>02609 {
- <a name="l02610"></a>02610 <span class="keywordflow">if</span>(vabs1==NULL)
- <a name="l02611"></a>02611 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS2Model_fromVABS1Model::solve(): The vabs 1 model has not been set"</span>);
- <a name="l02612"></a>02612
- <a name="l02613"></a>02613 vabs1-><a class="code" href="classVABSModelInput.html#ae9e0c54fac2464d9f13a599c5af1784a">buildSVD</a>();
- <a name="l02614"></a>02614 }
- <a name="l02615"></a>02615
- <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>()
- <a name="l02617"></a>02617 {
- <a name="l02618"></a>02618 <span class="keywordflow">if</span>(vabs1==NULL)
- <a name="l02619"></a>02619 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS2Model_fromVABS1Model::solve(): The vabs 1 model has not been set"</span>);
- <a name="l02620"></a>02620
- <a name="l02621"></a>02621 vabs1-><a class="code" href="classVABSModelInput.html#aa964d19fe486ffc21a58e341a34ab2d8">solveSVD</a>();
- <a name="l02622"></a>02622 }
- <a name="l02623"></a>02623
- <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>()
- <a name="l02625"></a>02625 {
- <a name="l02626"></a>02626 <span class="keywordflow">if</span>(vabs1==NULL)
- <a name="l02627"></a>02627 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS2Model_fromVABS1Model::solve(): The vabs 1 model has not been set"</span>);
- <a name="l02628"></a>02628
- <a name="l02629"></a>02629 vabs1-><a class="code" href="classVABSModelInput.html#aa1e92195b3ac2661ec4e001d4b2f6c47">processSVD</a>();
- <a name="l02630"></a>02630 }
- <a name="l02631"></a>02631
- <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>()
- <a name="l02633"></a>02633 {
- <a name="l02634"></a>02634 <span class="keywordflow">if</span>(vabs1==NULL)
- <a name="l02635"></a>02635 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS2Model_fromVABS1Model::solve(): The vabs 1 model has not been set"</span>);
- <a name="l02636"></a>02636
- <a name="l02637"></a>02637 vabs1-><a class="code" href="classVABSModelInput.html#a14f9d151b0d089a8a140418264b1ff15">solve</a>();
- <a name="l02638"></a>02638 }
- <a name="l02639"></a>02639
- <a name="l02640"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#ad7c5d9724a3bddda2532d29425598b03">02640</a> <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,6></a> <a class="code" href="classVABS2Model__fromVABS1Model.html#ad7c5d9724a3bddda2532d29425598b03">beamMatrix</a>()
- <a name="l02641"></a>02641 {
- <a name="l02642"></a>02642 <span class="keywordflow">if</span>(vabs1==NULL)
- <a name="l02643"></a>02643 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS2Model_fromVABS1Model::beamMatrix(): The vabs 1 model has not been set"</span>);
- <a name="l02644"></a>02644
- <a name="l02645"></a>02645 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,6></a> retVal=<a class="code" href="classmatrixStatic__Zero.html">matrixStatic_Zero<dataType,6,6></a>();
- <a name="l02646"></a>02646 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> vabs1Result=vabs1-><a class="code" href="classVABSModelBeamMatrix.html#ad74f2717ec4415b3603ba49f42403b0c">beamMatrix</a>();
- <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><4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l02648"></a>02648 {
- <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>;
- <a name="l02650"></a>02650 <span class="keywordflow">if</span>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>>0)
- <a name="l02651"></a>02651 atI+=2;
- <a name="l02652"></a>02652 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<4;j++)
- <a name="l02653"></a>02653 {
- <a name="l02654"></a>02654 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> atJ=j;
- <a name="l02655"></a>02655 <span class="keywordflow">if</span>(j>0)
- <a name="l02656"></a>02656 atJ+=2;
- <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);
- <a name="l02658"></a>02658 <span class="comment">// if(i==j) retVal.entry(atI,atJ)=vabs1Result.entry(i,j);</span>
- <a name="l02659"></a>02659 }
- <a name="l02660"></a>02660 }
- <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);
- <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);
- <a name="l02663"></a>02663
- <a name="l02664"></a>02664 <span class="keywordflow">return</span> retVal;
- <a name="l02665"></a>02665 }
- <a name="l02666"></a>02666
- <a name="l02667"></a>02667 <span class="comment">// A method that informs the post process module about the number of elements</span>
- <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>()
- <a name="l02669"></a>02669 {
- <a name="l02670"></a>02670 <span class="keywordflow">if</span>(vabs1==NULL)
- <a name="l02671"></a>02671 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS2Model_fromVABS1Model::size(): The vabs model has not been set"</span>);
- <a name="l02672"></a>02672 <span class="keywordflow">return</span> vabs1-><a class="code" href="classVABSModelPost.html#a476038f832b9ef6181ac62f3874fd0ec">size</a>();
- <a name="l02673"></a>02673 }
- <a name="l02674"></a>02674
- <a name="l02675"></a>02675 <span class="comment">// This is an access method to perform post processing</span>
- <a name="l02676"></a><a class="code" href="classVABS2Model__fromVABS1Model.html#a371b92b54277066775273a8af5c1cf2a">02676</a> <a class="code" href="classautoPntr.html">autoPntr< VABSElementInfo<dataType,matrixStaticVectCol<dataType,6></a> > > <a class="code" href="classVABS2Model__fromVABS1Model.html#a371b92b54277066775273a8af5c1cf2a">getElement</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)
- <a name="l02677"></a>02677 {
- <a name="l02678"></a>02678 <span class="keywordflow">if</span>(vabs1==NULL)
- <a name="l02679"></a>02679 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABS2Model_fromVABS1Model::getElement(): The vabs model has not been set"</span>);
- <a name="l02680"></a>02680
- <a name="l02681"></a>02681 <a class="code" href="classautoPntr.html">autoPntr<VABSElementInfo<dataType,matrixStaticVectCol<dataType,4></a> > > elm4Pntr=vabs1-><a class="code" href="classVABSModelPost.html#ab22c953c94473d150d7b45b30833969d">getElement</a>(at);
- <a name="l02682"></a>02682 <span class="keywordtype">bool</span> shouldDelete=elm4Pntr.<a class="code" href="classautoPntr.html#aeff67239fbb801ebdf76d8e8e6f242bc">deleteStatus</a>();
- <a name="l02683"></a>02683 <span class="keywordflow">return</span> <a class="code" href="classautoPntr.html">autoPntr<VABSElementInfo<dataType,matrixStaticVectCol<dataType,6></a> > >(<span class="keyword">new</span> <a class="code" href="classVABS2ElmInfo__fromVABS1ElmInfo.html">VABS2ElmInfo_fromVABS1ElmInfo<dataType></a>(elm4Pntr.<a class="code" href="classautoPntr.html#a3533ca63305b90c93c617ca4cb40f9e6">release</a>(),shouldDelete),<span class="keyword">true</span>);
- <a name="l02684"></a>02684 }
- <a name="l02685"></a>02685
- <a name="l02686"></a>02686 <span class="comment">// void getFailList(const matrixStaticVectCol<dataType>& beamStrain, std::list<failPoint<dataType>>& failList)</span>
- <a name="l02687"></a>02687 <span class="comment">// {</span>
- <a name="l02688"></a>02688 <span class="comment">// if(vabs1==NULL)</span>
- <a name="l02689"></a>02689 <span class="comment">// throw eMsg("VABS2Model_VABS1Model::getFailList(): The vabs 1 model has not been set");</span>
- <a name="l02690"></a>02690 <span class="comment">// vabs1->getFailList(beamStrain,failList);</span>
- <a name="l02691"></a>02691 <span class="comment">// }</span>
- <a name="l02692"></a>02692
- <a name="l02693"></a>02693 };
- <a name="l02694"></a>02694
- <a name="l02695"></a>02695 <span class="comment">// the vabs module determines various physical quantities with respect to a mesh scaled</span>
- <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>
- <a name="l02697"></a>02697 <span class="comment">// However the real chord length is something else lets say c.</span>
- <a name="l02698"></a>02698 <span class="comment">// In this case we need a scale (real chord length)/(reference length)</span>
- <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>
- <a name="l02700"></a>02700 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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>
- <a name="l02702"></a>02702 {
- <a name="l02703"></a>02703 <span class="keyword">private</span>:
- <a name="l02704"></a>02704
- <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>
- <a name="l02706"></a>02706
- <a name="l02707"></a>02707 <span class="keyword">protected</span>:
- <a name="l02708"></a>02708
- <a name="l02709"></a>02709 <span class="comment">// #####################################</span>
- <a name="l02710"></a>02710 <span class="comment">// The followign methods return coefficients that convert various quantities between the reference and real system</span>
- <a name="l02711"></a>02711 <span class="comment">// #####################################</span>
- <a name="l02712"></a>02712
- <a name="l02713"></a>02713 <span class="comment">// these methods simply scale the length</span>
- <a name="l02714"></a>02714
- <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>
- <a name="l02716"></a>02716 <span class="keyword"> </span>{
- <a name="l02717"></a>02717 <span class="keywordflow">return</span> <a class="code" href="namespaceViewWake.html#a7f186dc00f139878e136f6c3b4d10e71">scale</a>;
- <a name="l02718"></a>02718 }
- <a name="l02719"></a>02719
- <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>
- <a name="l02721"></a>02721 <span class="keyword"> </span>{
- <a name="l02722"></a>02722 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#aac7e81203dc733ae8a467ca89c34d640">referenceToRealScale</a>(defaultScale);
- <a name="l02723"></a>02723 }
- <a name="l02724"></a>02724
- <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>
- <a name="l02726"></a>02726 <span class="keyword"> </span>{
- <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>;
- <a name="l02728"></a>02728 }
- <a name="l02729"></a>02729
- <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>
- <a name="l02731"></a>02731 <span class="keyword"> </span>{
- <a name="l02732"></a>02732 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#a17caca9a9ac0e89bdf1bcddd35d7382b">realToReferenceScale</a>(defaultScale);
- <a name="l02733"></a>02733 }
- <a name="l02734"></a>02734
- <a name="l02735"></a>02735 <span class="comment">// these methods scale other physical quantities based on a length scale given as an argument</span>
- <a name="l02736"></a>02736
- <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>
- <a name="l02738"></a>02738 <span class="keyword"> </span>{
- <a name="l02739"></a>02739 <span class="keywordflow">return</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>(1.0)/lengthScale;
- <a name="l02740"></a>02740 }
- <a name="l02741"></a>02741
- <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>
- <a name="l02743"></a>02743 <span class="keyword"> </span>{
- <a name="l02744"></a>02744 <span class="keywordflow">return</span> lengthScale;
- <a name="l02745"></a>02745 }
- <a name="l02746"></a>02746
- <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>
- <a name="l02748"></a>02748 <span class="keyword"> </span>{
- <a name="l02749"></a>02749 <span class="keywordflow">return</span> pow(lengthScale,2.0);
- <a name="l02750"></a>02750 }
- <a name="l02751"></a>02751
- <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>
- <a name="l02753"></a>02753 <span class="keyword"> </span>{
- <a name="l02754"></a>02754 <span class="keywordflow">return</span> <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>(1.0)/lengthScale;
- <a name="l02755"></a>02755 }
- <a name="l02756"></a>02756
- <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>
- <a name="l02758"></a>02758 <span class="keyword"> </span>{
- <a name="l02759"></a>02759 <span class="keywordflow">return</span> pow(lengthScale,2.0);
- <a name="l02760"></a>02760 }
- <a name="l02761"></a>02761
- <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>
- <a name="l02763"></a>02763 <span class="keyword"> </span>{
- <a name="l02764"></a>02764 <span class="keywordflow">return</span> pow(lengthScale,4.0);
- <a name="l02765"></a>02765 }
- <a name="l02766"></a>02766
- <a name="l02767"></a>02767 <span class="keyword">public</span>:
- <a name="l02768"></a>02768
- <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)
- <a name="l02770"></a>02770 {}
- <a name="l02771"></a>02771
- <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<dataType></a>& asg) : defaultScale(asg.defaultScale)
- <a name="l02773"></a>02773 {}
- <a name="l02774"></a>02774
- <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>()
- <a name="l02776"></a>02776 {}
- <a name="l02777"></a>02777
- <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)
- <a name="l02779"></a>02779 {
- <a name="l02780"></a>02780 defaultScale=defaultScale_in;
- <a name="l02781"></a>02781 }
- <a name="l02782"></a>02782
- <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>& <a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>()<span class="keyword"> const</span>
- <a name="l02784"></a>02784 <span class="keyword"> </span>{
- <a name="l02785"></a>02785 <span class="keywordflow">return</span> defaultScale;
- <a name="l02786"></a>02786 }
- <a name="l02787"></a>02787 };
- <a name="l02788"></a>02788
- <a name="l02789"></a>02789 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> abstractType>
- <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><dataType> , <span class="keyword">public</span> abstractType
- <a name="l02791"></a>02791 {
- <a name="l02792"></a>02792 <span class="keyword">protected</span>:
- <a name="l02793"></a>02793
- <a name="l02794"></a>02794 <span class="keyword">virtual</span> abstractType& <a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>()=0;
- <a name="l02795"></a>02795 <span class="keyword">virtual</span> <span class="keyword">const</span> abstractType& <a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>() <span class="keyword">const</span>=0;
- <a name="l02796"></a>02796
- <a name="l02797"></a>02797 <span class="keyword">public</span>:
- <a name="l02798"></a>02798
- <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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>>(defaultScale_in)
- <a name="l02800"></a>02800 {}
- <a name="l02801"></a>02801
- <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>()
- <a name="l02803"></a>02803 {}
- <a name="l02804"></a>02804
- <a name="l02805"></a><a class="code" href="classscalingObject.html#ad0f703a14521945e34417f5bbc84ba77">02805</a> <a class="code" href="classscalingObject.html">scalingObject<dataType,abstractType></a>& <a class="code" href="classscalingObject.html#ad0f703a14521945e34417f5bbc84ba77">setDefaultScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in)
- <a name="l02806"></a>02806 {
- <a name="l02807"></a>02807 this-><a class="code" href="classscalingObject.html#ad0f703a14521945e34417f5bbc84ba77">scaling<dataType>::setDefaultScale</a>(defaultScale_in);
- <a name="l02808"></a>02808 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l02809"></a>02809 }
- <a name="l02810"></a>02810 };
- <a name="l02811"></a>02811
- <a name="l02812"></a>02812 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> abstractType>
- <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><dataType,abstractType>
- <a name="l02814"></a>02814 {
- <a name="l02815"></a>02815 <span class="keyword">private</span>:
- <a name="l02816"></a>02816
- <a name="l02817"></a>02817 abstractType& ref;
- <a name="l02818"></a>02818
- <a name="l02819"></a>02819 <span class="keyword">protected</span>:
- <a name="l02820"></a>02820
- <a name="l02821"></a><a class="code" href="classscalingObject__Ref.html#ab9e979697cb6fc23c900ec0095106d39">02821</a> abstractType& <a class="code" href="classscalingObject__Ref.html#ab9e979697cb6fc23c900ec0095106d39">getAbstract</a>()
- <a name="l02822"></a>02822 {
- <a name="l02823"></a>02823 <span class="keywordflow">return</span> ref;
- <a name="l02824"></a>02824 }
- <a name="l02825"></a>02825
- <a name="l02826"></a><a class="code" href="classscalingObject__Ref.html#ac45acc04491ab272ab2b6c3e66008251">02826</a> <span class="keyword">const</span> abstractType& <a class="code" href="classscalingObject__Ref.html#ab9e979697cb6fc23c900ec0095106d39">getAbstract</a>()<span class="keyword"> const</span>
- <a name="l02827"></a>02827 <span class="keyword"> </span>{
- <a name="l02828"></a>02828 <span class="keywordflow">return</span> ref;
- <a name="l02829"></a>02829 }
- <a name="l02830"></a>02830
- <a name="l02831"></a>02831 <span class="keyword">public</span>:
- <a name="l02832"></a>02832
- <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& ref_in,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> defaultScale_in=1.0) : ref(ref_in)
- <a name="l02834"></a>02834 {
- <a name="l02835"></a>02835 this-><a class="code" href="classscalingObject.html#ad0f703a14521945e34417f5bbc84ba77">setDefaultScale</a>(defaultScale_in);
- <a name="l02836"></a>02836 }
- <a name="l02837"></a>02837
- <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>()
- <a name="l02839"></a>02839 {}
- <a name="l02840"></a>02840 };
- <a name="l02841"></a>02841
- <a name="l02842"></a>02842 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> abstractType>
- <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><dataType,abstractType>
- <a name="l02844"></a>02844 {
- <a name="l02845"></a>02845 <span class="keyword">private</span>:
- <a name="l02846"></a>02846
- <a name="l02847"></a>02847 abstractType* pAbstract;
- <a name="l02848"></a>02848 <span class="keywordtype">bool</span> canDelete;
- <a name="l02849"></a>02849
- <a name="l02850"></a>02850 <span class="keyword">protected</span>:
- <a name="l02851"></a>02851
- <a name="l02852"></a><a class="code" href="classscalingObject__Pntr.html#a5879fda88e332f23c6840911acfff092">02852</a> abstractType& <a class="code" href="classscalingObject__Pntr.html#a5879fda88e332f23c6840911acfff092">getAbstract</a>()
- <a name="l02853"></a>02853 {
- <a name="l02854"></a>02854 <span class="keywordflow">if</span>(pAbstract==NULL)
- <a name="l02855"></a>02855 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"scalingObject_Pntr::getAbstract(): Pointer to the abstract type is NULL"</span>);
- <a name="l02856"></a>02856 <span class="keywordflow">return</span> *pAbstract;
- <a name="l02857"></a>02857 }
- <a name="l02858"></a>02858
- <a name="l02859"></a><a class="code" href="classscalingObject__Pntr.html#a493bea743297d11a1bca4e7fe675e022">02859</a> <span class="keyword">const</span> abstractType& <a class="code" href="classscalingObject__Pntr.html#a5879fda88e332f23c6840911acfff092">getAbstract</a>()<span class="keyword"> const</span>
- <a name="l02860"></a>02860 <span class="keyword"> </span>{
- <a name="l02861"></a>02861 <span class="keywordflow">if</span>(pAbstract==NULL)
- <a name="l02862"></a>02862 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"scalingObject_Pntr::getAbstract(): Pointer to the abstract type is NULL"</span>);
- <a name="l02863"></a>02863 <span class="keywordflow">return</span> *pAbstract;
- <a name="l02864"></a>02864 }
- <a name="l02865"></a>02865
- <a name="l02866"></a>02866 <span class="keyword">public</span>:
- <a name="l02867"></a>02867
- <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)
- <a name="l02869"></a>02869 {
- <a name="l02870"></a>02870 this-><a class="code" href="classscalingObject.html#ad0f703a14521945e34417f5bbc84ba77">setDefaultScale</a>(defaultScale_in);
- <a name="l02871"></a>02871 }
- <a name="l02872"></a>02872
- <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>()
- <a name="l02874"></a>02874 {
- <a name="l02875"></a>02875 <span class="keywordflow">if</span>(canDelete && pAbstract!=NULL)
- <a name="l02876"></a>02876 <span class="keyword">delete</span> pAbstract;
- <a name="l02877"></a>02877 }
- <a name="l02878"></a>02878
- <a name="l02879"></a><a class="code" href="classscalingObject__Pntr.html#afbdd6daef451689dc355edb8c721138e">02879</a> <a class="code" href="classscalingObject__Pntr.html">scalingObject_Pntr<dataType,abstractType></a>& <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>)
- <a name="l02880"></a>02880 {
- <a name="l02881"></a>02881 <span class="keywordflow">if</span>(canDelete && pAbstract!=NULL)
- <a name="l02882"></a>02882 <span class="keyword">delete</span> pAbstract;
- <a name="l02883"></a>02883
- <a name="l02884"></a>02884 pAbstract=ref_in;
- <a name="l02885"></a>02885 canDelete=canDelete_in;
- <a name="l02886"></a>02886
- <a name="l02887"></a>02887 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l02888"></a>02888 }
- <a name="l02889"></a>02889 };
- <a name="l02890"></a>02890
- <a name="l02891"></a>02891 <span class="comment">// This is a template that require specialization</span>
- <a name="l02892"></a>02892 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> strainType>
- <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<dataType,VABSElementInfo<dataType,matrixStaticVectCol<dataType,4> > ></span>
- <a name="l02894"></a>02894 {};
- <a name="l02895"></a>02895
- <a name="l02896"></a>02896 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,4> > : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classscalingObject.html">scalingObject</a><dataType,VABSElementInfo<dataType,matrixStaticVectCol<dataType,4> > >
- <a name="l02898"></a>02898 {
- <a name="l02899"></a>02899 <span class="keyword">public</span>:
- <a name="l02900"></a>02900
- <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>()
- <a name="l02902"></a>02902 {}
- <a name="l02903"></a>02903
- <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>()
- <a name="l02905"></a>02905 {}
- <a name="l02906"></a>02906
- <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<dataType,4></a>& beamStrain)
- <a name="l02908"></a>02908 {
- <a name="l02909"></a>02909 <span class="keywordflow">return</span> this->fail_Scaled(s,t,beamStrain,this->getDefaultScale());
- <a name="l02910"></a>02910 }
- <a name="l02911"></a>02911
- <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<dataType,4></a>& beamStrain,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)
- <a name="l02913"></a>02913 {
- <a name="l02914"></a>02914 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data<dataType,4></a> scaledBeamStrain;
- <a name="l02915"></a>02915
- <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);
- <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->curvatureScale(this->realToReferenceScale(realScale));
- <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->curvatureScale(this->realToReferenceScale(realScale));
- <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->curvatureScale(this->realToReferenceScale(realScale));
- <a name="l02920"></a>02920
- <a name="l02921"></a>02921 <span class="keywordflow">return</span> this->getAbstract().fail(s,t,scaledBeamStrain);
- <a name="l02922"></a>02922 }
- <a name="l02923"></a>02923 };
- <a name="l02924"></a>02924
- <a name="l02925"></a>02925 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixStaticVectCol.html">matrixStaticVectCol</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,6> > : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classscalingObject.html">scalingObject</a><dataType,VABSElementInfo<dataType,matrixStaticVectCol<dataType,6> > >
- <a name="l02927"></a>02927 {
- <a name="l02928"></a>02928 <span class="keyword">public</span>:
- <a name="l02929"></a>02929
- <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>()
- <a name="l02931"></a>02931 {}
- <a name="l02932"></a>02932
- <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>()
- <a name="l02934"></a>02934 {}
- <a name="l02935"></a>02935
- <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<dataType,6></a>& beamStrain)
- <a name="l02937"></a>02937 {
- <a name="l02938"></a>02938 <span class="keywordflow">return</span> this->fail_Scaled(s,t,beamStrain,this->getDefaultScale());
- <a name="l02939"></a>02939 }
- <a name="l02940"></a>02940
- <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<dataType,6></a>& beamStrain,<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)
- <a name="l02942"></a>02942 {
- <a name="l02943"></a>02943 <a class="code" href="classmatrixRdWtStaticVectCol__Data.html">matrixRdWtStaticVectCol_Data<dataType,6></a> scaledBeamStrain;
- <a name="l02944"></a>02944
- <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);
- <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);
- <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);
- <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->curvatureScale(this->realToReferenceScale(realScale));
- <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->curvatureScale(this->realToReferenceScale(realScale));
- <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->curvatureScale(this->realToReferenceScale(realScale));
- <a name="l02951"></a>02951
- <a name="l02952"></a>02952 <span class="keywordflow">return</span> this->getAbstract().fail(s,t,scaledBeamStrain);
- <a name="l02953"></a>02953 }
- <a name="l02954"></a>02954 };
- <a name="l02955"></a>02955
- <a name="l02956"></a>02956 <span class="comment">// this is a template that require partial specialization according to beamMtxType </span>
- <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>
- <a name="l02958"></a>02958 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> beamMtxType>
- <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<dataType,VABSModelBeamMatrix<beamMtxType> ></span>
- <a name="l02960"></a>02960 {};
- <a name="l02961"></a>02961
- <a name="l02962"></a>02962 <span class="comment">// beamMtxType is matrixRdWtStaticSqr_Data<dataType,4> for Bernoulli type</span>
- <a name="l02963"></a>02963 <span class="comment">// is matrixRdWtStaticSqr_Data<dataType,6> for Timoshenko type</span>
- <a name="l02964"></a>02964 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,4> > : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classscalingObject.html">scalingObject</a><dataType,VABSModelBeamMatrix<matrixRdWtStaticSqr_Data<dataType,4> > >
- <a name="l02966"></a>02966 {
- <a name="l02967"></a>02967 <span class="keyword">public</span>:
- <a name="l02968"></a>02968
- <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>()
- <a name="l02970"></a>02970 {}
- <a name="l02971"></a>02971
- <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>()
- <a name="l02973"></a>02973 {}
- <a name="l02974"></a>02974
- <a name="l02975"></a>02975 <span class="comment">//This retrieve the beam matrix</span>
- <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<dataType,4></a> beamMatrix()
- <a name="l02977"></a>02977 {
- <a name="l02978"></a>02978 <span class="keywordflow">return</span> this->beamMatrix_Scaled(this->getDefaultScale());
- <a name="l02979"></a>02979 }
- <a name="l02980"></a>02980
- <a name="l02981"></a>02981 <span class="comment">//This retrieve the beam matrix</span>
- <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<dataType,4></a> beamMatrix_Scaled(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)
- <a name="l02983"></a>02983 {
- <a name="l02984"></a>02984 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,4></a> retVal;
- <a name="l02985"></a>02985
- <a name="l02986"></a>02986 retVal=this->getAbstract().beamMatrix();
- <a name="l02987"></a>02987
- <a name="l02988"></a>02988 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> rowScale;
- <a name="l02989"></a>02989 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> colScale;
- <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><4;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l02991"></a>02991 {
- <a name="l02992"></a>02992 <span class="keywordflow">if</span>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>==0)
- <a name="l02993"></a>02993 rowScale=this->forceScale(referenceToRealScale(realScale));
- <a name="l02994"></a>02994 <span class="keywordflow">else</span>
- <a name="l02995"></a>02995 rowScale=this->momentScale(referenceToRealScale(realScale));
- <a name="l02996"></a>02996 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<4;j++)
- <a name="l02997"></a>02997 {
- <a name="l02998"></a>02998 <span class="keywordflow">if</span>(j==0)
- <a name="l02999"></a>02999 colScale=1.0;
- <a name="l03000"></a>03000 <span class="keywordflow">else</span>
- <a name="l03001"></a>03001 colScale=this->curvatureScale(realToReferenceScale(realScale));
- <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;
- <a name="l03003"></a>03003 }
- <a name="l03004"></a>03004 }
- <a name="l03005"></a>03005
- <a name="l03006"></a>03006 <span class="keywordflow">return</span> retVal;
- <a name="l03007"></a>03007 }
- <a name="l03008"></a>03008 };
- <a name="l03009"></a>03009
- <a name="l03010"></a>03010 <span class="comment">// beamMtxType is matrixRdWtStaticSqr_Data<dataType,4> for Bernoulli type</span>
- <a name="l03011"></a>03011 <span class="comment">// is matrixRdWtStaticSqr_Data<dataType,6> for Timoshenko type</span>
- <a name="l03012"></a>03012 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,6> > : <span class="keyword">public</span> <span class="keyword">virtual</span> <a class="code" href="classscalingObject.html">scalingObject</a><dataType,VABSModelBeamMatrix<matrixRdWtStaticSqr_Data<dataType,6> > >
- <a name="l03014"></a>03014 {
- <a name="l03015"></a>03015 <span class="keyword">public</span>:
- <a name="l03016"></a>03016
- <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>()
- <a name="l03018"></a>03018 {}
- <a name="l03019"></a>03019
- <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>()
- <a name="l03021"></a>03021 {}
- <a name="l03022"></a>03022
- <a name="l03023"></a>03023 <span class="comment">//This retrieve the beam matrix</span>
- <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<dataType,6></a> beamMatrix()
- <a name="l03025"></a>03025 {
- <a name="l03026"></a>03026 <span class="keywordflow">return</span> this->beamMatrix_Scaled(this->getDefaultScale());
- <a name="l03027"></a>03027 }
- <a name="l03028"></a>03028
- <a name="l03029"></a>03029 <span class="comment">//This retrieve the beam matrix</span>
- <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<dataType,6></a> beamMatrix_Scaled(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> realScale)
- <a name="l03031"></a>03031 {
- <a name="l03032"></a>03032 <a class="code" href="classmatrixRdWtStaticSqr__Data.html">matrixRdWtStaticSqr_Data<dataType,6></a> retVal;
- <a name="l03033"></a>03033
- <a name="l03034"></a>03034 retVal=this->getAbstract().beamMatrix();
- <a name="l03035"></a>03035
- <a name="l03036"></a>03036 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> rowScale;
- <a name="l03037"></a>03037 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> colScale;
- <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><6;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l03039"></a>03039 {
- <a name="l03040"></a>03040 <span class="keywordflow">if</span>(<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a><3)
- <a name="l03041"></a>03041 rowScale=this->forceScale(referenceToRealScale(realScale));
- <a name="l03042"></a>03042 <span class="keywordflow">else</span>
- <a name="l03043"></a>03043 rowScale=this->momentScale(referenceToRealScale(realScale));
- <a name="l03044"></a>03044 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> j=0;j<6;j++)
- <a name="l03045"></a>03045 {
- <a name="l03046"></a>03046 <span class="keywordflow">if</span>(j<3)
- <a name="l03047"></a>03047 colScale=1.0;
- <a name="l03048"></a>03048 <span class="keywordflow">else</span>
- <a name="l03049"></a>03049 colScale=this->curvatureScale(realToReferenceScale(realScale));
- <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;
- <a name="l03051"></a>03051 }
- <a name="l03052"></a>03052 }
- <a name="l03053"></a>03053
- <a name="l03054"></a>03054 <span class="keywordflow">return</span> retVal;
- <a name="l03055"></a>03055 }
- <a name="l03056"></a>03056 };
- <a name="l03057"></a>03057
- <a name="l03058"></a>03058 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><dataType,cxAreaIntProp<dataType> >
- <a name="l03060"></a>03060 {
- <a name="l03061"></a>03061 <span class="keyword">public</span>:
- <a name="l03062"></a>03062
- <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>()
- <a name="l03064"></a>03064 {}
- <a name="l03065"></a>03065
- <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>()
- <a name="l03067"></a>03067 {}
- <a name="l03068"></a>03068
- <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>
- <a name="l03070"></a>03070 <span class="keyword"> </span>{
- <a name="l03071"></a>03071 <span class="keywordflow">return</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#abe8a6ee425c5aa6ac3bb864af82e1b56">getArea_Scaled</a>(this-><a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>());
- <a name="l03072"></a>03072 }
- <a name="l03073"></a>03073
- <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>
- <a name="l03075"></a>03075 <span class="keyword"> </span>{
- <a name="l03076"></a>03076 <span class="keywordflow">return</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#ad02f1edb8c48911ea5b4430f83c8ccb8">getXBar_Scaled</a>(this-><a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>());
- <a name="l03077"></a>03077 }
- <a name="l03078"></a>03078
- <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>
- <a name="l03080"></a>03080 <span class="keyword"> </span>{
- <a name="l03081"></a>03081 <span class="keywordflow">return</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#a7a827480a931c0c7b50529c17fa37017">getYBar_Scaled</a>(this-><a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>());
- <a name="l03082"></a>03082 }
- <a name="l03083"></a>03083
- <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>
- <a name="l03085"></a>03085 <span class="keyword"> </span>{
- <a name="l03086"></a>03086 <span class="keywordflow">return</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#a6e930f1f61b6551b5d4dd17ef8fd9658">getIxx_Scaled</a>(this-><a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>());
- <a name="l03087"></a>03087 }
- <a name="l03088"></a>03088
- <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>
- <a name="l03090"></a>03090 <span class="keyword"> </span>{
- <a name="l03091"></a>03091 <span class="keywordflow">return</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#aa6e5102ea881b7bc2b9f382516b58f34">getIxy_Scaled</a>(this-><a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>());
- <a name="l03092"></a>03092 }
- <a name="l03093"></a>03093
- <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>
- <a name="l03095"></a>03095 <span class="keyword"> </span>{
- <a name="l03096"></a>03096 <span class="keywordflow">return</span> <a class="code" href="classscalingObject__cxAreaIntProp.html#a99d4f994ddea6a7ab4d6ccaae9c725e9">getIyy_Scaled</a>(this-><a class="code" href="classscaling.html#aef899741c72755a4f14606daa85a821e">getDefaultScale</a>());
- <a name="l03097"></a>03097 }
- <a name="l03098"></a>03098
- <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>
- <a name="l03100"></a>03100 <span class="keyword"> </span>{
- <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-><a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>().getArea());
- <a name="l03102"></a>03102 }
- <a name="l03103"></a>03103
- <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>
- <a name="l03105"></a>03105 <span class="keyword"> </span>{
- <a name="l03106"></a>03106 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#aac7e81203dc733ae8a467ca89c34d640">referenceToRealScale</a>(realScale)*(this-><a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>().getXBar());
- <a name="l03107"></a>03107 }
- <a name="l03108"></a>03108
- <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>
- <a name="l03110"></a>03110 <span class="keyword"> </span>{
- <a name="l03111"></a>03111 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#aac7e81203dc733ae8a467ca89c34d640">referenceToRealScale</a>(realScale)*(this-><a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>().getYBar());
- <a name="l03112"></a>03112 }
- <a name="l03113"></a>03113
- <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>
- <a name="l03115"></a>03115 <span class="keyword"> </span>{
- <a name="l03116"></a>03116 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#af84bc45022ad992488c57661462c696f">secondMomentScale</a>(realScale)*(this-><a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>().getIxx());
- <a name="l03117"></a>03117 }
- <a name="l03118"></a>03118
- <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>
- <a name="l03120"></a>03120 <span class="keyword"> </span>{
- <a name="l03121"></a>03121 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#af84bc45022ad992488c57661462c696f">secondMomentScale</a>(realScale)*(this-><a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>().getIxy());
- <a name="l03122"></a>03122 }
- <a name="l03123"></a>03123
- <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>
- <a name="l03125"></a>03125 <span class="keyword"> </span>{
- <a name="l03126"></a>03126 <span class="keywordflow">return</span> <a class="code" href="classscaling.html#af84bc45022ad992488c57661462c696f">secondMomentScale</a>(realScale)*(this-><a class="code" href="classscalingObject.html#a665c4a8ba3667fe87d1a2004614fcc44">getAbstract</a>().getIyy());
- <a name="l03127"></a>03127 }
- <a name="l03128"></a>03128 };
- <a name="l03129"></a>03129
- <a name="l03130"></a>03130 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> strainType>
- <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><dataType,strainType> , <span class="keyword">public</span> <a class="code" href="classscalingObject__Ref.html">scalingObject_Ref</a><dataType,VABSElementInfo<dataType,strainType> >
- <a name="l03132"></a>03132 {
- <a name="l03133"></a>03133 <span class="keyword">public</span>:
- <a name="l03134"></a>03134
- <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<dataType,strainType></a>& 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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,strainType> >(ref_in,defaultScale_in)
- <a name="l03136"></a>03136 {}
- <a name="l03137"></a>03137
- <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>()
- <a name="l03139"></a>03139 {}
- <a name="l03140"></a>03140 };
- <a name="l03141"></a>03141
- <a name="l03142"></a>03142 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> strainType>
- <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><dataType,strainType> , <span class="keyword">public</span> <a class="code" href="classscalingObject__Pntr.html">scalingObject_Pntr</a><dataType,VABSElementInfo<dataType,strainType> >
- <a name="l03144"></a>03144 {
- <a name="l03145"></a>03145 <span class="keyword">public</span>:
- <a name="l03146"></a>03146
- <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<dataType,strainType></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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,strainType> >(ref_in,defaultScale_in,canDelete_in)
- <a name="l03148"></a>03148 {}
- <a name="l03149"></a>03149
- <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>()
- <a name="l03151"></a>03151 {}
- <a name="l03152"></a>03152 };
- <a name="l03153"></a>03153
- <a name="l03154"></a>03154 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> beamMtxType>
- <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><dataType,beamMtxType> , <span class="keyword">public</span> <a class="code" href="classscalingObject__Ref.html">scalingObject_Ref</a><dataType,VABSModelBeamMatrix<beamMtxType> >
- <a name="l03156"></a>03156 {
- <a name="l03157"></a>03157 <span class="keyword">public</span>:
- <a name="l03158"></a>03158
- <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<beamMtxType></a>& 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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classVABSModelBeamMatrix.html">VABSModelBeamMatrix</a><beamMtxType> >(ref_in,defaultScale_in)
- <a name="l03160"></a>03160 {}
- <a name="l03161"></a>03161
- <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>()
- <a name="l03163"></a>03163 {}
- <a name="l03164"></a>03164
- <a name="l03165"></a>03165 };
- <a name="l03166"></a>03166
- <a name="l03167"></a>03167 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> beamMtxType>
- <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><dataType,beamMtxType> , <span class="keyword">public</span> <a class="code" href="classscalingObject__Pntr.html">scalingObject_Pntr</a><dataType,VABSModelBeamMatrix<beamMtxType> >
- <a name="l03169"></a>03169 {
- <a name="l03170"></a>03170 <span class="keyword">public</span>:
- <a name="l03171"></a>03171
- <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<beamMtxType></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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classVABSModelBeamMatrix.html">VABSModelBeamMatrix</a><beamMtxType> >(ref_in,defaultScale_in,canDelete_in)
- <a name="l03173"></a>03173 {}
- <a name="l03174"></a>03174
- <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>()
- <a name="l03176"></a>03176 {}
- <a name="l03177"></a>03177 };
- <a name="l03178"></a>03178
- <a name="l03179"></a>03179 <span class="keyword">template</span><<span class="keyword">class</span> dataType>
- <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><dataType> , <span class="keyword">public</span> <a class="code" href="classscalingObject__Pntr.html">scalingObject_Pntr</a><dataType,cxAreaIntProp<dataType> >
- <a name="l03181"></a>03181 {
- <a name="l03182"></a>03182 <span class="keyword">public</span>:
- <a name="l03183"></a>03183
- <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<dataType></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><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classcxAreaIntProp.html">cxAreaIntProp</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>> >(ref_in,defaultScale_in,canDelete_in)
- <a name="l03185"></a>03185 {}
- <a name="l03186"></a>03186
- <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>()
- <a name="l03188"></a>03188 {}
- <a name="l03189"></a>03189 };
- <a name="l03190"></a>03190
- <a name="l03191"></a>03191 <span class="keyword">template</span><<span class="keyword">class</span> dataType,<span class="keyword">class</span> strainType>
- <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><scalingObject<dataType,VABSElementInfo<dataType,strainType> > >
- <a name="l03193"></a>03193 {
- <a name="l03194"></a>03194 <span class="keyword">private</span>:
- <a name="l03195"></a>03195
- <a name="l03196"></a>03196 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> scale;
- <a name="l03197"></a>03197 <a class="code" href="classVABSModelPost.html">VABSModelPost<VABSElementInfo<dataType,strainType></a> >* vabsPost;
- <a name="l03198"></a>03198 <span class="keywordtype">bool</span> canDelete;
- <a name="l03199"></a>03199
- <a name="l03200"></a>03200 <span class="keyword">public</span>:
- <a name="l03201"></a>03201
- <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><<a class="code" href="classVABSElementInfo.html">VABSElementInfo<dataType,strainType></a> >* 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)
- <a name="l03203"></a>03203 {}
- <a name="l03204"></a>03204
- <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>()
- <a name="l03206"></a>03206 {
- <a name="l03207"></a>03207 <span class="keywordflow">if</span>(canDelete && vabsPost!=NULL)
- <a name="l03208"></a>03208 <span class="keyword">delete</span> vabsPost;
- <a name="l03209"></a>03209 }
- <a name="l03210"></a>03210
- <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><<a class="code" href="classVABSElementInfo.html">VABSElementInfo<dataType,strainType></a> >* vabsPost_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
- <a name="l03212"></a>03212 {
- <a name="l03213"></a>03213 <span class="keywordflow">if</span>(canDelete && vabsPost!=NULL)
- <a name="l03214"></a>03214 <span class="keyword">delete</span> vabsPost;
- <a name="l03215"></a>03215
- <a name="l03216"></a>03216 vabsPost=vabsPost_in;
- <a name="l03217"></a>03217 canDelete=canDelete_in;
- <a name="l03218"></a>03218 }
- <a name="l03219"></a>03219
- <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<dataType,strainType></a> <a class="code" href="classVABSModelPost__scaling__Pntr.html#acea2890313e51ae4ff031591e3019874">setDefaultScale</a>(<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> scale_in)
- <a name="l03221"></a>03221 {
- <a name="l03222"></a>03222 scale=scale_in;
- <a name="l03223"></a>03223 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l03224"></a>03224 }
- <a name="l03225"></a>03225
- <a name="l03226"></a>03226 <span class="comment">// A method that informs the post process module about the number of elements</span>
- <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>()
- <a name="l03228"></a>03228 {
- <a name="l03229"></a>03229 <span class="keywordflow">return</span> vabsPost-><a class="code" href="classVABSModelPost.html#a476038f832b9ef6181ac62f3874fd0ec">size</a>();
- <a name="l03230"></a>03230 }
- <a name="l03231"></a>03231
- <a name="l03232"></a>03232 <span class="comment">// This is an access method to perform post processing</span>
- <a name="l03233"></a><a class="code" href="classVABSModelPost__scaling__Pntr.html#a0281e6d9a4e0aa85925b0b1db6e14379">03233</a> <a class="code" href="classautoPntr.html">autoPntr<scalingObject<dataType,VABSElementInfo<dataType,strainType></a> > > <a class="code" href="classVABSModelPost__scaling__Pntr.html#a0281e6d9a4e0aa85925b0b1db6e14379">getElement</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)
- <a name="l03234"></a>03234 {
- <a name="l03235"></a>03235 <span class="keywordflow">if</span>(vabsPost==NULL)
- <a name="l03236"></a>03236 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"VABSModelPost_scaling_Pntr::getElement(): The vabsPost is NULL"</span>);
- <a name="l03237"></a>03237
- <a name="l03238"></a>03238 <a class="code" href="classautoPntr.html">autoPntr<VABSElementInfo<dataType,matrixStaticVectCol<dataType,6></a> > > pntrToElm=vabsPost-><a class="code" href="classVABSModelPost.html#ab22c953c94473d150d7b45b30833969d">getElement</a>(at);
- <a name="l03239"></a>03239 <span class="keywordtype">bool</span> deleteStatus=pntrToElm.<a class="code" href="classautoPntr.html#aeff67239fbb801ebdf76d8e8e6f242bc">deleteStatus</a>();
- <a name="l03240"></a>03240 <span class="keywordflow">return</span> <a class="code" href="classautoPntr.html">autoPntr<scalingObject<dataType,VABSElementInfo<dataType,strainType></a> > >(<span class="keyword">new</span> <a class="code" href="classscalingObject__VABSElementInfo__Pntr.html">scalingObject_VABSElementInfo_Pntr<dataType,strainType></a>(pntrToElm.<a class="code" href="classautoPntr.html#a3533ca63305b90c93c617ca4cb40f9e6">release</a>(),scale,deleteStatus),<span class="keyword">true</span>);
- <a name="l03241"></a>03241 }
- <a name="l03242"></a>03242 };
- <a name="l03243"></a>03243
- <a name="l03244"></a>03244 <span class="keyword">template</span><<span class="keyword">class</span> locationType>
- <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>
- <a name="l03246"></a>03246 {
- <a name="l03247"></a>03247 <span class="keyword">public</span>:
- <a name="l03248"></a>03248
- <a name="l03249"></a><a class="code" href="classvabsBladeBase.html#a6601b540f4f698c5c4ab187a396733af">03249</a> <a class="code" href="classvabsBladeBase.html#a6601b540f4f698c5c4ab187a396733af">vabsBladeBase</a>()
- <a name="l03250"></a>03250 {}
- <a name="l03251"></a>03251
- <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>()
- <a name="l03253"></a>03253 {}
- <a name="l03254"></a>03254
- <a name="l03255"></a>03255 <span class="comment">// get the information about the contents</span>
- <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;
- <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;
- <a name="l03258"></a>03258 };
- <a name="l03259"></a>03259
- <a name="l03260"></a>03260 <span class="keyword">template</span><<span class="keyword">class</span> locationType,<span class="keyword">class</span> cxDesignType>
- <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><locationType>
- <a name="l03262"></a>03262 {
- <a name="l03263"></a>03263 <span class="keyword">public</span>:
- <a name="l03264"></a>03264
- <a name="l03265"></a><a class="code" href="classvabsBladeDesign.html#a7a667907852fd406552f5424913011d1">03265</a> <a class="code" href="classvabsBladeDesign.html#a7a667907852fd406552f5424913011d1">vabsBladeDesign</a>()
- <a name="l03266"></a>03266 {}
- <a name="l03267"></a>03267
- <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>()
- <a name="l03269"></a>03269 {}
- <a name="l03270"></a>03270
- <a name="l03271"></a>03271 <span class="comment">// pass in the input parameters</span>
- <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<locationType,cxDesignType></a>* desSrc_in,<span class="keywordtype">bool</span> deleteCXDesignSource=<span class="keyword">false</span>)=0;
- <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;
- <a name="l03274"></a>03274
- <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;
- <a name="l03276"></a>03276 };
- <a name="l03277"></a>03277
- <a name="l03278"></a>03278 <span class="keyword">template</span><<span class="keyword">class</span> locationType,<span class="keyword">class</span> lengthType,<span class="keyword">class</span> beamMtxType>
- <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><locationType>
- <a name="l03280"></a>03280 {
- <a name="l03281"></a>03281 <span class="keyword">public</span>:
- <a name="l03282"></a>03282
- <a name="l03283"></a><a class="code" href="classvabsBladeMatrix.html#a6e05b51606e3f5eaf38ac3e36ba2c4b1">03283</a> <a class="code" href="classvabsBladeMatrix.html#a6e05b51606e3f5eaf38ac3e36ba2c4b1">vabsBladeMatrix</a>()
- <a name="l03284"></a>03284 {}
- <a name="l03285"></a>03285
- <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>()
- <a name="l03287"></a>03287 {}
- <a name="l03288"></a>03288
- <a name="l03289"></a>03289 <span class="comment">// These are the methods the provide the K matrices</span>
- <a name="l03290"></a>03290 <span class="keyword">virtual</span> <a class="code" href="classautoPntr.html">autoPntr<scalingObject<lengthType,VABSModelBeamMatrix<beamMtxType></a> > > <a class="code" href="classvabsBladeMatrix.html#af45b951894c87b45191ddeaa32104638">getMatrix</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)=0;
- <a name="l03291"></a>03291 };
- <a name="l03292"></a>03292
- <a name="l03293"></a>03293 <span class="comment">// template<class locationType,class lengthType,class elmPostType,class cxPostType></span>
- <a name="l03294"></a>03294 <span class="keyword">template</span><<span class="keyword">class</span> locationType,<span class="keyword">class</span> lengthType,<span class="keyword">class</span> elmPostType,<span class="keyword">class</span> areaType>
- <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><locationType> , <span class="keyword">public</span> <a class="code" href="classcrossSectionAreaSource.html">crossSectionAreaSource</a><locationType,areaType>
- <a name="l03296"></a>03296 {
- <a name="l03297"></a>03297 <span class="keyword">public</span>:
- <a name="l03298"></a>03298
- <a name="l03299"></a><a class="code" href="classvabsBladePost.html#a06c0c46ef05c4c222b2ae8b25fec2a4c">03299</a> <a class="code" href="classvabsBladePost.html#a06c0c46ef05c4c222b2ae8b25fec2a4c">vabsBladePost</a>()
- <a name="l03300"></a>03300 {}
- <a name="l03301"></a>03301
- <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>()
- <a name="l03303"></a>03303 {}
- <a name="l03304"></a>03304
- <a name="l03305"></a>03305 <span class="comment">// these are the methods that are used for post processing</span>
- <a name="l03306"></a>03306 <span class="keyword">virtual</span> <a class="code" href="classautoPntr.html">autoPntr<VABSModelPost<elmPostType></a> > <a class="code" href="classvabsBladePost.html#a42e4b85b307b582d2bef59a21de1e365">getPost</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)=0;
- <a name="l03307"></a>03307 <span class="comment">// virtual autoPntr<scalingObject<lengthType,cxPostType> > getCXPost(unsigned long at)=0;</span>
- <a name="l03308"></a>03308 };
- <a name="l03309"></a>03309
- <a name="l03310"></a>03310 <span class="keyword">template</span><<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>
- <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><locationType,cxDesignType> , <span class="keyword">public</span> <a class="code" href="classvabsBladeMatrix.html">vabsBladeMatrix</a><locationType,lengthType,beamMtxType> , <span class="keyword">public</span> <a class="code" href="classvabsBladePost.html">vabsBladePost</a><locationType,lengthType,elmPostType,areaType>
- <a name="l03312"></a>03312 {
- <a name="l03313"></a>03313 <span class="keyword">protected</span>:
- <a name="l03314"></a>03314
- <a name="l03315"></a><a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">03315</a> <a class="code" href="classchordSource.html">chordSource<locationType,lengthType></a>* <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>;
- <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>;
- <a name="l03317"></a>03317
- <a name="l03318"></a>03318 <span class="keyword">public</span>:
- <a name="l03319"></a>03319
- <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<locationType,lengthType></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)
- <a name="l03321"></a>03321 {}
- <a name="l03322"></a>03322
- <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>()
- <a name="l03324"></a>03324 {
- <a name="l03325"></a>03325 <span class="keywordflow">if</span>(<a class="code" href="classvabsBlade.html#a5e760efd8828271a6efd3371f1a8b50c">canDelete</a> && <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>!=NULL)
- <a name="l03326"></a>03326 <span class="keyword">delete</span> <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>;
- <a name="l03327"></a>03327 }
- <a name="l03328"></a>03328
- <a name="l03329"></a>03329 <span class="comment">// set scaling data source</span>
- <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<locationType,lengthType></a>* chordScale_in,<span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>)
- <a name="l03331"></a>03331 {
- <a name="l03332"></a>03332 <span class="keywordflow">if</span>(<a class="code" href="classvabsBlade.html#a5e760efd8828271a6efd3371f1a8b50c">canDelete</a> && <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>!=NULL)
- <a name="l03333"></a>03333 <span class="keyword">delete</span> <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>;
- <a name="l03334"></a>03334
- <a name="l03335"></a>03335 <a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>=chordScale_in;
- <a name="l03336"></a>03336 <a class="code" href="classvabsBlade.html#a5e760efd8828271a6efd3371f1a8b50c">canDelete</a>=canDelete_in;
- <a name="l03337"></a>03337 }
- <a name="l03338"></a>03338 };
- <a name="l03339"></a>03339
- <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>
- <a name="l03341"></a>03341 <span class="comment">// other versions to be implemented later include one where there is one crossSectionGeom for all</span>
- <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>
- <a name="l03343"></a>03343 <span class="keyword">template</span><<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>
- <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><locationType,lengthType,cxDesignType,beamMtxType,scalingObject<dataType,VABSElementInfo<dataType,strainType> >,areaType>
- <a name="l03345"></a>03345 {
- <a name="l03346"></a>03346 <span class="keyword">private</span>:
- <a name="l03347"></a>03347
- <a name="l03348"></a>03348 <span class="comment">// chordSource<locationType,lengthType>* chordScale;</span>
- <a name="l03349"></a>03349 <span class="comment">// bool canDelete;</span>
- <a name="l03350"></a>03350
- <a name="l03351"></a>03351 std::vector<locationType> locations;
- <a name="l03352"></a>03352 std::vector<crossSectionGeom<dataType,cxDesignType>*> cxGeoms;
- <a name="l03353"></a>03353 std::vector<VABSModel<dataType,beamMtxType,VABSElementInfo<dataType,strainType> >*> vabsModels;
- <a name="l03354"></a>03354
- <a name="l03355"></a>03355 <span class="comment">// variables for pre/post processing the mesh</span>
- <a name="l03356"></a>03356 std::vector<cxAreaIntProp_Data<dataType> > meshProps;
- <a name="l03357"></a>03357 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> centerX;
- <a name="l03358"></a>03358 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> centerY;
- <a name="l03359"></a>03359
- <a name="l03360"></a>03360 std::vector<bool> deleteCX;
- <a name="l03361"></a>03361 std::vector<bool> deleteVABS;
- <a name="l03362"></a>03362
- <a name="l03363"></a>03363 <a class="code" href="classcxDesignSource.html">cxDesignSource<locationType,cxDesignType></a>* desSrc;
- <a name="l03364"></a>03364 <span class="keywordtype">bool</span> deleteCXDesignSource;
- <a name="l03365"></a>03365 <span class="keywordtype">bool</span> meshSet;
- <a name="l03366"></a>03366
- <a name="l03367"></a>03367 <span class="keyword">public</span>:
- <a name="l03368"></a>03368
- <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>(
- <a name="l03370"></a>03370 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> size_in=1,
- <a name="l03371"></a>03371 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> centerX_in=0.0,
- <a name="l03372"></a>03372 <a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a> centerY_in=0.0,
- <a name="l03373"></a>03373 <a class="code" href="classchordSource.html">chordSource<locationType,lengthType></a>* chordScale_in=NULL,
- <a name="l03374"></a>03374 <a class="code" href="classcxDesignSource.html">cxDesignSource<locationType,cxDesignType></a>* desSrc_in=NULL,
- <a name="l03375"></a>03375 <span class="keywordtype">bool</span> canDelete_in=<span class="keyword">false</span>,
- <a name="l03376"></a>03376 <span class="keywordtype">bool</span> deleteCXDesignSource_in=<span class="keyword">false</span>)
- <a name="l03377"></a>03377 : <a class="code" href="classvabsBlade.html">vabsBlade</a><locationType,lengthType,cxDesignType,beamMtxType,<a class="code" href="classscalingObject.html">scalingObject</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,<a class="code" href="classVABSElementInfo.html">VABSElementInfo</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,strainType> >,areaType>(chordScale_in,canDelete_in)
- <a name="l03378"></a>03378 , locations(size_in,0.0)
- <a name="l03379"></a>03379 , cxGeoms(size_in,NULL)
- <a name="l03380"></a>03380 , vabsModels(size_in,NULL)
- <a name="l03381"></a>03381 , meshProps(size_in)
- <a name="l03382"></a>03382 , centerX(centerX_in)
- <a name="l03383"></a>03383 , centerY(centerY_in)
- <a name="l03384"></a>03384 , deleteCX(size_in,false)
- <a name="l03385"></a>03385 , deleteVABS(size_in,false)
- <a name="l03386"></a>03386 , desSrc(desSrc_in)
- <a name="l03387"></a>03387 , deleteCXDesignSource(deleteCXDesignSource_in)
- <a name="l03388"></a>03388 , meshSet(false)
- <a name="l03389"></a>03389 {}
- <a name="l03390"></a>03390
- <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>()
- <a name="l03392"></a>03392 {
- <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><cxGeoms.size();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l03394"></a>03394 {
- <a name="l03395"></a>03395 <span class="keywordflow">if</span>(deleteCX[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>] && cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]!=NULL)
- <a name="l03396"></a>03396 <span class="keyword">delete</span> cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>];
- <a name="l03397"></a>03397 <span class="keywordflow">if</span>(deleteVABS[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>] && vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]!=NULL)
- <a name="l03398"></a>03398 <span class="keyword">delete</span> vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>];
- <a name="l03399"></a>03399 }
- <a name="l03400"></a>03400
- <a name="l03401"></a>03401 <span class="keywordflow">if</span>(deleteCXDesignSource && desSrc!=NULL)
- <a name="l03402"></a>03402 <span class="keyword">delete</span> desSrc;
- <a name="l03403"></a>03403 }
- <a name="l03404"></a>03404
- <a name="l03405"></a><a class="code" href="classvabsBlade__vector.html#a7e461b772fe8adc53cee97f286e721ca">03405</a> <a class="code" href="classvabsBlade__vector.html">vabsBlade_vector<dataType,cxDesignType,beamMtxType,strainType,locationType,lengthType></a>& <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<dataType,cxDesignType></a>* cxGeom_in,<a class="code" href="classVABSModel.html">VABSModel</a><<a class="code" href="timoshenko_8cpp.html#a926743e1c2bd9fc382c84014036246c2">dataType</a>,beamMtxType,<a class="code" href="classVABSElementInfo.html">VABSElementInfo<dataType,strainType></a> >* 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>)
- <a name="l03406"></a>03406 {
- <a name="l03407"></a>03407 <span class="keywordflow">if</span>(at>=locations.size())
- <a name="l03408"></a>03408 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::setCX(): The cross section does not exist"</span>);
- <a name="l03409"></a>03409
- <a name="l03410"></a>03410 locations[at]=location_in;
- <a name="l03411"></a>03411
- <a name="l03412"></a>03412 <span class="keywordflow">if</span>(deleteCX[at] && cxGeoms[at]!=NULL)
- <a name="l03413"></a>03413 <span class="keyword">delete</span> cxGeoms[at];
- <a name="l03414"></a>03414 cxGeoms[at]=cxGeom_in;
- <a name="l03415"></a>03415
- <a name="l03416"></a>03416 <span class="keywordflow">if</span>(deleteVABS[at] && vabsModels[at]!=NULL)
- <a name="l03417"></a>03417 <span class="keyword">delete</span> vabsModels[at];
- <a name="l03418"></a>03418 vabsModels[at]=vabsModel_in;
- <a name="l03419"></a>03419
- <a name="l03420"></a>03420 deleteCX[at]=deleteCX_in;
- <a name="l03421"></a>03421 deleteVABS[at]=deleteVABS_in;
- <a name="l03422"></a>03422
- <a name="l03423"></a>03423 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
- <a name="l03424"></a>03424 }
- <a name="l03425"></a>03425
- <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)
- <a name="l03427"></a>03427 {
- <a name="l03428"></a>03428 <span class="keywordflow">if</span>(size_in==this-><a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>())
- <a name="l03429"></a>03429 <span class="keywordflow">return</span>;
- <a name="l03430"></a>03430 <span class="keywordflow">if</span>(size_in<this-><a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>())
- <a name="l03431"></a>03431 {
- <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><cxGeoms.size();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l03433"></a>03433 {
- <a name="l03434"></a>03434 <span class="keywordflow">if</span>(deleteCX[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>] && cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]!=NULL)
- <a name="l03435"></a>03435 <span class="keyword">delete</span> cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>];
- <a name="l03436"></a>03436 <span class="keywordflow">if</span>(deleteVABS[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>] && vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]!=NULL)
- <a name="l03437"></a>03437 <span class="keyword">delete</span> vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>];
- <a name="l03438"></a>03438 }
- <a name="l03439"></a>03439 }
- <a name="l03440"></a>03440
- <a name="l03441"></a>03441 locations.resize(size_in,0.0);
- <a name="l03442"></a>03442 cxGeoms.resize(size_in,NULL);
- <a name="l03443"></a>03443 vabsModels.resize(size_in,NULL);
- <a name="l03444"></a>03444 deleteCX.resize(size_in,<span class="keyword">false</span>);
- <a name="l03445"></a>03445 deleteVABS.resize(size_in,<span class="keyword">false</span>);
- <a name="l03446"></a>03446 }
- <a name="l03447"></a>03447
- <a name="l03448"></a>03448 <span class="comment">// get the information about the contents</span>
- <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>()
- <a name="l03450"></a>03450 {
- <a name="l03451"></a>03451 <span class="keywordflow">return</span> locations.size();
- <a name="l03452"></a>03452 }
- <a name="l03453"></a>03453
- <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)
- <a name="l03455"></a>03455 {
- <a name="l03456"></a>03456 <span class="keywordflow">if</span>(at>=locations.size())
- <a name="l03457"></a>03457 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::getLocation(): The cross section does not exist"</span>);
- <a name="l03458"></a>03458
- <a name="l03459"></a>03459 <span class="keywordflow">return</span> locations[at];
- <a name="l03460"></a>03460 }
- <a name="l03461"></a>03461
- <a name="l03462"></a>03462 <span class="comment">// pass in the input parameters</span>
- <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<locationType,cxDesignType></a>* desSrc_in,<span class="keywordtype">bool</span> deleteCXDesignSource_in=<span class="keyword">false</span>)
- <a name="l03464"></a>03464 {
- <a name="l03465"></a>03465 <span class="keywordflow">if</span>(deleteCXDesignSource && desSrc!=NULL && desSrc!=desSrc_in)
- <a name="l03466"></a>03466 <span class="keyword">delete</span> desSrc;
- <a name="l03467"></a>03467
- <a name="l03468"></a>03468 desSrc=desSrc_in;
- <a name="l03469"></a>03469 deleteCXDesignSource=deleteCXDesignSource_in;
- <a name="l03470"></a>03470 }
- <a name="l03471"></a>03471
- <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>()
- <a name="l03473"></a>03473 {
- <a name="l03474"></a>03474 <span class="keywordflow">if</span>(desSrc==NULL)
- <a name="l03475"></a>03475 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::newDesign(): The design source has not been set"</span>);
- <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><this-><a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l03477"></a>03477 {
- <a name="l03478"></a>03478 <span class="keywordflow">if</span>(cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]==NULL)
- <a name="l03479"></a>03479 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::newDesign(): Not all the cross section geometries have been set"</span>);
- <a name="l03480"></a>03480 <span class="keywordflow">if</span>(vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]==NULL)
- <a name="l03481"></a>03481 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::newDesign(): Not all the vabs models have been set"</span>);
- <a name="l03482"></a>03482 }
- <a name="l03483"></a>03483
- <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><this-><a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l03485"></a>03485 {
- <a name="l03486"></a>03486 cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]->setDesign(desSrc->getCXDesign(locations[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]));
- <a name="l03487"></a>03487
- <a name="l03488"></a>03488 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l03489"></a>03489 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
- <a name="l03490"></a>03490 <a class="code" href="namespaceTIMEALG.html#a3fb3afd05aab47f9f50f1d31f74b420d">TIMEALG::meshCalcStart</a>();
- <a name="l03491"></a>03491 <span class="preprocessor">#endif</span>
- <a name="l03492"></a>03492 <span class="preprocessor"></span>
- <a name="l03493"></a>03493 <a class="code" href="classmesh.html">mesh<dataType></a>* msh=<span class="keyword">new</span> <a class="code" href="classmesh.html">mesh<dataType></a>();
- <a name="l03494"></a>03494 <span class="keywordflow">if</span>(msh==NULL)
- <a name="l03495"></a>03495 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::newDesign(): Failed to create the mesh"</span>);
- <a name="l03496"></a>03496 cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]->getMesh(*msh);
- <a name="l03497"></a>03497
- <a name="l03498"></a>03498 <span class="comment">// generate the mesh statistics</span>
- <a name="l03499"></a>03499 meshProps[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]=msh-><a class="code" href="classmesh.html#a5a1537dc32069794a5295a4a5e506ce7">getProperties</a>();
- <a name="l03500"></a>03500
- <a name="l03501"></a>03501 msh-><a class="code" href="classmesh.html#a16f338040b8caf85f37a48d9eaa1c744">shift</a>(-meshProps[i].xBar,-meshProps[i].yBar);
- <a name="l03502"></a>03502
- <a name="l03503"></a>03503 <span class="comment">// // shift the mesh to the desired origin</span>
- <a name="l03504"></a>03504 <span class="comment">// if(centerX!=0.0 || centerY!=0.0)</span>
- <a name="l03505"></a>03505 <span class="comment">// msh->shift(-centerX,-centerY);</span>
- <a name="l03506"></a>03506
- <a name="l03507"></a>03507 vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]->setMesh(msh,<span class="keyword">true</span>);
- <a name="l03508"></a>03508
- <a name="l03509"></a>03509 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l03510"></a>03510 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a0f6f1e21ec85156faf6da7393aae7287">TIMEALG::meshCalcStop</a>();
- <a name="l03511"></a>03511 <span class="preprocessor">#endif</span>
- <a name="l03512"></a>03512 <span class="preprocessor"></span>
- <a name="l03513"></a>03513 }
- <a name="l03514"></a>03514 meshSet=<span class="keyword">true</span>;
- <a name="l03515"></a>03515 }
- <a name="l03516"></a>03516
- <a name="l03517"></a>03517 <span class="preprocessor">#ifdef ADJOINT_VABS</span>
- <a name="l03518"></a>03518 <span class="preprocessor"></span>
- <a name="l03519"></a>03519 <span class="keywordtype">void</span> highDesign()
- <a name="l03520"></a>03520 {
- <a name="l03521"></a>03521 <span class="keywordflow">if</span>(desSrc==NULL)
- <a name="l03522"></a>03522 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::newDesign(): The design source has not been set"</span>);
- <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><this-><a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l03524"></a>03524 {
- <a name="l03525"></a>03525 <span class="keywordflow">if</span>(cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]==NULL)
- <a name="l03526"></a>03526 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::newDesign(): Not all the cross section geometries have been set"</span>);
- <a name="l03527"></a>03527 <span class="keywordflow">if</span>(vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]==NULL)
- <a name="l03528"></a>03528 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::newDesign(): Not all the vabs models have been set"</span>);
- <a name="l03529"></a>03529 }
- <a name="l03530"></a>03530
- <a name="l03531"></a>03531 <span class="keyword">typename</span> std::vector<VABS1Model_Base<dataType>*>::iterator it=VABS1Model_Base<dataType>::vabsList.begin();
- <a name="l03532"></a>03532 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> nLoop=this-><a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();
- <a name="l03533"></a>03533
- <a name="l03534"></a>03534 std::vector< mesh<dataType>* > msh(nLoop,NULL);
- <a name="l03535"></a>03535
- <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><nLoop;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l03537"></a>03537 {
- <a name="l03538"></a>03538 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <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>);
- <a name="l03540"></a>03540 <a class="code" href="namespaceTIMEALG.html#a3fb3afd05aab47f9f50f1d31f74b420d">TIMEALG::meshCalcStart</a>();
- <a name="l03541"></a>03541 <span class="preprocessor">#endif</span>
- <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<dataType></a>();
- <a name="l03543"></a>03543 <span class="keywordflow">if</span>(msh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]==NULL)
- <a name="l03544"></a>03544 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::newDesign(): Failed to create the mesh"</span>);
- <a name="l03545"></a>03545 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l03546"></a>03546 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a0f6f1e21ec85156faf6da7393aae7287">TIMEALG::meshCalcStop</a>();
- <a name="l03547"></a>03547 <span class="preprocessor">#endif</span>
- <a name="l03548"></a>03548 <span class="preprocessor"></span> }
- <a name="l03549"></a>03549
- <a name="l03550"></a>03550 <span class="comment">// #pragma omp parallel default(shared)</span>
- <a name="l03551"></a>03551 {
- <a name="l03552"></a>03552 <span class="comment">// #pragma omp for schedule(static,1)</span>
- <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><nLoop;<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>++)
- <a name="l03554"></a>03554 {
- <a name="l03555"></a>03555 cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]->setDesign(desSrc->getCXDesign(locations[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]));
- <a name="l03556"></a>03556
- <a name="l03557"></a>03557 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l03558"></a>03558 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
- <a name="l03559"></a>03559 <a class="code" href="namespaceTIMEALG.html#a3fb3afd05aab47f9f50f1d31f74b420d">TIMEALG::meshCalcStart</a>();
- <a name="l03560"></a>03560 <span class="preprocessor">#endif</span>
- <a name="l03561"></a>03561 <span class="preprocessor"></span>
- <a name="l03562"></a>03562 <span class="comment">// mesh<dataType>* msh=new mesh<dataType>();</span>
- <a name="l03563"></a>03563 <span class="comment">// if(msh==NULL)</span>
- <a name="l03564"></a>03564 <span class="comment">// throw eMsg("vabsBlade_vector::newDesign(): Failed to create the mesh");</span>
- <a name="l03565"></a>03565 cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]->getMesh(*msh[i]);
- <a name="l03566"></a>03566
- <a name="l03567"></a>03567 <span class="comment">// generate the mesh statistics</span>
- <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>]->getProperties();
- <a name="l03569"></a>03569 <span class="comment">// cxAreaIntProp_Data<dataType> meshProp=msh->getProperties();</span>
- <a name="l03570"></a>03570
- <a name="l03571"></a>03571 msh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]->shift(-meshProps[i].xBar,-meshProps[i].yBar);
- <a name="l03572"></a>03572
- <a name="l03573"></a>03573 <span class="comment">// // shift the mesh to the desired origin</span>
- <a name="l03574"></a>03574 <span class="comment">// if(centerX!=0.0 || centerY!=0.0)</span>
- <a name="l03575"></a>03575 <span class="comment">// msh->shift(-centerX,-centerY);</span>
- <a name="l03576"></a>03576
- <a name="l03577"></a>03577 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l03578"></a>03578 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a0f6f1e21ec85156faf6da7393aae7287">TIMEALG::meshCalcStop</a>();
- <a name="l03579"></a>03579 <span class="preprocessor">#endif</span>
- <a name="l03580"></a>03580 <span class="preprocessor"></span>
- <a name="l03581"></a>03581 (*it)->buildHighMatrix(msh[i]);
- <a name="l03582"></a>03582 it++;
- <a name="l03583"></a>03583
- <a name="l03584"></a>03584 <span class="comment">// delete msh;</span>
- <a name="l03585"></a>03585 }
- <a name="l03586"></a>03586 }
- <a name="l03587"></a>03587
- <a name="l03588"></a>03588 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i<nLoop;i++)
- <a name="l03589"></a>03589 <span class="keyword">delete</span> msh[i];
- <a name="l03590"></a>03590 }
- <a name="l03591"></a>03591
- <a name="l03592"></a>03592 <span class="keywordtype">void</span> lowDesign()
- <a name="l03593"></a>03593 {
- <a name="l03594"></a>03594 <span class="keywordflow">if</span>(desSrc==NULL)
- <a name="l03595"></a>03595 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::newDesign(): The design source has not been set"</span>);
- <a name="l03596"></a>03596 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i<this-><a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();i++)
- <a name="l03597"></a>03597 {
- <a name="l03598"></a>03598 <span class="keywordflow">if</span>(cxGeoms[i]==NULL)
- <a name="l03599"></a>03599 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::newDesign(): Not all the cross section geometries have been set"</span>);
- <a name="l03600"></a>03600 <span class="keywordflow">if</span>(vabsModels[i]==NULL)
- <a name="l03601"></a>03601 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::newDesign(): Not all the vabs models have been set"</span>);
- <a name="l03602"></a>03602 }
- <a name="l03603"></a>03603
- <a name="l03604"></a>03604 <span class="keyword">typename</span> std::vector<VABS1Model_Base<dataType>*>::iterator it=VABS1Model_Base<dataType>::vabsList.begin();
- <a name="l03605"></a>03605 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> nLoop=this-><a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();
- <a name="l03606"></a>03606
- <a name="l03607"></a>03607 std::vector< mesh<dataType>* > msh(nLoop,NULL);
- <a name="l03608"></a>03608
- <a name="l03609"></a>03609 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i<nLoop;i++)
- <a name="l03610"></a>03610 {
- <a name="l03611"></a>03611 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l03612"></a>03612 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
- <a name="l03613"></a>03613 <a class="code" href="namespaceTIMEALG.html#a3fb3afd05aab47f9f50f1d31f74b420d">TIMEALG::meshCalcStart</a>();
- <a name="l03614"></a>03614 <span class="preprocessor">#endif</span>
- <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<dataType></a>();
- <a name="l03616"></a>03616 <span class="keywordflow">if</span>(msh[i]==NULL)
- <a name="l03617"></a>03617 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::newDesign(): Failed to create the mesh"</span>);
- <a name="l03618"></a>03618 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l03619"></a>03619 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a0f6f1e21ec85156faf6da7393aae7287">TIMEALG::meshCalcStop</a>();
- <a name="l03620"></a>03620 <span class="preprocessor">#endif</span>
- <a name="l03621"></a>03621 <span class="preprocessor"></span> }
- <a name="l03622"></a>03622
- <a name="l03623"></a>03623 <span class="comment">// #pragma omp parallel default(shared)</span>
- <a name="l03624"></a>03624 {
- <a name="l03625"></a>03625 <span class="comment">// #pragma omp for schedule(static,1)</span>
- <a name="l03626"></a>03626 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i<nLoop;i++)
- <a name="l03627"></a>03627 {
- <a name="l03628"></a>03628 cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]->setDesign(desSrc->getCXDesign(locations[i]));
- <a name="l03629"></a>03629
- <a name="l03630"></a>03630 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l03631"></a>03631 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
- <a name="l03632"></a>03632 <a class="code" href="namespaceTIMEALG.html#a3fb3afd05aab47f9f50f1d31f74b420d">TIMEALG::meshCalcStart</a>();
- <a name="l03633"></a>03633 <span class="preprocessor">#endif</span>
- <a name="l03634"></a>03634 <span class="preprocessor"></span>
- <a name="l03635"></a>03635 <span class="comment">// mesh<dataType>* msh=new mesh<dataType>();</span>
- <a name="l03636"></a>03636 <span class="comment">// if(msh==NULL)</span>
- <a name="l03637"></a>03637 <span class="comment">// throw eMsg("vabsBlade_vector::newDesign(): Failed to create the mesh");</span>
- <a name="l03638"></a>03638 cxGeoms[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]->getMesh(*msh[i]);
- <a name="l03639"></a>03639
- <a name="l03640"></a>03640 <span class="comment">// generate the mesh statistics</span>
- <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>]->getProperties();
- <a name="l03642"></a>03642 <span class="comment">// cxAreaIntProp_Data<dataType> meshProp=msh->getProperties();</span>
- <a name="l03643"></a>03643
- <a name="l03644"></a>03644 msh[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]->shift(-meshProps[i].xBar,-meshProps[i].yBar);
- <a name="l03645"></a>03645
- <a name="l03646"></a>03646 <span class="comment">// // shift the mesh to the desired origin</span>
- <a name="l03647"></a>03647 <span class="comment">// if(centerX!=0.0 || centerY!=0.0)</span>
- <a name="l03648"></a>03648 <span class="comment">// msh->shift(-centerX,-centerY);</span>
- <a name="l03649"></a>03649
- <a name="l03650"></a>03650 <span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l03651"></a>03651 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a0f6f1e21ec85156faf6da7393aae7287">TIMEALG::meshCalcStop</a>();
- <a name="l03652"></a>03652 <span class="preprocessor">#endif</span>
- <a name="l03653"></a>03653 <span class="preprocessor"></span>
- <a name="l03654"></a>03654 (*it)->buildLowMatrix(msh[i]);
- <a name="l03655"></a>03655 it++;
- <a name="l03656"></a>03656
- <a name="l03657"></a>03657 <span class="comment">// delete msh;</span>
- <a name="l03658"></a>03658 }
- <a name="l03659"></a>03659
- <a name="l03660"></a>03660 }
- <a name="l03661"></a>03661
- <a name="l03662"></a>03662 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i<nLoop;i++)
- <a name="l03663"></a>03663 <span class="keyword">delete</span> msh[i];
- <a name="l03664"></a>03664 }
- <a name="l03665"></a>03665
- <a name="l03666"></a>03666 <span class="preprocessor">#endif</span>
- <a name="l03667"></a>03667 <span class="preprocessor"></span>
- <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>()
- <a name="l03669"></a>03669 {
- <a name="l03670"></a>03670 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> maxLoop=this-><a class="code" href="classvabsBlade__vector.html#a69ccd6eaa2a7f33194c20bb755a08256">size</a>();
- <a name="l03671"></a>03671
- <a name="l03672"></a>03672 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i<maxLoop;i++)
- <a name="l03673"></a>03673 {
- <a name="l03674"></a>03674 <span class="keywordflow">if</span>(vabsModels[i]==NULL)
- <a name="l03675"></a>03675 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::solve(): Not all the vabs models have been set"</span>);
- <a name="l03676"></a>03676 }
- <a name="l03677"></a>03677
- <a name="l03678"></a>03678 <span class="keywordflow">if</span>(!meshSet)
- <a name="l03679"></a>03679 <a class="code" href="classvabsBlade__vector.html#ade73ef7d1c851840595f6628d9ee3daf">newDesign</a>();
- <a name="l03680"></a>03680
- <a name="l03681"></a>03681 <span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
- <a name="l03682"></a>03682 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> << <span class="stringliteral">"Starting the VABS calculations"</span> << std::endl;
- <a name="l03683"></a>03683 <span class="preprocessor">#endif</span>
- <a name="l03684"></a>03684 <span class="preprocessor"></span>
- <a name="l03685"></a>03685 <span class="preprocessor">#ifndef IGNORE_OMP</span>
- <a name="l03686"></a>03686 <span class="preprocessor"></span><span class="preprocessor"> #pragma omp parallel default(shared)</span>
- <a name="l03687"></a>03687 <span class="preprocessor"></span> {
- <a name="l03688"></a>03688 <span class="preprocessor"> #pragma omp for schedule(static,1)</span>
- <a name="l03689"></a>03689 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
- <a name="l03690"></a>03690 <span class="preprocessor"></span>
- <a name="l03691"></a>03691 <span class="keywordflow">for</span>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;i<maxLoop;i++)
- <a name="l03692"></a>03692 {
- <a name="l03693"></a>03693 <span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
- <a name="l03694"></a>03694 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> << <span class="stringliteral">"\tPreparing cross section "</span> << i << std::endl;
- <a name="l03695"></a>03695 <span class="preprocessor">#endif</span>
- <a name="l03696"></a>03696 <span class="preprocessor"></span><span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l03697"></a>03697 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
- <a name="l03698"></a>03698 <span class="preprocessor">#endif</span>
- <a name="l03699"></a>03699 <span class="preprocessor"></span> vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]->buildSVD();
- <a name="l03700"></a>03700 }
- <a name="l03701"></a>03701 <span class="preprocessor">#ifndef IGNORE_OMP</span>
- <a name="l03702"></a>03702 <span class="preprocessor"></span> }
- <a name="l03703"></a>03703 <span class="preprocessor">#endif</span>
- <a name="l03704"></a>03704 <span class="preprocessor"></span>
- <a name="l03705"></a>03705 <span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
- <a name="l03706"></a>03706 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> << <span class="stringliteral">"About to start decomposition"</span> << std::endl;
- <a name="l03707"></a>03707 <span class="preprocessor">#endif</span>
- <a name="l03708"></a>03708 <span class="preprocessor"></span>
- <a name="l03709"></a>03709 <span class="preprocessor">#ifndef IGNORE_OMP</span>
- <a name="l03710"></a>03710 <span class="preprocessor"></span><span class="preprocessor"> #pragma omp parallel default(shared)</span>
- <a name="l03711"></a>03711 <span class="preprocessor"></span> {
- <a name="l03712"></a>03712 <span class="preprocessor"> #pragma omp for schedule(static,1)</span>
- <a name="l03713"></a>03713 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
- <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<maxLoop;i++)
- <a name="l03715"></a>03715 {
- <a name="l03716"></a>03716 <span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
- <a name="l03717"></a>03717 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> << <span class="stringliteral">"\tDecomposing cross section "</span> << i << std::endl;
- <a name="l03718"></a>03718 <span class="preprocessor">#endif</span>
- <a name="l03719"></a>03719 <span class="preprocessor"></span><span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l03720"></a>03720 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
- <a name="l03721"></a>03721 <span class="preprocessor">#endif</span>
- <a name="l03722"></a>03722 <span class="preprocessor"></span> vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]->solveSVD();
- <a name="l03723"></a>03723 }
- <a name="l03724"></a>03724 <span class="preprocessor">#ifndef IGNORE_OMP</span>
- <a name="l03725"></a>03725 <span class="preprocessor"></span> }
- <a name="l03726"></a>03726 <span class="preprocessor">#endif</span>
- <a name="l03727"></a>03727 <span class="preprocessor"></span>
- <a name="l03728"></a>03728 <span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
- <a name="l03729"></a>03729 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> << <span class="stringliteral">"About to finalize the results"</span> << std::endl;
- <a name="l03730"></a>03730 <span class="preprocessor">#endif</span>
- <a name="l03731"></a>03731 <span class="preprocessor"></span>
- <a name="l03732"></a>03732 <span class="preprocessor">#ifndef IGNORE_OMP</span>
- <a name="l03733"></a>03733 <span class="preprocessor"></span><span class="preprocessor"> #pragma omp parallel</span>
- <a name="l03734"></a>03734 <span class="preprocessor"></span> {
- <a name="l03735"></a>03735 <span class="preprocessor"> #pragma omp for schedule(static,1)</span>
- <a name="l03736"></a>03736 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
- <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<maxLoop;i++)
- <a name="l03738"></a>03738 {
- <a name="l03739"></a>03739 <span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
- <a name="l03740"></a>03740 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> << <span class="stringliteral">"\tFinalizing cross section "</span> << i << std::endl;
- <a name="l03741"></a>03741 <span class="preprocessor">#endif</span>
- <a name="l03742"></a>03742 <span class="preprocessor"></span><span class="preprocessor">#ifdef COLLECT_TIMING</span>
- <a name="l03743"></a>03743 <span class="preprocessor"></span> <a class="code" href="namespaceTIMEALG.html#a5d198442c9e929436e8855a6eca905b8">TIMEALG::setCX</a>(i);
- <a name="l03744"></a>03744 <span class="preprocessor">#endif</span>
- <a name="l03745"></a>03745 <span class="preprocessor"></span> vabsModels[<a class="code" href="namespaceCPPL.html#aca67a31b860a54cc09b2519953aa2b39">i</a>]->processSVD();
- <a name="l03746"></a>03746 }
- <a name="l03747"></a>03747 <span class="preprocessor">#ifndef IGNORE_OMP</span>
- <a name="l03748"></a>03748 <span class="preprocessor"></span> }
- <a name="l03749"></a>03749 <span class="preprocessor">#endif</span>
- <a name="l03750"></a>03750 <span class="preprocessor"></span><span class="preprocessor">#ifdef PRINT_VABS_PROGRESS</span>
- <a name="l03751"></a>03751 <span class="preprocessor"></span> <a class="code" href="beamModuleCalc_8cpp.html#abd0ba18a15db2c852c89751bf6e47e89">std::PROGRESS_OUTPUT</a> << <span class="stringliteral">"Done!"</span> << std::endl;
- <a name="l03752"></a>03752 <span class="preprocessor">#endif</span>
- <a name="l03753"></a>03753 <span class="preprocessor"></span> }
- <a name="l03754"></a>03754
- <a name="l03755"></a>03755 <span class="comment">// These are the methods the provide the K matrices</span>
- <a name="l03756"></a><a class="code" href="classvabsBlade__vector.html#ae38d75c181e66138f6af1a029191c1d8">03756</a> <a class="code" href="classautoPntr.html">autoPntr<scalingObject<dataType,VABSModelBeamMatrix<beamMtxType></a> > > <a class="code" href="classvabsBlade__vector.html#ae38d75c181e66138f6af1a029191c1d8">getMatrix</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)
- <a name="l03757"></a>03757 {
- <a name="l03758"></a>03758 <span class="keywordflow">if</span>(at>=locations.size())
- <a name="l03759"></a>03759 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::getMatrix(): The cross section does not exist"</span>);
- <a name="l03760"></a>03760 <span class="keywordflow">if</span>(this-><a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>==NULL)
- <a name="l03761"></a>03761 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::getMatrix(): The chord scale has not been set"</span>);
- <a name="l03762"></a>03762 <span class="keywordflow">if</span>(vabsModels[at]==NULL)
- <a name="l03763"></a>03763 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::getMatrix(): The VABS model has not been set"</span>);
- <a name="l03764"></a>03764
- <a name="l03765"></a>03765 <span class="keywordflow">return</span> <a class="code" href="classautoPntr.html">autoPntr<scalingObject<dataType,VABSModelBeamMatrix<beamMtxType></a> > >(<span class="keyword">new</span> <a class="code" href="classscalingObject__VABSModelBeamMatrix__Pntr.html">scalingObject_VABSModelBeamMatrix_Pntr<lengthType,beamMtxType></a>(vabsModels[at],this-><a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>-><a class="code" href="classchordSource.html#acfdf28524e56a1d81727e1a834d55433">getChord</a>(locations[at]),<span class="keyword">false</span>),<span class="keyword">true</span>);
- <a name="l03766"></a>03766 }
- <a name="l03767"></a>03767
- <a name="l03768"></a>03768 <span class="comment">// these are the methods that are used for post processing</span>
- <a name="l03769"></a><a class="code" href="classvabsBlade__vector.html#ae8759e7e791303386f34dd858e8f4c26">03769</a> <a class="code" href="classautoPntr.html">autoPntr<VABSModelPost<scalingObject<dataType,VABSElementInfo<dataType,strainType></a> > > > <a class="code" href="classvabsBlade__vector.html#ae8759e7e791303386f34dd858e8f4c26">getPost</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> at)
- <a name="l03770"></a>03770 {
- <a name="l03771"></a>03771 <span class="keywordflow">if</span>(at>=locations.size())
- <a name="l03772"></a>03772 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::getPost(): The cross section does not exist"</span>);
- <a name="l03773"></a>03773 <span class="keywordflow">if</span>(this-><a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>==NULL)
- <a name="l03774"></a>03774 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::getPost(): The chord scale has not been set"</span>);
- <a name="l03775"></a>03775 <span class="keywordflow">if</span>(vabsModels[at]==NULL)
- <a name="l03776"></a>03776 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::getPost(): The VABS model has not been set"</span>);
- <a name="l03777"></a>03777
- <a name="l03778"></a>03778 <span class="keywordflow">return</span> <a class="code" href="classautoPntr.html">autoPntr<VABSModelPost<scalingObject<dataType,VABSElementInfo<dataType,strainType></a> > > >(<span class="keyword">new</span> <a class="code" href="classVABSModelPost__scaling__Pntr.html">VABSModelPost_scaling_Pntr<dataType,strainType></a>(vabsModels[at],this-><a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>-><a class="code" href="classchordSource.html#acfdf28524e56a1d81727e1a834d55433">getChord</a>(locations[at]),<span class="keyword">false</span>),<span class="keyword">true</span>);
- <a name="l03779"></a>03779 }
- <a name="l03780"></a>03780
- <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)
- <a name="l03782"></a>03782 {
- <a name="l03783"></a>03783 <span class="keywordflow">if</span>(location<locationType(0.0) || location>locationType(1.0))
- <a name="l03784"></a>03784 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::getCrossSectionArea(): This area source is only defined on the domain of [0,1]"</span>);
- <a name="l03785"></a>03785 <span class="keywordflow">if</span>(this-><a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>==NULL)
- <a name="l03786"></a>03786 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::getCrossSectionArea(): The chordScale object has not been set"</span>);
- <a name="l03787"></a>03787 <span class="keywordflow">if</span>(!meshSet)
- <a name="l03788"></a>03788 <a class="code" href="classvabsBlade__vector.html#ade73ef7d1c851840595f6628d9ee3daf">newDesign</a>();
- <a name="l03789"></a>03789
- <a name="l03790"></a>03790 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> i=0;
- <a name="l03791"></a>03791 <span class="keywordflow">while</span>(location>locations[i] && i<(locations.size()-1))
- <a name="l03792"></a>03792 i++;
- <a name="l03793"></a>03793
- <a name="l03794"></a>03794 <span class="comment">// collect the upper area</span>
- <a name="l03795"></a>03795 <a class="code" href="classscalingObject__cxAreaIntProp__Pntr.html">scalingObject_cxAreaIntProp_Pntr<dataType></a> aHigh(&meshProps[i],this-><a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>-><a class="code" href="classchordSource.html#acfdf28524e56a1d81727e1a834d55433">getChord</a>(location),<span class="keyword">false</span>);
- <a name="l03796"></a>03796
- <a name="l03797"></a>03797 <span class="comment">// check if interpolation is needed... if not just return the value</span>
- <a name="l03798"></a>03798 <span class="keywordflow">if</span>(i==0 || (i==(locations.size()-1) && location>locations[i]) )
- <a name="l03799"></a>03799 <span class="keywordflow">return</span> aHigh.<a class="code" href="classscalingObject__cxAreaIntProp.html#a79fab7baffefb933ebc78dddbb0b84ad">getArea</a>();
- <a name="l03800"></a>03800 <span class="keywordflow">if</span>(locations[i]==locations[i-1])
- <a name="l03801"></a>03801 <span class="keywordflow">return</span> aHigh.getArea();
- <a name="l03802"></a>03802
- <a name="l03803"></a>03803 <span class="comment">// collect the lower matrix</span>
- <a name="l03804"></a>03804 <a class="code" href="classscalingObject__cxAreaIntProp__Pntr.html">scalingObject_cxAreaIntProp_Pntr<dataType></a> aLow(&meshProps[i-1],this-><a class="code" href="classvabsBlade.html#a4d1d2cf1bf5be9849ee3a0af610f431e">chordScale</a>-><a class="code" href="classchordSource.html#acfdf28524e56a1d81727e1a834d55433">getChord</a>(location),<span class="keyword">false</span>);
- <a name="l03805"></a>03805
- <a name="l03806"></a>03806 <span class="comment">// perform the interpolation (linear)</span>
- <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]);
- <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>();
- <a name="l03809"></a>03809 }
- <a name="l03810"></a>03810
- <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>
- <a name="l03812"></a>03812 <span class="keyword"> </span>{
- <a name="l03813"></a>03813 <span class="keywordflow">throw</span> <a class="code" href="classeMsg.html">eMsg</a>(<span class="stringliteral">"vabsBlade_vector::getCrossSectionArea(): The const method has not been implemented"</span>);
- <a name="l03814"></a>03814 <span class="comment">// if(location<locationType(0.0) || location>locationType(1.0))</span>
- <a name="l03815"></a>03815 <span class="comment">// throw eMsg("vabsBlade_vector::getCrossSectionArea(): This area source is only defined on the domain of [0,1]");</span>
- <a name="l03816"></a>03816 <span class="comment">// if(this->chordScale==NULL)</span>
- <a name="l03817"></a>03817 <span class="comment">// throw eMsg("vabsBlade_vector::getCrossSectionArea(): The chordScale object has not been set");</span>
- <a name="l03818"></a>03818 <span class="comment">// if(!meshSet)</span>
- <a name="l03819"></a>03819 <span class="comment">// newDesign();</span>
- <a name="l03820"></a>03820 <span class="comment">// </span>
- <a name="l03821"></a>03821 <span class="comment">// unsigned long i=0;</span>
- <a name="l03822"></a>03822 <span class="comment">// while(location>locations[i] && i<(locations.size()-1))</span>
- <a name="l03823"></a>03823 <span class="comment">// i++;</span>
- <a name="l03824"></a>03824 <span class="comment">// </span>
- <a name="l03825"></a>03825 <span class="comment">// // collect the upper area</span>
- <a name="l03826"></a>03826 <span class="comment">// scalingObject_cxAreaIntProp_Pntr<dataType> aHigh(&meshProps[i],this->chordScale->getChord(location),false);</span>
- <a name="l03827"></a>03827 <span class="comment">// </span>
- <a name="l03828"></a>03828 <span class="comment">// // check if interpolation is needed... if not just return the value</span>
- <a name="l03829"></a>03829 <span class="comment">// if(i==0 || i==(locations.size()-1))</span>
- <a name="l03830"></a>03830 <span class="comment">// return aHigh.getArea();</span>
- <a name="l03831"></a>03831 <span class="comment">// if(locations[i]==locations[i-1])</span>
- <a name="l03832"></a>03832 <span class="comment">// return aHigh.getArea();</span>
- <a name="l03833"></a>03833 <span class="comment">// </span>
- <a name="l03834"></a>03834 <span class="comment">// // collect the lower matrix</span>
- <a name="l03835"></a>03835 <span class="comment">// scalingObject_cxAreaIntProp_Pntr<dataType> aLow(&meshProps[i-1],this->chordScale->getChord(location),false);</span>
- <a name="l03836"></a>03836 <span class="comment">// </span>
- <a name="l03837"></a>03837 <span class="comment">// // perform the interpolation (linear)</span>
- <a name="l03838"></a>03838 <span class="comment">// dataType weight=(location-locations[i-1])/(locations[i]-locations[i-1]);</span>
- <a name="l03839"></a>03839 <span class="comment">// return (dataType(1.0)-weight)*aLow.getArea()+weight*aHigh.getArea();</span>
- <a name="l03840"></a>03840 }
- <a name="l03841"></a>03841
- <a name="l03842"></a>03842 <span class="comment">// autoPntr<scalingObject<lengthType,cxAreaIntProp<dataType> > > getCXPost(unsigned long at)</span>
- <a name="l03843"></a>03843 <span class="comment">// {</span>
- <a name="l03844"></a>03844 <span class="comment">// if(at>=locations.size())</span>
- <a name="l03845"></a>03845 <span class="comment">// throw eMsg("vabsBlade_vector::getCXPost(): The cross section does not exist");</span>
- <a name="l03846"></a>03846 <span class="comment">// if(this->chordScale==NULL)</span>
- <a name="l03847"></a>03847 <span class="comment">// throw eMsg("vabsBlade_vector::getCXPost(): The chord scale has not been set");</span>
- <a name="l03848"></a>03848 <span class="comment">// </span>
- <a name="l03849"></a>03849 <span class="comment">// return autoPntr<scalingObject<lengthType,cxAreaIntProp<dataType> > >(new scalingObject_cxAreaIntProp_Pntr(&meshProps[at],this->chordScale->getChord(locations[at]),false),true);</span>
- <a name="l03850"></a>03850 <span class="comment">// }</span>
- <a name="l03851"></a>03851 };
- <a name="l03852"></a>03852
- <a name="l03853"></a>03853 <span class="keyword">template</span><<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>
- <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