-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbasis__matrix_8h_source.html
136 lines (134 loc) · 32.7 KB
/
basis__matrix_8h_source.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.11"/>
<title>MAST: /home/travis/build/MASTmultiphysics/mast-multiphysics/src/numerics/basis_matrix.h Source File</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtreedata.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
$(document).ready(initResizable);
$(window).load(resizeHeight);
</script>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/searchdata.js"></script>
<script type="text/javascript" src="search/search.js"></script>
<script type="text/javascript">
$(document).ready(function() { init_search(); });
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td id="projectalign" style="padding-left: 0.5em;">
<div id="projectname">MAST
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.11 -->
<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="pages.html"><span>Related Pages</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><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
<div id="nav-tree">
<div id="nav-tree-contents">
<div id="nav-sync" class="sync"></div>
</div>
</div>
<div id="splitbar" style="-moz-user-select:none;"
class="ui-resizable-handle">
</div>
</div>
<script type="text/javascript">
$(document).ready(function(){initNavTree('basis__matrix_8h_source.html','');});
</script>
<div id="doc-content">
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
onkeydown="return searchBox.OnSearchSelectKey(event)">
</div>
<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="javascript:void(0)" frameborder="0"
name="MSearchResults" id="MSearchResults">
</iframe>
</div>
<div class="header">
<div class="headertitle">
<div class="title">basis_matrix.h</div> </div>
</div><!--header-->
<div class="contents">
<a href="basis__matrix_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"> 1</span> <span class="comment">/*</span></div><div class="line"><a name="l00002"></a><span class="lineno"> 2</span> <span class="comment"> * MAST: Multidisciplinary-design Adaptation and Sensitivity Toolkit</span></div><div class="line"><a name="l00003"></a><span class="lineno"> 3</span> <span class="comment"> * Copyright (C) 2013-2019 Manav Bhatia</span></div><div class="line"><a name="l00004"></a><span class="lineno"> 4</span> <span class="comment"> *</span></div><div class="line"><a name="l00005"></a><span class="lineno"> 5</span> <span class="comment"> * This library is free software; you can redistribute it and/or</span></div><div class="line"><a name="l00006"></a><span class="lineno"> 6</span> <span class="comment"> * modify it under the terms of the GNU Lesser General Public</span></div><div class="line"><a name="l00007"></a><span class="lineno"> 7</span> <span class="comment"> * License as published by the Free Software Foundation; either</span></div><div class="line"><a name="l00008"></a><span class="lineno"> 8</span> <span class="comment"> * version 2.1 of the License, or (at your option) any later version.</span></div><div class="line"><a name="l00009"></a><span class="lineno"> 9</span> <span class="comment"> *</span></div><div class="line"><a name="l00010"></a><span class="lineno"> 10</span> <span class="comment"> * This library is distributed in the hope that it will be useful,</span></div><div class="line"><a name="l00011"></a><span class="lineno"> 11</span> <span class="comment"> * but WITHOUT ANY WARRANTY; without even the implied warranty of</span></div><div class="line"><a name="l00012"></a><span class="lineno"> 12</span> <span class="comment"> * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU</span></div><div class="line"><a name="l00013"></a><span class="lineno"> 13</span> <span class="comment"> * Lesser General Public License for more details.</span></div><div class="line"><a name="l00014"></a><span class="lineno"> 14</span> <span class="comment"> *</span></div><div class="line"><a name="l00015"></a><span class="lineno"> 15</span> <span class="comment"> * You should have received a copy of the GNU Lesser General Public</span></div><div class="line"><a name="l00016"></a><span class="lineno"> 16</span> <span class="comment"> * License along with this library; if not, write to the Free Software</span></div><div class="line"><a name="l00017"></a><span class="lineno"> 17</span> <span class="comment"> * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA</span></div><div class="line"><a name="l00018"></a><span class="lineno"> 18</span> <span class="comment"> */</span></div><div class="line"><a name="l00019"></a><span class="lineno"> 19</span> </div><div class="line"><a name="l00020"></a><span class="lineno"> 20</span> </div><div class="line"><a name="l00021"></a><span class="lineno"> 21</span> <span class="preprocessor">#ifndef __mast__structural_basis_matrix_h__</span></div><div class="line"><a name="l00022"></a><span class="lineno"> 22</span> <span class="preprocessor">#define __mast__structural_basis_matrix_h__</span></div><div class="line"><a name="l00023"></a><span class="lineno"> 23</span> </div><div class="line"><a name="l00024"></a><span class="lineno"> 24</span> <span class="comment">// C++ includes</span></div><div class="line"><a name="l00025"></a><span class="lineno"> 25</span> <span class="preprocessor">#include <vector></span></div><div class="line"><a name="l00026"></a><span class="lineno"> 26</span> </div><div class="line"><a name="l00027"></a><span class="lineno"> 27</span> <span class="comment">// libmesh includes</span></div><div class="line"><a name="l00028"></a><span class="lineno"> 28</span> <span class="preprocessor">#include "libmesh/shell_matrix.h"</span></div><div class="line"><a name="l00029"></a><span class="lineno"> 29</span> <span class="preprocessor">#include "libmesh/numeric_vector.h"</span></div><div class="line"><a name="l00030"></a><span class="lineno"> 30</span> </div><div class="line"><a name="l00031"></a><span class="lineno"> 31</span> </div><div class="line"><a name="l00032"></a><span class="lineno"> 32</span> <span class="keyword">namespace </span><a class="code" href="namespace_m_a_s_t.html">MAST</a> {</div><div class="line"><a name="l00033"></a><span class="lineno"> 33</span>  </div><div class="line"><a name="l00034"></a><span class="lineno"> 34</span>  <span class="keyword">template</span> <<span class="keyword">typename</span> T></div><div class="line"><a name="l00035"></a><span class="lineno"> 35</span>  <span class="keyword">class </span>BasisMatrix:</div><div class="line"><a name="l00036"></a><span class="lineno"> 36</span>  <span class="keyword">public</span> libMesh::ShellMatrix<T></div><div class="line"><a name="l00037"></a><span class="lineno"> 37</span>  {</div><div class="line"><a name="l00038"></a><span class="lineno"> 38</span>  <span class="keyword">public</span>:</div><div class="line"><a name="l00039"></a><span class="lineno"> 39</span>  <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#aabfc4979f29a676fde647d20c1e028cf">BasisMatrix</a>(<span class="keyword">const</span> libMesh::Parallel::Communicator &comm_in);</div><div class="line"><a name="l00040"></a><span class="lineno"> 40</span>  </div><div class="line"><a name="l00041"></a><span class="lineno"> 41</span>  <span class="keyword">virtual</span> <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a31dad140b73a77c9ac32254d8744d8ec">~BasisMatrix</a>();</div><div class="line"><a name="l00042"></a><span class="lineno"> 42</span>  </div><div class="line"><a name="l00043"></a><span class="lineno"> 43</span>  </div><div class="line"><a name="l00048"></a><span class="lineno"><a class="line" href="class_m_a_s_t_1_1_basis_matrix.html#a68c8bebc5959478622203699cafcc388"> 48</a></span>  <span class="keyword">virtual</span> libMesh::numeric_index_type <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a68c8bebc5959478622203699cafcc388">m</a> ()<span class="keyword"> const </span>{</div><div class="line"><a name="l00049"></a><span class="lineno"> 49</span>  </div><div class="line"><a name="l00050"></a><span class="lineno"> 50</span>  libmesh_assert(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">modes</a>.size() > 0);</div><div class="line"><a name="l00051"></a><span class="lineno"> 51</span>  <span class="keywordflow">return</span> <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">modes</a>[0]->size();</div><div class="line"><a name="l00052"></a><span class="lineno"> 52</span>  }</div><div class="line"><a name="l00053"></a><span class="lineno"> 53</span>  </div><div class="line"><a name="l00058"></a><span class="lineno"><a class="line" href="class_m_a_s_t_1_1_basis_matrix.html#a47c064073f951c25dbbabfed15b3bbfa"> 58</a></span>  <span class="keyword">virtual</span> libMesh::numeric_index_type <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a47c064073f951c25dbbabfed15b3bbfa">n</a> ()<span class="keyword"> const </span>{</div><div class="line"><a name="l00059"></a><span class="lineno"> 59</span>  </div><div class="line"><a name="l00060"></a><span class="lineno"> 60</span>  libmesh_assert(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">modes</a>.size() > 0);</div><div class="line"><a name="l00061"></a><span class="lineno"> 61</span>  <span class="keywordflow">return</span> (libMesh::numeric_index_type) <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">modes</a>.size();</div><div class="line"><a name="l00062"></a><span class="lineno"> 62</span>  }</div><div class="line"><a name="l00063"></a><span class="lineno"> 63</span>  </div><div class="line"><a name="l00064"></a><span class="lineno"> 64</span>  </div><div class="line"><a name="l00069"></a><span class="lineno"> 69</span>  <span class="keyword">template</span> <<span class="keyword">typename</span> VecType></div><div class="line"><a name="l00070"></a><span class="lineno"><a class="line" href="class_m_a_s_t_1_1_basis_matrix.html#a3bd3324729119fa5602c970adac062b3"> 70</a></span>  <span class="keywordtype">void</span> <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a3bd3324729119fa5602c970adac062b3">vector_mult</a> (libMesh::NumericVector<T>& dest,</div><div class="line"><a name="l00071"></a><span class="lineno"> 71</span>  <span class="keyword">const</span> VecType& arg)<span class="keyword"> const </span>{</div><div class="line"><a name="l00072"></a><span class="lineno"> 72</span>  </div><div class="line"><a name="l00073"></a><span class="lineno"> 73</span>  libmesh_assert(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">modes</a>.size() > 0);</div><div class="line"><a name="l00074"></a><span class="lineno"> 74</span>  libmesh_assert_equal_to(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a68c8bebc5959478622203699cafcc388">m</a>(), dest.size());</div><div class="line"><a name="l00075"></a><span class="lineno"> 75</span>  libmesh_assert_equal_to(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a47c064073f951c25dbbabfed15b3bbfa">n</a>(), arg.size());</div><div class="line"><a name="l00076"></a><span class="lineno"> 76</span>  </div><div class="line"><a name="l00077"></a><span class="lineno"> 77</span>  dest.zero();</div><div class="line"><a name="l00078"></a><span class="lineno"> 78</span>  <span class="keywordflow">for</span> (<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> i=0; i<<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a47c064073f951c25dbbabfed15b3bbfa">n</a>(); i++)</div><div class="line"><a name="l00079"></a><span class="lineno"> 79</span>  dest.add(arg(i), *(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">modes</a>[i]));</div><div class="line"><a name="l00080"></a><span class="lineno"> 80</span>  }</div><div class="line"><a name="l00081"></a><span class="lineno"> 81</span>  </div><div class="line"><a name="l00086"></a><span class="lineno"> 86</span>  <span class="keyword">virtual</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00087"></a><span class="lineno"><a class="line" href="class_m_a_s_t_1_1_basis_matrix.html#a2d1f49f07a0034a6b9a0a3d5a7bf2484"> 87</a></span>  <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a2d1f49f07a0034a6b9a0a3d5a7bf2484">vector_mult</a> (libMesh::NumericVector<T>& dest,</div><div class="line"><a name="l00088"></a><span class="lineno"> 88</span>  <span class="keyword">const</span> libMesh::NumericVector<T>& arg)<span class="keyword"> const </span>{</div><div class="line"><a name="l00089"></a><span class="lineno"> 89</span>  </div><div class="line"><a name="l00090"></a><span class="lineno"> 90</span>  <span class="comment">// not defined for multiplcation with libMesh::NumericVector</span></div><div class="line"><a name="l00091"></a><span class="lineno"> 91</span>  libmesh_assert(<span class="keyword">false</span>);</div><div class="line"><a name="l00092"></a><span class="lineno"> 92</span>  }</div><div class="line"><a name="l00093"></a><span class="lineno"> 93</span>  </div><div class="line"><a name="l00094"></a><span class="lineno"> 94</span>  </div><div class="line"><a name="l00099"></a><span class="lineno"> 99</span>  <span class="keyword">template</span> <<span class="keyword">typename</span> VecType></div><div class="line"><a name="l00100"></a><span class="lineno"> 100</span>  <span class="keywordtype">void</span></div><div class="line"><a name="l00101"></a><span class="lineno"><a class="line" href="class_m_a_s_t_1_1_basis_matrix.html#a9a87a38ce9a6efada5b8b13ce1249bac"> 101</a></span>  <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a9a87a38ce9a6efada5b8b13ce1249bac">vector_mult_transpose</a> (VecType& dest,</div><div class="line"><a name="l00102"></a><span class="lineno"> 102</span>  <span class="keyword">const</span> libMesh::NumericVector<T>& arg)<span class="keyword"> const </span>{</div><div class="line"><a name="l00103"></a><span class="lineno"> 103</span>  </div><div class="line"><a name="l00104"></a><span class="lineno"> 104</span>  libmesh_assert(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">modes</a>.size() > 0);</div><div class="line"><a name="l00105"></a><span class="lineno"> 105</span>  libmesh_assert_equal_to(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a68c8bebc5959478622203699cafcc388">m</a>(), arg.size());</div><div class="line"><a name="l00106"></a><span class="lineno"> 106</span>  libmesh_assert_equal_to(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a47c064073f951c25dbbabfed15b3bbfa">n</a>(), dest.size());</div><div class="line"><a name="l00107"></a><span class="lineno"> 107</span>  </div><div class="line"><a name="l00108"></a><span class="lineno"> 108</span>  dest.setZero(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a47c064073f951c25dbbabfed15b3bbfa">n</a>());</div><div class="line"><a name="l00109"></a><span class="lineno"> 109</span>  <span class="keywordflow">for</span> (<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> i=0; i<<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a47c064073f951c25dbbabfed15b3bbfa">n</a>(); i++)</div><div class="line"><a name="l00110"></a><span class="lineno"> 110</span>  dest(i) = arg.dot(*(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">modes</a>[i]));</div><div class="line"><a name="l00111"></a><span class="lineno"> 111</span>  }</div><div class="line"><a name="l00112"></a><span class="lineno"> 112</span>  </div><div class="line"><a name="l00113"></a><span class="lineno"> 113</span>  </div><div class="line"><a name="l00118"></a><span class="lineno"> 118</span>  <span class="keyword">virtual</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00119"></a><span class="lineno"><a class="line" href="class_m_a_s_t_1_1_basis_matrix.html#a6ab41c1e0258e4f5a1e00b6adb92a8da"> 119</a></span>  <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a6ab41c1e0258e4f5a1e00b6adb92a8da">vector_mult_transpose</a> (libMesh::NumericVector<T>& dest,</div><div class="line"><a name="l00120"></a><span class="lineno"> 120</span>  <span class="keyword">const</span> libMesh::NumericVector<T>& arg)<span class="keyword"> const </span>{</div><div class="line"><a name="l00121"></a><span class="lineno"> 121</span>  </div><div class="line"><a name="l00122"></a><span class="lineno"> 122</span>  <span class="comment">// not defined for multiplcation with libMesh::NumericVector</span></div><div class="line"><a name="l00123"></a><span class="lineno"> 123</span>  libmesh_assert(<span class="keyword">false</span>);</div><div class="line"><a name="l00124"></a><span class="lineno"> 124</span>  }</div><div class="line"><a name="l00125"></a><span class="lineno"> 125</span>  </div><div class="line"><a name="l00129"></a><span class="lineno"> 129</span>  <span class="keyword">virtual</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00130"></a><span class="lineno"><a class="line" href="class_m_a_s_t_1_1_basis_matrix.html#a02860fb312e23157cb6d897508a3939f"> 130</a></span>  <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a02860fb312e23157cb6d897508a3939f">vector_mult_add</a> (libMesh::NumericVector<T>& dest,</div><div class="line"><a name="l00131"></a><span class="lineno"> 131</span>  <span class="keyword">const</span> libMesh::NumericVector<T>& arg)<span class="keyword"> const </span>{</div><div class="line"><a name="l00132"></a><span class="lineno"> 132</span>  </div><div class="line"><a name="l00133"></a><span class="lineno"> 133</span>  <span class="comment">// not defined for multiplcation with libMesh::NumericVector</span></div><div class="line"><a name="l00134"></a><span class="lineno"> 134</span>  libmesh_assert(<span class="keyword">false</span>);</div><div class="line"><a name="l00135"></a><span class="lineno"> 135</span>  }</div><div class="line"><a name="l00136"></a><span class="lineno"> 136</span>  </div><div class="line"><a name="l00137"></a><span class="lineno"> 137</span>  </div><div class="line"><a name="l00141"></a><span class="lineno"> 141</span>  <span class="keyword">virtual</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00142"></a><span class="lineno"><a class="line" href="class_m_a_s_t_1_1_basis_matrix.html#afae555f32e07994f8fefcbe63485d0ce"> 142</a></span>  <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#afae555f32e07994f8fefcbe63485d0ce">get_diagonal</a> (libMesh::NumericVector<T>& dest)<span class="keyword"> const </span>{</div><div class="line"><a name="l00143"></a><span class="lineno"> 143</span>  </div><div class="line"><a name="l00144"></a><span class="lineno"> 144</span>  <span class="comment">// not defined for multiplcation with libMesh::NumericVector</span></div><div class="line"><a name="l00145"></a><span class="lineno"> 145</span>  libmesh_assert(<span class="keyword">false</span>);</div><div class="line"><a name="l00146"></a><span class="lineno"> 146</span>  }</div><div class="line"><a name="l00147"></a><span class="lineno"> 147</span>  </div><div class="line"><a name="l00148"></a><span class="lineno"> 148</span>  </div><div class="line"><a name="l00153"></a><span class="lineno"> 153</span>  <span class="keyword">virtual</span> libMesh::NumericVector<T>&</div><div class="line"><a name="l00154"></a><span class="lineno"><a class="line" href="class_m_a_s_t_1_1_basis_matrix.html#a74f6aadd27e37e613d9e850b89e7f86c"> 154</a></span>  <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a74f6aadd27e37e613d9e850b89e7f86c">basis</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> i) {</div><div class="line"><a name="l00155"></a><span class="lineno"> 155</span>  </div><div class="line"><a name="l00156"></a><span class="lineno"> 156</span>  <span class="comment">// not defined for multiplcation with libMesh::NumericVector</span></div><div class="line"><a name="l00157"></a><span class="lineno"> 157</span>  libmesh_assert(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">modes</a>.size() > 0);</div><div class="line"><a name="l00158"></a><span class="lineno"> 158</span>  libmesh_assert_less(i, <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">modes</a>.size());</div><div class="line"><a name="l00159"></a><span class="lineno"> 159</span>  </div><div class="line"><a name="l00160"></a><span class="lineno"> 160</span>  <span class="keywordflow">return</span> *(<a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">modes</a>[i]);</div><div class="line"><a name="l00161"></a><span class="lineno"> 161</span>  }</div><div class="line"><a name="l00162"></a><span class="lineno"> 162</span>  </div><div class="line"><a name="l00166"></a><span class="lineno"><a class="line" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd"> 166</a></span>  std::vector<libMesh::NumericVector<T>*> <a class="code" href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">modes</a>;</div><div class="line"><a name="l00167"></a><span class="lineno"> 167</span>  };</div><div class="line"><a name="l00168"></a><span class="lineno"> 168</span>  </div><div class="line"><a name="l00169"></a><span class="lineno"> 169</span> }</div><div class="line"><a name="l00170"></a><span class="lineno"> 170</span> </div><div class="line"><a name="l00171"></a><span class="lineno"> 171</span> <span class="preprocessor">#endif // __mast__structural_basis_matrix_h__</span></div><div class="ttc" id="class_m_a_s_t_1_1_basis_matrix_html_a2d1f49f07a0034a6b9a0a3d5a7bf2484"><div class="ttname"><a href="class_m_a_s_t_1_1_basis_matrix.html#a2d1f49f07a0034a6b9a0a3d5a7bf2484">MAST::BasisMatrix::vector_mult</a></div><div class="ttdeci">virtual void vector_mult(libMesh::NumericVector< T > &dest, const libMesh::NumericVector< T > &arg) const </div><div class="ttdoc">Multiplies the matrix with arg and stores the result in dest. </div><div class="ttdef"><b>Definition:</b> <a href="basis__matrix_8h_source.html#l00087">basis_matrix.h:87</a></div></div>
<div class="ttc" id="class_m_a_s_t_1_1_basis_matrix_html_a68c8bebc5959478622203699cafcc388"><div class="ttname"><a href="class_m_a_s_t_1_1_basis_matrix.html#a68c8bebc5959478622203699cafcc388">MAST::BasisMatrix::m</a></div><div class="ttdeci">virtual libMesh::numeric_index_type m() const </div><div class="ttdef"><b>Definition:</b> <a href="basis__matrix_8h_source.html#l00048">basis_matrix.h:48</a></div></div>
<div class="ttc" id="class_m_a_s_t_1_1_basis_matrix_html_aabfc4979f29a676fde647d20c1e028cf"><div class="ttname"><a href="class_m_a_s_t_1_1_basis_matrix.html#aabfc4979f29a676fde647d20c1e028cf">MAST::BasisMatrix::BasisMatrix</a></div><div class="ttdeci">BasisMatrix(const libMesh::Parallel::Communicator &comm_in)</div><div class="ttdef"><b>Definition:</b> <a href="basis__matrix_8cpp_source.html#l00026">basis_matrix.cpp:26</a></div></div>
<div class="ttc" id="class_m_a_s_t_1_1_basis_matrix_html_a9a87a38ce9a6efada5b8b13ce1249bac"><div class="ttname"><a href="class_m_a_s_t_1_1_basis_matrix.html#a9a87a38ce9a6efada5b8b13ce1249bac">MAST::BasisMatrix::vector_mult_transpose</a></div><div class="ttdeci">void vector_mult_transpose(VecType &dest, const libMesh::NumericVector< T > &arg) const </div><div class="ttdoc">Multiplies the matrix with arg and stores the result in dest. </div><div class="ttdef"><b>Definition:</b> <a href="basis__matrix_8h_source.html#l00101">basis_matrix.h:101</a></div></div>
<div class="ttc" id="class_m_a_s_t_1_1_basis_matrix_html_a6ab41c1e0258e4f5a1e00b6adb92a8da"><div class="ttname"><a href="class_m_a_s_t_1_1_basis_matrix.html#a6ab41c1e0258e4f5a1e00b6adb92a8da">MAST::BasisMatrix::vector_mult_transpose</a></div><div class="ttdeci">virtual void vector_mult_transpose(libMesh::NumericVector< T > &dest, const libMesh::NumericVector< T > &arg) const </div><div class="ttdoc">Multiplies the transpose of matrix with arg and stores the result in dest. </div><div class="ttdef"><b>Definition:</b> <a href="basis__matrix_8h_source.html#l00119">basis_matrix.h:119</a></div></div>
<div class="ttc" id="class_m_a_s_t_1_1_basis_matrix_html_a02860fb312e23157cb6d897508a3939f"><div class="ttname"><a href="class_m_a_s_t_1_1_basis_matrix.html#a02860fb312e23157cb6d897508a3939f">MAST::BasisMatrix::vector_mult_add</a></div><div class="ttdeci">virtual void vector_mult_add(libMesh::NumericVector< T > &dest, const libMesh::NumericVector< T > &arg) const </div><div class="ttdoc">Multiplies the matrix with arg and adds the result to dest. </div><div class="ttdef"><b>Definition:</b> <a href="basis__matrix_8h_source.html#l00130">basis_matrix.h:130</a></div></div>
<div class="ttc" id="class_m_a_s_t_1_1_basis_matrix_html_a74f6aadd27e37e613d9e850b89e7f86c"><div class="ttname"><a href="class_m_a_s_t_1_1_basis_matrix.html#a74f6aadd27e37e613d9e850b89e7f86c">MAST::BasisMatrix::basis</a></div><div class="ttdeci">virtual libMesh::NumericVector< T > & basis(unsigned int i)</div><div class="ttdoc">Returns the vector that defines the i^th basis vector. </div><div class="ttdef"><b>Definition:</b> <a href="basis__matrix_8h_source.html#l00154">basis_matrix.h:154</a></div></div>
<div class="ttc" id="class_m_a_s_t_1_1_basis_matrix_html_a47c064073f951c25dbbabfed15b3bbfa"><div class="ttname"><a href="class_m_a_s_t_1_1_basis_matrix.html#a47c064073f951c25dbbabfed15b3bbfa">MAST::BasisMatrix::n</a></div><div class="ttdeci">virtual libMesh::numeric_index_type n() const </div><div class="ttdef"><b>Definition:</b> <a href="basis__matrix_8h_source.html#l00058">basis_matrix.h:58</a></div></div>
<div class="ttc" id="class_m_a_s_t_1_1_basis_matrix_html_a3bd3324729119fa5602c970adac062b3"><div class="ttname"><a href="class_m_a_s_t_1_1_basis_matrix.html#a3bd3324729119fa5602c970adac062b3">MAST::BasisMatrix::vector_mult</a></div><div class="ttdeci">void vector_mult(libMesh::NumericVector< T > &dest, const VecType &arg) const </div><div class="ttdoc">Multiplies the matrix with arg and stores the result in dest. </div><div class="ttdef"><b>Definition:</b> <a href="basis__matrix_8h_source.html#l00070">basis_matrix.h:70</a></div></div>
<div class="ttc" id="class_m_a_s_t_1_1_basis_matrix_html_afae555f32e07994f8fefcbe63485d0ce"><div class="ttname"><a href="class_m_a_s_t_1_1_basis_matrix.html#afae555f32e07994f8fefcbe63485d0ce">MAST::BasisMatrix::get_diagonal</a></div><div class="ttdeci">virtual void get_diagonal(libMesh::NumericVector< T > &dest) const </div><div class="ttdoc">Copies the diagonal part of the matrix into dest. </div><div class="ttdef"><b>Definition:</b> <a href="basis__matrix_8h_source.html#l00142">basis_matrix.h:142</a></div></div>
<div class="ttc" id="class_m_a_s_t_1_1_basis_matrix_html_a31dad140b73a77c9ac32254d8744d8ec"><div class="ttname"><a href="class_m_a_s_t_1_1_basis_matrix.html#a31dad140b73a77c9ac32254d8744d8ec">MAST::BasisMatrix::~BasisMatrix</a></div><div class="ttdeci">virtual ~BasisMatrix()</div><div class="ttdef"><b>Definition:</b> <a href="basis__matrix_8cpp_source.html#l00031">basis_matrix.cpp:31</a></div></div>
<div class="ttc" id="class_m_a_s_t_1_1_basis_matrix_html_a7ffef555f42a229e6fa5c38f6165debd"><div class="ttname"><a href="class_m_a_s_t_1_1_basis_matrix.html#a7ffef555f42a229e6fa5c38f6165debd">MAST::BasisMatrix::modes</a></div><div class="ttdeci">std::vector< libMesh::NumericVector< T > * > modes</div><div class="ttdoc">vector of modes </div><div class="ttdef"><b>Definition:</b> <a href="basis__matrix_8h_source.html#l00166">basis_matrix.h:166</a></div></div>
<div class="ttc" id="namespace_m_a_s_t_html"><div class="ttname"><a href="namespace_m_a_s_t.html">MAST</a></div><div class="ttdef"><b>Definition:</b> <a href="flutter__root__base_8h_source.html#l00027">flutter_root_base.h:27</a></div></div>
</div><!-- fragment --></div><!-- contents -->
</div><!-- doc-content -->
<!-- start footer part -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
<ul>
<li class="navelem"><a class="el" href="dir_68267d1309a1af8e8297ef4c3efbcdba.html">src</a></li><li class="navelem"><a class="el" href="dir_e75d4dc68656c37cfb4cb5b6a269bfe6.html">numerics</a></li><li class="navelem"><a class="el" href="basis__matrix_8h.html">basis_matrix.h</a></li>
<li class="footer">Generated by
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.11 </li>
</ul>
</div>
</body>
</html>