blob: c164503324ba492ed442de91b120b8c96010d5b5 [file] [log] [blame]
<!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.13"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>mxnet: /work/mxnet/3rdparty/mshadow/mshadow/base.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="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>
<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">mxnet
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.13 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
$(function() {
initMenu('',true,false,'search.php','Search');
$(document).ready(function() { init_search(); });
});
</script>
<div id="main-nav"></div>
<!-- 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 id="nav-path" class="navpath">
<ul>
<li class="navelem"><a class="el" href="dir_8cab8f464681f7cc51cee77e79a434cd.html">3rdparty</a></li><li class="navelem"><a class="el" href="dir_3e48ced36faa4eaa1b41f6d960bf0edb.html">mshadow</a></li><li class="navelem"><a class="el" href="dir_00b035bb2ad81894e6ad291054ea5f82.html">mshadow</a></li> </ul>
</div>
</div><!-- top -->
<div class="header">
<div class="headertitle">
<div class="title">base.h</div> </div>
</div><!--header-->
<div class="contents">
<a href="3rdparty_2mshadow_2mshadow_2base_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>&#160;<span class="comment">/*</span></div><div class="line"><a name="l00002"></a><span class="lineno"> 2</span>&#160;<span class="comment"> * Licensed to the Apache Software Foundation (ASF) under one</span></div><div class="line"><a name="l00003"></a><span class="lineno"> 3</span>&#160;<span class="comment"> * or more contributor license agreements. See the NOTICE file</span></div><div class="line"><a name="l00004"></a><span class="lineno"> 4</span>&#160;<span class="comment"> * distributed with this work for additional information</span></div><div class="line"><a name="l00005"></a><span class="lineno"> 5</span>&#160;<span class="comment"> * regarding copyright ownership. The ASF licenses this file</span></div><div class="line"><a name="l00006"></a><span class="lineno"> 6</span>&#160;<span class="comment"> * to you under the Apache License, Version 2.0 (the</span></div><div class="line"><a name="l00007"></a><span class="lineno"> 7</span>&#160;<span class="comment"> * &quot;License&quot;); you may not use this file except in compliance</span></div><div class="line"><a name="l00008"></a><span class="lineno"> 8</span>&#160;<span class="comment"> * with the License. You may obtain a copy of the License at</span></div><div class="line"><a name="l00009"></a><span class="lineno"> 9</span>&#160;<span class="comment"> *</span></div><div class="line"><a name="l00010"></a><span class="lineno"> 10</span>&#160;<span class="comment"> * http://www.apache.org/licenses/LICENSE-2.0</span></div><div class="line"><a name="l00011"></a><span class="lineno"> 11</span>&#160;<span class="comment"> *</span></div><div class="line"><a name="l00012"></a><span class="lineno"> 12</span>&#160;<span class="comment"> * Unless required by applicable law or agreed to in writing,</span></div><div class="line"><a name="l00013"></a><span class="lineno"> 13</span>&#160;<span class="comment"> * software distributed under the License is distributed on an</span></div><div class="line"><a name="l00014"></a><span class="lineno"> 14</span>&#160;<span class="comment"> * &quot;AS IS&quot; BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY</span></div><div class="line"><a name="l00015"></a><span class="lineno"> 15</span>&#160;<span class="comment"> * KIND, either express or implied. See the License for the</span></div><div class="line"><a name="l00016"></a><span class="lineno"> 16</span>&#160;<span class="comment"> * specific language governing permissions and limitations</span></div><div class="line"><a name="l00017"></a><span class="lineno"> 17</span>&#160;<span class="comment"> * under the License.</span></div><div class="line"><a name="l00018"></a><span class="lineno"> 18</span>&#160;<span class="comment"> */</span></div><div class="line"><a name="l00019"></a><span class="lineno"> 19</span>&#160;</div><div class="line"><a name="l00026"></a><span class="lineno"> 26</span>&#160;<span class="preprocessor">#ifndef MSHADOW_BASE_H_</span></div><div class="line"><a name="l00027"></a><span class="lineno"> 27</span>&#160;<span class="preprocessor">#define MSHADOW_BASE_H_</span></div><div class="line"><a name="l00028"></a><span class="lineno"> 28</span>&#160;<span class="preprocessor">#ifdef _MSC_VER</span></div><div class="line"><a name="l00029"></a><span class="lineno"> 29</span>&#160;<span class="preprocessor">#ifndef _CRT_SECURE_NO_WARNINGS</span></div><div class="line"><a name="l00030"></a><span class="lineno"> 30</span>&#160;<span class="preprocessor">#define _CRT_SECURE_NO_WARNINGS</span></div><div class="line"><a name="l00031"></a><span class="lineno"> 31</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00032"></a><span class="lineno"> 32</span>&#160;<span class="preprocessor">#ifndef _CRT_SECURE_NO_DEPRECATE</span></div><div class="line"><a name="l00033"></a><span class="lineno"> 33</span>&#160;<span class="preprocessor">#define _CRT_SECURE_NO_DEPRECATE</span></div><div class="line"><a name="l00034"></a><span class="lineno"> 34</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00035"></a><span class="lineno"> 35</span>&#160;<span class="preprocessor">#ifndef NOMINMAX</span></div><div class="line"><a name="l00036"></a><span class="lineno"> 36</span>&#160;<span class="preprocessor">#define NOMINMAX</span></div><div class="line"><a name="l00037"></a><span class="lineno"> 37</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00038"></a><span class="lineno"> 38</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00039"></a><span class="lineno"> 39</span>&#160;<span class="preprocessor">#include &lt;cmath&gt;</span></div><div class="line"><a name="l00040"></a><span class="lineno"> 40</span>&#160;<span class="preprocessor">#include &lt;cstdio&gt;</span></div><div class="line"><a name="l00041"></a><span class="lineno"> 41</span>&#160;<span class="preprocessor">#include &lt;cfloat&gt;</span></div><div class="line"><a name="l00042"></a><span class="lineno"> 42</span>&#160;<span class="preprocessor">#include &lt;climits&gt;</span></div><div class="line"><a name="l00043"></a><span class="lineno"> 43</span>&#160;<span class="preprocessor">#include &lt;algorithm&gt;</span></div><div class="line"><a name="l00044"></a><span class="lineno"> 44</span>&#160;<span class="preprocessor">#include &lt;functional&gt;</span></div><div class="line"><a name="l00045"></a><span class="lineno"> 45</span>&#160;<span class="preprocessor">#include &lt;sstream&gt;</span></div><div class="line"><a name="l00046"></a><span class="lineno"> 46</span>&#160;<span class="preprocessor">#include &lt;string&gt;</span></div><div class="line"><a name="l00047"></a><span class="lineno"> 47</span>&#160;</div><div class="line"><a name="l00048"></a><span class="lineno"> 48</span>&#160;<span class="preprocessor">#ifdef _MSC_VER</span></div><div class="line"><a name="l00049"></a><span class="lineno"> 49</span>&#160;<span class="keyword">typedef</span> <span class="keywordtype">signed</span> <span class="keywordtype">char</span> int8_t;</div><div class="line"><a name="l00051"></a><span class="lineno"> 51</span>&#160;<span class="keyword">typedef</span> __int16 int16_t;</div><div class="line"><a name="l00052"></a><span class="lineno"> 52</span>&#160;<span class="keyword">typedef</span> __int32 int32_t;</div><div class="line"><a name="l00053"></a><span class="lineno"> 53</span>&#160;<span class="keyword">typedef</span> __int64 int64_t;</div><div class="line"><a name="l00054"></a><span class="lineno"> 54</span>&#160;<span class="keyword">typedef</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> uint8_t;</div><div class="line"><a name="l00055"></a><span class="lineno"> 55</span>&#160;<span class="keyword">typedef</span> <span class="keywordtype">unsigned</span> __int16 uint16_t;</div><div class="line"><a name="l00056"></a><span class="lineno"> 56</span>&#160;<span class="keyword">typedef</span> <span class="keywordtype">unsigned</span> __int32 uint32_t;</div><div class="line"><a name="l00057"></a><span class="lineno"> 57</span>&#160;<span class="keyword">typedef</span> <span class="keywordtype">unsigned</span> __int64 uint64_t;</div><div class="line"><a name="l00059"></a><span class="lineno"> 59</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00060"></a><span class="lineno"> 60</span>&#160;<span class="preprocessor">#include &lt;inttypes.h&gt;</span></div><div class="line"><a name="l00061"></a><span class="lineno"> 61</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00062"></a><span class="lineno"> 62</span>&#160;<span class="comment">// macro defintiions</span></div><div class="line"><a name="l00067"></a><span class="lineno"> 67</span>&#160;<span class="comment"></span><span class="preprocessor">#ifndef MSHADOW_STAND_ALONE</span></div><div class="line"><a name="l00068"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#adb97209063773b312b79a275688a2093"> 68</a></span>&#160;<span class="preprocessor">#define MSHADOW_STAND_ALONE 0</span></div><div class="line"><a name="l00069"></a><span class="lineno"> 69</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160;</div><div class="line"><a name="l00071"></a><span class="lineno"> 71</span>&#160;<span class="preprocessor">#ifndef MSHADOW_ALLOC_PAD</span></div><div class="line"><a name="l00072"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a72d4e933c0003ccdc01b5d5f054dcf39"> 72</a></span>&#160;<span class="preprocessor">#define MSHADOW_ALLOC_PAD true</span></div><div class="line"><a name="l00073"></a><span class="lineno"> 73</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00074"></a><span class="lineno"> 74</span>&#160;</div><div class="line"><a name="l00082"></a><span class="lineno"> 82</span>&#160;<span class="preprocessor">#ifndef MSHADOW_MIN_PAD_RATIO</span></div><div class="line"><a name="l00083"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#aaddfd904e59a1fc9fb07019cff73adee"> 83</a></span>&#160;<span class="preprocessor"> #define MSHADOW_MIN_PAD_RATIO 2</span></div><div class="line"><a name="l00084"></a><span class="lineno"> 84</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160;</div><div class="line"><a name="l00086"></a><span class="lineno"> 86</span>&#160;<span class="preprocessor">#if MSHADOW_STAND_ALONE</span></div><div class="line"><a name="l00087"></a><span class="lineno"> 87</span>&#160;<span class="preprocessor"> #define MSHADOW_USE_CBLAS 0</span></div><div class="line"><a name="l00088"></a><span class="lineno"> 88</span>&#160;<span class="preprocessor"> #define MSHADOW_USE_MKL 0</span></div><div class="line"><a name="l00089"></a><span class="lineno"> 89</span>&#160;<span class="preprocessor"> #define MSHADOW_USE_CUDA 0</span></div><div class="line"><a name="l00090"></a><span class="lineno"> 90</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00091"></a><span class="lineno"> 91</span>&#160;</div><div class="line"><a name="l00096"></a><span class="lineno"> 96</span>&#160;<span class="preprocessor">#ifndef MSHADOW_FORCE_STREAM</span></div><div class="line"><a name="l00097"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a19a013475c0af9faff9348c649d80e03"> 97</a></span>&#160;<span class="preprocessor">#define MSHADOW_FORCE_STREAM 1</span></div><div class="line"><a name="l00098"></a><span class="lineno"> 98</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00099"></a><span class="lineno"> 99</span>&#160;</div><div class="line"><a name="l00101"></a><span class="lineno"> 101</span>&#160;<span class="preprocessor">#ifndef MSHADOW_USE_CBLAS</span></div><div class="line"><a name="l00102"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a6c5fbf2591134429036ca9af316e4600"> 102</a></span>&#160;<span class="preprocessor"> #define MSHADOW_USE_CBLAS 0</span></div><div class="line"><a name="l00103"></a><span class="lineno"> 103</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00104"></a><span class="lineno"> 104</span>&#160;</div><div class="line"><a name="l00105"></a><span class="lineno"> 105</span>&#160;<span class="preprocessor">#ifndef MSHADOW_USE_MKL</span></div><div class="line"><a name="l00106"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a5fb3349b887a553f578daa6e4b4f1e56"> 106</a></span>&#160;<span class="preprocessor"> #define MSHADOW_USE_MKL 1</span></div><div class="line"><a name="l00107"></a><span class="lineno"> 107</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00108"></a><span class="lineno"> 108</span>&#160;</div><div class="line"><a name="l00109"></a><span class="lineno"> 109</span>&#160;<span class="preprocessor">#ifndef MSHADOW_USE_ARMPL</span></div><div class="line"><a name="l00110"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a98b0b65f80a009fcea6a467b42e19798"> 110</a></span>&#160;<span class="preprocessor"> #define MSHADOW_USE_ARMPL 0</span></div><div class="line"><a name="l00111"></a><span class="lineno"> 111</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00112"></a><span class="lineno"> 112</span>&#160;</div><div class="line"><a name="l00117"></a><span class="lineno"> 117</span>&#160;<span class="preprocessor">#ifndef MSHADOW_USE_CUDA</span></div><div class="line"><a name="l00118"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a52e5c06e325bfed605a4f63a48fe0020"> 118</a></span>&#160;<span class="preprocessor"> #define MSHADOW_USE_CUDA 1</span></div><div class="line"><a name="l00119"></a><span class="lineno"> 119</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00120"></a><span class="lineno"> 120</span>&#160;</div><div class="line"><a name="l00124"></a><span class="lineno"> 124</span>&#160;<span class="preprocessor">#ifndef MSHADOW_USE_CUDNN</span></div><div class="line"><a name="l00125"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#affa4511f720838acfdbbc5f1da36a6e6"> 125</a></span>&#160;<span class="preprocessor"> #define MSHADOW_USE_CUDNN 0</span></div><div class="line"><a name="l00126"></a><span class="lineno"> 126</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00127"></a><span class="lineno"> 127</span>&#160;</div><div class="line"><a name="l00131"></a><span class="lineno"> 131</span>&#160;<span class="preprocessor">#ifndef MSHADOW_USE_CUSOLVER</span></div><div class="line"><a name="l00132"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a97592c78424f2386677ad622d93d27ee"> 132</a></span>&#160;<span class="preprocessor"> #define MSHADOW_USE_CUSOLVER MSHADOW_USE_CUDA</span></div><div class="line"><a name="l00133"></a><span class="lineno"> 133</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00134"></a><span class="lineno"> 134</span>&#160;</div><div class="line"><a name="l00139"></a><span class="lineno"> 139</span>&#160;<span class="preprocessor">#ifndef MSHADOW_OLD_CUDA</span></div><div class="line"><a name="l00140"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a48188fc0839e136ff0f0f5ebafe24e19"> 140</a></span>&#160;<span class="preprocessor">#define MSHADOW_OLD_CUDA 0</span></div><div class="line"><a name="l00141"></a><span class="lineno"> 141</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00142"></a><span class="lineno"> 142</span>&#160;</div><div class="line"><a name="l00146"></a><span class="lineno"> 146</span>&#160;<span class="preprocessor">#ifndef MSHADOW_IN_CXX11</span></div><div class="line"><a name="l00147"></a><span class="lineno"> 147</span>&#160;<span class="preprocessor"> #if (defined(__GXX_EXPERIMENTAL_CXX0X__) ||\</span></div><div class="line"><a name="l00148"></a><span class="lineno"> 148</span>&#160;<span class="preprocessor"> __cplusplus &gt;= 201103L || defined(_MSC_VER))</span></div><div class="line"><a name="l00149"></a><span class="lineno"> 149</span>&#160;<span class="preprocessor"> #define MSHADOW_IN_CXX11 1</span></div><div class="line"><a name="l00150"></a><span class="lineno"> 150</span>&#160;<span class="preprocessor"> #else</span></div><div class="line"><a name="l00151"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a4cb113139e6b7a7fe8da3d68574e17e8"> 151</a></span>&#160;<span class="preprocessor"> #define MSHADOW_IN_CXX11 0</span></div><div class="line"><a name="l00152"></a><span class="lineno"> 152</span>&#160;<span class="preprocessor"> #endif</span></div><div class="line"><a name="l00153"></a><span class="lineno"> 153</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00154"></a><span class="lineno"> 154</span>&#160;</div><div class="line"><a name="l00156"></a><span class="lineno"> 156</span>&#160;<span class="preprocessor">#ifndef MSHADOW_USE_SSE</span></div><div class="line"><a name="l00157"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a08b353dc670d04847f78a70a72856058"> 157</a></span>&#160;<span class="preprocessor"> #define MSHADOW_USE_SSE 1</span></div><div class="line"><a name="l00158"></a><span class="lineno"> 158</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00159"></a><span class="lineno"> 159</span>&#160;</div><div class="line"><a name="l00161"></a><span class="lineno"> 161</span>&#160;<span class="preprocessor">#ifndef MSHADOW_USE_F16C</span></div><div class="line"><a name="l00162"></a><span class="lineno"> 162</span>&#160;<span class="preprocessor"> #if defined(_MSC_VER) || defined(__CUDACC__)</span></div><div class="line"><a name="l00163"></a><span class="lineno"> 163</span>&#160;<span class="preprocessor"> #define MSHADOW_USE_F16C 0</span></div><div class="line"><a name="l00164"></a><span class="lineno"> 164</span>&#160;<span class="preprocessor"> #elif defined(__clang__) &amp;&amp; \</span></div><div class="line"><a name="l00165"></a><span class="lineno"> 165</span>&#160;<span class="preprocessor"> ((__clang_major__ &lt; 8) || ((__clang_major__ == 8) &amp;&amp; (__clang_minor__ &lt; 1)))</span></div><div class="line"><a name="l00166"></a><span class="lineno"> 166</span>&#160;<span class="preprocessor"> #define MSHADOW_USE_F16C 0</span></div><div class="line"><a name="l00167"></a><span class="lineno"> 167</span>&#160;<span class="preprocessor"> #else</span></div><div class="line"><a name="l00168"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af914aa3e4887150dd618b6162f88803f"> 168</a></span>&#160;<span class="preprocessor"> #define MSHADOW_USE_F16C 1</span></div><div class="line"><a name="l00169"></a><span class="lineno"> 169</span>&#160;<span class="preprocessor"> #endif</span></div><div class="line"><a name="l00170"></a><span class="lineno"> 170</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00171"></a><span class="lineno"> 171</span>&#160;</div><div class="line"><a name="l00173"></a><span class="lineno"> 173</span>&#160;<span class="preprocessor">#ifndef MSHADOW_USE_NVML</span></div><div class="line"><a name="l00174"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a2ff0316ca02738dcfd65dacba7b964a0"> 174</a></span>&#160;<span class="preprocessor"> #define MSHADOW_USE_NVML 0</span></div><div class="line"><a name="l00175"></a><span class="lineno"> 175</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00176"></a><span class="lineno"> 176</span>&#160;<span class="comment">// SSE is conflict with cudacc</span></div><div class="line"><a name="l00177"></a><span class="lineno"> 177</span>&#160;<span class="preprocessor">#ifdef __CUDACC__</span></div><div class="line"><a name="l00178"></a><span class="lineno"> 178</span>&#160;<span class="preprocessor"> #undef MSHADOW_USE_SSE</span></div><div class="line"><a name="l00179"></a><span class="lineno"> 179</span>&#160;<span class="preprocessor"> #define MSHADOW_USE_SSE 0</span></div><div class="line"><a name="l00180"></a><span class="lineno"> 180</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00181"></a><span class="lineno"> 181</span>&#160;</div><div class="line"><a name="l00182"></a><span class="lineno"> 182</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CBLAS</span></div><div class="line"><a name="l00183"></a><span class="lineno"> 183</span>&#160;<span class="keyword">extern</span> <span class="stringliteral">&quot;C&quot;</span> {</div><div class="line"><a name="l00184"></a><span class="lineno"> 184</span>&#160;<span class="preprocessor"> #if MSHADOW_USE_ARMPL</span></div><div class="line"><a name="l00185"></a><span class="lineno"> 185</span>&#160;<span class="preprocessor"> #define armpl_singlecomplex_t float _Complex</span></div><div class="line"><a name="l00186"></a><span class="lineno"> 186</span>&#160;<span class="preprocessor"> #define armpl_doublecomplex_t double _Complex</span></div><div class="line"><a name="l00187"></a><span class="lineno"> 187</span>&#160;<span class="preprocessor"> #endif</span></div><div class="line"><a name="l00188"></a><span class="lineno"> 188</span>&#160;<span class="preprocessor"> #include &lt;cblas.h&gt;</span></div><div class="line"><a name="l00189"></a><span class="lineno"> 189</span>&#160;}</div><div class="line"><a name="l00190"></a><span class="lineno"> 190</span>&#160;<span class="preprocessor">#elif MSHADOW_USE_MKL</span></div><div class="line"><a name="l00191"></a><span class="lineno"> 191</span>&#160;<span class="preprocessor"> #include &lt;mkl_blas.h&gt;</span></div><div class="line"><a name="l00192"></a><span class="lineno"> 192</span>&#160;<span class="preprocessor"> #include &lt;mkl_cblas.h&gt;</span></div><div class="line"><a name="l00193"></a><span class="lineno"> 193</span>&#160;<span class="preprocessor"> #include &lt;mkl_vsl.h&gt;</span></div><div class="line"><a name="l00194"></a><span class="lineno"> 194</span>&#160;<span class="preprocessor"> #include &lt;mkl_vsl_functions.h&gt;</span></div><div class="line"><a name="l00195"></a><span class="lineno"> 195</span>&#160;<span class="preprocessor"> #include &lt;mkl_version.h&gt;</span></div><div class="line"><a name="l00196"></a><span class="lineno"> 196</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00197"></a><span class="lineno"> 197</span>&#160;</div><div class="line"><a name="l00198"></a><span class="lineno"> 198</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CUDA</span></div><div class="line"><a name="l00199"></a><span class="lineno"> 199</span>&#160;<span class="preprocessor"> #include &lt;cuda.h&gt;</span></div><div class="line"><a name="l00200"></a><span class="lineno"> 200</span>&#160;<span class="preprocessor"> #include &lt;cublas_v2.h&gt;</span></div><div class="line"><a name="l00201"></a><span class="lineno"> 201</span>&#160;<span class="preprocessor"> #include &lt;curand.h&gt;</span></div><div class="line"><a name="l00202"></a><span class="lineno"> 202</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00203"></a><span class="lineno"> 203</span>&#160;</div><div class="line"><a name="l00204"></a><span class="lineno"> 204</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CUDNN == 1</span></div><div class="line"><a name="l00205"></a><span class="lineno"> 205</span>&#160;<span class="preprocessor"> #include &lt;cudnn.h&gt;</span></div><div class="line"><a name="l00206"></a><span class="lineno"> 206</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00207"></a><span class="lineno"> 207</span>&#160;</div><div class="line"><a name="l00208"></a><span class="lineno"> 208</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CUSOLVER == 1</span></div><div class="line"><a name="l00209"></a><span class="lineno"> 209</span>&#160;<span class="preprocessor"> #include &lt;cusolverDn.h&gt;</span></div><div class="line"><a name="l00210"></a><span class="lineno"> 210</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00211"></a><span class="lineno"> 211</span>&#160;</div><div class="line"><a name="l00212"></a><span class="lineno"> 212</span>&#160;<span class="preprocessor">#if MSHADOW_USE_NVML</span></div><div class="line"><a name="l00213"></a><span class="lineno"> 213</span>&#160;<span class="preprocessor"> #include &lt;nvml.h&gt;</span></div><div class="line"><a name="l00214"></a><span class="lineno"> 214</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00215"></a><span class="lineno"> 215</span>&#160;</div><div class="line"><a name="l00216"></a><span class="lineno"> 216</span>&#160;<span class="comment">// --------------------------------</span></div><div class="line"><a name="l00217"></a><span class="lineno"> 217</span>&#160;<span class="comment">// MSHADOW_XINLINE is used for inlining template code for both CUDA and CPU code</span></div><div class="line"><a name="l00218"></a><span class="lineno"> 218</span>&#160;<span class="preprocessor">#ifdef MSHADOW_XINLINE</span></div><div class="line"><a name="l00219"></a><span class="lineno"> 219</span>&#160;<span class="preprocessor"> #error &quot;MSHADOW_XINLINE must not be defined&quot;</span></div><div class="line"><a name="l00220"></a><span class="lineno"> 220</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00221"></a><span class="lineno"> 221</span>&#160;<span class="preprocessor">#ifdef _MSC_VER</span></div><div class="line"><a name="l00222"></a><span class="lineno"> 222</span>&#160;<span class="preprocessor">#define MSHADOW_FORCE_INLINE __forceinline</span></div><div class="line"><a name="l00223"></a><span class="lineno"> 223</span>&#160;<span class="preprocessor">#pragma warning(disable : 4068)</span></div><div class="line"><a name="l00224"></a><span class="lineno"> 224</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00225"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#ad9835bbd312a2aead44b7870947ef884"> 225</a></span>&#160;<span class="preprocessor">#define MSHADOW_FORCE_INLINE inline __attribute__((always_inline))</span></div><div class="line"><a name="l00226"></a><span class="lineno"> 226</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00227"></a><span class="lineno"> 227</span>&#160;<span class="preprocessor">#ifdef __CUDACC__</span></div><div class="line"><a name="l00228"></a><span class="lineno"> 228</span>&#160;<span class="preprocessor"> #define MSHADOW_XINLINE MSHADOW_FORCE_INLINE __device__ __host__</span></div><div class="line"><a name="l00229"></a><span class="lineno"> 229</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00230"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69"> 230</a></span>&#160;<span class="preprocessor"> #define MSHADOW_XINLINE MSHADOW_FORCE_INLINE</span></div><div class="line"><a name="l00231"></a><span class="lineno"> 231</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00232"></a><span class="lineno"> 232</span>&#160;</div><div class="line"><a name="l00233"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#ae3f37fc5e892a11db794e475fae404a8"> 233</a></span>&#160;<span class="preprocessor">#define MSHADOW_CINLINE MSHADOW_FORCE_INLINE</span></div><div class="line"><a name="l00234"></a><span class="lineno"> 234</span>&#160;</div><div class="line"><a name="l00235"></a><span class="lineno"> 235</span>&#160;<span class="preprocessor">#if defined(__GXX_EXPERIMENTAL_CXX0X) ||\</span></div><div class="line"><a name="l00236"></a><span class="lineno"> 236</span>&#160;<span class="preprocessor"> defined(__GXX_EXPERIMENTAL_CXX0X__) || __cplusplus &gt;= 201103L</span></div><div class="line"><a name="l00237"></a><span class="lineno"> 237</span>&#160;<span class="preprocessor"> #define MSHADOW_CONSTEXPR constexpr</span></div><div class="line"><a name="l00238"></a><span class="lineno"> 238</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00239"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a297359cf21f8a173b059a7b8c5e02ebf"> 239</a></span>&#160;<span class="preprocessor"> #define MSHADOW_CONSTEXPR const</span></div><div class="line"><a name="l00240"></a><span class="lineno"> 240</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00241"></a><span class="lineno"> 241</span>&#160;</div><div class="line"><a name="l00248"></a><span class="lineno"> 248</span>&#160;<span class="preprocessor">#ifndef MSHADOW_DEFAULT_DTYPE</span></div><div class="line"><a name="l00249"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a1588e3cdf209b0cf13609d1c0e3838c7"> 249</a></span>&#160;<span class="preprocessor">#define MSHADOW_DEFAULT_DTYPE = ::mshadow::default_real_t</span></div><div class="line"><a name="l00250"></a><span class="lineno"> 250</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00251"></a><span class="lineno"> 251</span>&#160;</div><div class="line"><a name="l00255"></a><span class="lineno"> 255</span>&#160;<span class="preprocessor">#ifndef MSHADOW_USE_GLOG</span></div><div class="line"><a name="l00256"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a6444c537a4443d99d62604642e6422c8"> 256</a></span>&#160;<span class="preprocessor">#define MSHADOW_USE_GLOG DMLC_USE_GLOG</span></div><div class="line"><a name="l00257"></a><span class="lineno"> 257</span>&#160;<span class="preprocessor">#endif // MSHADOW_USE_GLOG</span></div><div class="line"><a name="l00258"></a><span class="lineno"> 258</span>&#160;</div><div class="line"><a name="l00259"></a><span class="lineno"> 259</span>&#160;<span class="preprocessor">#if DMLC_USE_CXX11</span></div><div class="line"><a name="l00260"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a53a342d1f8cc22d36ed49e4c51c19f0c"> 260</a></span>&#160;<span class="preprocessor">#define MSHADOW_THROW_EXCEPTION noexcept(false)</span></div><div class="line"><a name="l00261"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a26c198967f39ff94cd560ea82e773f8d"> 261</a></span>&#160;<span class="preprocessor">#define MSHADOW_NO_EXCEPTION noexcept(true)</span></div><div class="line"><a name="l00262"></a><span class="lineno"> 262</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00263"></a><span class="lineno"> 263</span>&#160;<span class="preprocessor">#define MSHADOW_THROW_EXCEPTION</span></div><div class="line"><a name="l00264"></a><span class="lineno"> 264</span>&#160;<span class="preprocessor">#define MSHADOW_NO_EXCEPTION</span></div><div class="line"><a name="l00265"></a><span class="lineno"> 265</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00266"></a><span class="lineno"> 266</span>&#160;</div><div class="line"><a name="l00267"></a><span class="lineno"> 267</span>&#160;<span class="preprocessor">#if defined(_MSC_VER)</span></div><div class="line"><a name="l00268"></a><span class="lineno"> 268</span>&#160;<span class="preprocessor">#define MSHADOW_ALIGNED(x) __declspec(align(x))</span></div><div class="line"><a name="l00269"></a><span class="lineno"> 269</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00270"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a9a2941102b46ebdb39e04d66da40d238"> 270</a></span>&#160;<span class="preprocessor">#define MSHADOW_ALIGNED(x) __attribute__ ((aligned(x)))</span></div><div class="line"><a name="l00271"></a><span class="lineno"> 271</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00272"></a><span class="lineno"> 272</span>&#160;</div><div class="line"><a name="l00278"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a8f433b4dd005a854eec58178ffd3d4bd"> 278</a></span>&#160;<span class="preprocessor">#define MSHADOW_CUDA_CALL(func) \</span></div><div class="line"><a name="l00279"></a><span class="lineno"> 279</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l00280"></a><span class="lineno"> 280</span>&#160;<span class="preprocessor"> cudaError_t e = (func); \</span></div><div class="line"><a name="l00281"></a><span class="lineno"> 281</span>&#160;<span class="preprocessor"> if (e == cudaErrorCudartUnloading) { \</span></div><div class="line"><a name="l00282"></a><span class="lineno"> 282</span>&#160;<span class="preprocessor"> throw dmlc::Error(cudaGetErrorString(e)); \</span></div><div class="line"><a name="l00283"></a><span class="lineno"> 283</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l00284"></a><span class="lineno"> 284</span>&#160;<span class="preprocessor"> CHECK(e == cudaSuccess) \</span></div><div class="line"><a name="l00285"></a><span class="lineno"> 285</span>&#160;<span class="preprocessor"> &lt;&lt; &quot;CUDA: &quot; &lt;&lt; cudaGetErrorString(e); \</span></div><div class="line"><a name="l00286"></a><span class="lineno"> 286</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l00287"></a><span class="lineno"> 287</span>&#160;</div><div class="line"><a name="l00292"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a144171091678fc9f3cbc8a9612db899d"> 292</a></span>&#160;<span class="preprocessor">#define MSHADOW_CATCH_ERROR(func) \</span></div><div class="line"><a name="l00293"></a><span class="lineno"> 293</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l00294"></a><span class="lineno"> 294</span>&#160;<span class="preprocessor"> try { \</span></div><div class="line"><a name="l00295"></a><span class="lineno"> 295</span>&#160;<span class="preprocessor"> (func); \</span></div><div class="line"><a name="l00296"></a><span class="lineno"> 296</span>&#160;<span class="preprocessor"> } catch (const dmlc::Error &amp;e) { \</span></div><div class="line"><a name="l00297"></a><span class="lineno"> 297</span>&#160;<span class="preprocessor"> std::string what = e.what(); \</span></div><div class="line"><a name="l00298"></a><span class="lineno"> 298</span>&#160;<span class="preprocessor"> if (what.find(&quot;driver shutting down&quot;) == std::string::npos) { \</span></div><div class="line"><a name="l00299"></a><span class="lineno"> 299</span>&#160;<span class="preprocessor"> LOG(ERROR) &lt;&lt; &quot;Ignore CUDA Error &quot; &lt;&lt; what; \</span></div><div class="line"><a name="l00300"></a><span class="lineno"> 300</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l00301"></a><span class="lineno"> 301</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l00302"></a><span class="lineno"> 302</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l00303"></a><span class="lineno"> 303</span>&#160;</div><div class="line"><a name="l00304"></a><span class="lineno"> 304</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="half_8h.html">./half.h</a>&quot;</span></div><div class="line"><a name="l00305"></a><span class="lineno"> 305</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="half2_8h.html">./half2.h</a>&quot;</span></div><div class="line"><a name="l00306"></a><span class="lineno"> 306</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="bfloat_8h.html">./bfloat.h</a>&quot;</span></div><div class="line"><a name="l00307"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a5260fbd063fdb83af6cff734306ce856"> 307</a></span>&#160;<span class="preprocessor">#define MSHADOW_HALF_BF_OPERATOR(RTYPE, OP) \</span></div><div class="line"><a name="l00308"></a><span class="lineno"> 308</span>&#160;<span class="preprocessor"> MSHADOW_XINLINE RTYPE operator OP(mshadow::half::half_t a, mshadow::bfloat::bf16_t b) { \</span></div><div class="line"><a name="l00309"></a><span class="lineno"> 309</span>&#160;<span class="preprocessor"> return float(a) OP float(b); </span><span class="comment">/* NOLINT(*) */</span><span class="preprocessor"> \</span></div><div class="line"><a name="l00310"></a><span class="lineno"> 310</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l00311"></a><span class="lineno"> 311</span>&#160;<span class="preprocessor"> MSHADOW_XINLINE RTYPE operator OP(mshadow::bfloat::bf16_t a, mshadow::half::half_t b) { \</span></div><div class="line"><a name="l00312"></a><span class="lineno"> 312</span>&#160;<span class="preprocessor"> return float(a) OP float(b); </span><span class="comment">/* NOLINT(*) */</span><span class="preprocessor"> \</span></div><div class="line"><a name="l00313"></a><span class="lineno"> 313</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l00314"></a><span class="lineno"> 314</span>&#160;</div><div class="line"><a name="l00316"></a><span class="lineno"> 316</span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a5260fbd063fdb83af6cff734306ce856">MSHADOW_HALF_BF_OPERATOR</a>(<span class="keywordtype">float</span>, +)</div><div class="line"><a name="l00318"></a><span class="lineno"> 318</span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a5260fbd063fdb83af6cff734306ce856">MSHADOW_HALF_BF_OPERATOR</a>(<span class="keywordtype">float</span>, -)</div><div class="line"><a name="l00320"></a><span class="lineno"> 320</span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a5260fbd063fdb83af6cff734306ce856">MSHADOW_HALF_BF_OPERATOR</a>(<span class="keywordtype">float</span>, *)</div><div class="line"><a name="l00322"></a><span class="lineno"> 322</span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a5260fbd063fdb83af6cff734306ce856">MSHADOW_HALF_BF_OPERATOR</a>(<span class="keywordtype">float</span>, /)</div><div class="line"><a name="l00324"></a><span class="lineno"> 324</span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a5260fbd063fdb83af6cff734306ce856">MSHADOW_HALF_BF_OPERATOR</a>(<span class="keywordtype">bool</span>, &gt;)</div><div class="line"><a name="l00326"></a><span class="lineno"> 326</span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a5260fbd063fdb83af6cff734306ce856">MSHADOW_HALF_BF_OPERATOR</a>(<span class="keywordtype">bool</span>, &lt;)</div><div class="line"><a name="l00328"></a><span class="lineno"> 328</span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a5260fbd063fdb83af6cff734306ce856">MSHADOW_HALF_BF_OPERATOR</a>(<span class="keywordtype">bool</span>, &gt;=)</div><div class="line"><a name="l00330"></a><span class="lineno"> 330</span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a5260fbd063fdb83af6cff734306ce856">MSHADOW_HALF_BF_OPERATOR</a>(<span class="keywordtype">bool</span>, &lt;=)</div><div class="line"><a name="l00331"></a><span class="lineno"> 331</span>&#160;</div><div class="line"><a name="l00332"></a><span class="lineno"> 332</span>&#160;<span class="preprocessor">#include &quot;./logging.h&quot;</span></div><div class="line"><a name="l00333"></a><span class="lineno"> 333</span>&#160;</div><div class="line"><a name="l00334"></a><span class="lineno"><a class="line" href="namespacemshadow.html"> 334</a></span>&#160;<span class="keyword">namespace </span><a class="code" href="namespacemshadow.html">mshadow</a> {</div><div class="line"><a name="l00336"></a><span class="lineno"><a class="line" href="namespacemshadow.html#ac4cba6b672478463350f7d84b47e99e3"> 336</a></span>&#160;<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <a class="code" href="namespacemshadow.html#ac4cba6b672478463350f7d84b47e99e3">kRandBufferSize</a> = 1000000;</div><div class="line"><a name="l00338"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a8afab1f2134d65e09679faa324ecf9ce"> 338</a></span>&#160;<span class="keyword">const</span> <span class="keywordtype">float</span> <a class="code" href="namespacemshadow.html#a8afab1f2134d65e09679faa324ecf9ce">kPi</a> = 3.1415926f;</div><div class="line"><a name="l00340"></a><span class="lineno"> 340</span>&#160;<span class="preprocessor">#if MSHADOW_INT64_TENSOR_SIZE == 1</span></div><div class="line"><a name="l00341"></a><span class="lineno"> 341</span>&#160; <span class="keyword">typedef</span> int64_t <a class="code" href="namespacemshadow.html#adcbc2e1131386fccb1474b0bdf045926">index_t</a>;</div><div class="line"><a name="l00342"></a><span class="lineno"> 342</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00343"></a><span class="lineno"><a class="line" href="namespacemshadow.html#adcbc2e1131386fccb1474b0bdf045926"> 343</a></span>&#160; <span class="keyword">typedef</span> int32_t <a class="code" href="namespacemshadow.html#adcbc2e1131386fccb1474b0bdf045926">index_t</a>;</div><div class="line"><a name="l00344"></a><span class="lineno"> 344</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00345"></a><span class="lineno"> 345</span>&#160;</div><div class="line"><a name="l00346"></a><span class="lineno"> 346</span>&#160;<span class="preprocessor">#ifdef _WIN32</span></div><div class="line"><a name="l00347"></a><span class="lineno"> 347</span>&#160;</div><div class="line"><a name="l00348"></a><span class="lineno"> 348</span>&#160; <span class="keyword">typedef</span> int64_t <a class="code" href="namespacemshadow.html#aa94c153a2f8bcd10be82a4f5598ae5b9">openmp_index_t</a>;</div><div class="line"><a name="l00349"></a><span class="lineno"> 349</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00350"></a><span class="lineno"> 350</span>&#160;</div><div class="line"><a name="l00351"></a><span class="lineno"><a class="line" href="namespacemshadow.html#aa94c153a2f8bcd10be82a4f5598ae5b9"> 351</a></span>&#160; <span class="keyword">typedef</span> index_t <a class="code" href="namespacemshadow.html#aa94c153a2f8bcd10be82a4f5598ae5b9">openmp_index_t</a>;</div><div class="line"><a name="l00352"></a><span class="lineno"> 352</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00353"></a><span class="lineno"> 353</span>&#160;</div><div class="line"><a name="l00355"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a10a73dbdb4a2b833495c2315b6da69ce"> 355</a></span>&#160;<span class="keyword">typedef</span> <span class="keywordtype">float</span> <a class="code" href="namespacemshadow.html#a10a73dbdb4a2b833495c2315b6da69ce">default_real_t</a>;</div><div class="line"><a name="l00356"></a><span class="lineno"> 356</span>&#160;</div><div class="line"><a name="l00358"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1"> 358</a></span>&#160;<span class="keyword">enum</span> <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1">TypeFlag</a> {</div><div class="line"><a name="l00359"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a404a5fd26328cf46170f6eb3424c9633"> 359</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a404a5fd26328cf46170f6eb3424c9633">kFloat32</a> = 0,</div><div class="line"><a name="l00360"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a1f5a1c62216cbd2200443d501924cf28"> 360</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a1f5a1c62216cbd2200443d501924cf28">kFloat64</a> = 1,</div><div class="line"><a name="l00361"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a37ab9e42757689b17620f5728296d5d4"> 361</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a37ab9e42757689b17620f5728296d5d4">kFloat16</a> = 2,</div><div class="line"><a name="l00362"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a1a39d2f8230da3cb53528904c8a5fff0"> 362</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a1a39d2f8230da3cb53528904c8a5fff0">kUint8</a> = 3,</div><div class="line"><a name="l00363"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a4fbb02e389c3126918b505cd01188368"> 363</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a4fbb02e389c3126918b505cd01188368">kInt32</a> = 4,</div><div class="line"><a name="l00364"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a020e3574a4ec06c8e0b23a1b8a93026c"> 364</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a020e3574a4ec06c8e0b23a1b8a93026c">kInt8</a> = 5,</div><div class="line"><a name="l00365"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1accdd431fb941a9158baa00e7c5f3dc23"> 365</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1accdd431fb941a9158baa00e7c5f3dc23">kInt64</a> = 6,</div><div class="line"><a name="l00366"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1ad2f7fcc5a34a6b27898cfd5d1626882a"> 366</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1ad2f7fcc5a34a6b27898cfd5d1626882a">kBool</a> = 7,</div><div class="line"><a name="l00367"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a36cfd4fc26c0ee29affa99a36db0db17"> 367</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a36cfd4fc26c0ee29affa99a36db0db17">kInt16</a> = 8,</div><div class="line"><a name="l00368"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1aefe5e24a51079065b7707225c9289908"> 368</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1aefe5e24a51079065b7707225c9289908">kUint16</a> = 9,</div><div class="line"><a name="l00369"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1ad48a252ca3e6d2cbe89f1ba570d206a7"> 369</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1ad48a252ca3e6d2cbe89f1ba570d206a7">kUint32</a> = 10,</div><div class="line"><a name="l00370"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a2c5f8f21a24725e29edad31e3ba75ade"> 370</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a2c5f8f21a24725e29edad31e3ba75ade">kUint64</a> = 11,</div><div class="line"><a name="l00371"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a2313be720271dd8ef9d3becbed309f2e"> 371</a></span>&#160; <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a2313be720271dd8ef9d3becbed309f2e">kBfloat16</a> = 12</div><div class="line"><a name="l00372"></a><span class="lineno"> 372</span>&#160;};</div><div class="line"><a name="l00373"></a><span class="lineno"> 373</span>&#160;</div><div class="line"><a name="l00374"></a><span class="lineno"> 374</span>&#160;<span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00375"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType.html"> 375</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1DataType.html">DataType</a>;</div><div class="line"><a name="l00376"></a><span class="lineno"> 376</span>&#160;</div><div class="line"><a name="l00377"></a><span class="lineno"> 377</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00378"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01float_01_4.html"> 378</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1DataType.html">DataType</a>&lt;float&gt; {</div><div class="line"><a name="l00379"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01float_01_4.html#a9d3121fa39e365da9a2446e48a53d931"> 379</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kFlag = <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a404a5fd26328cf46170f6eb3424c9633">kFloat32</a>;</div><div class="line"><a name="l00380"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01float_01_4.html#a504a7e54598690e29928a89a76f15a09"> 380</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kLanes = 1;</div><div class="line"><a name="l00381"></a><span class="lineno"> 381</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CUDA</span></div><div class="line"><a name="l00382"></a><span class="lineno"> 382</span>&#160;<span class="preprocessor">#if (CUDA_VERSION &gt;= 8000)</span></div><div class="line"><a name="l00383"></a><span class="lineno"> 383</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudaDataType_t kCudaFlag = CUDA_R_32F;</div><div class="line"><a name="l00384"></a><span class="lineno"> 384</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00385"></a><span class="lineno"> 385</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CUDNN</span></div><div class="line"><a name="l00386"></a><span class="lineno"> 386</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudnnDataType_t kCudnnFlag = CUDNN_DATA_FLOAT;</div><div class="line"><a name="l00387"></a><span class="lineno"> 387</span>&#160; <span class="keyword">typedef</span> <span class="keywordtype">float</span> ScaleType;</div><div class="line"><a name="l00388"></a><span class="lineno"> 388</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00389"></a><span class="lineno"> 389</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00390"></a><span class="lineno"> 390</span>&#160;};</div><div class="line"><a name="l00391"></a><span class="lineno"> 391</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00392"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01double_01_4.html"> 392</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1DataType.html">DataType</a>&lt;double&gt; {</div><div class="line"><a name="l00393"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01double_01_4.html#a658d2110dd485145654b8af031b0cf0b"> 393</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kFlag = <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a1f5a1c62216cbd2200443d501924cf28">kFloat64</a>;</div><div class="line"><a name="l00394"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01double_01_4.html#aedb50ba7ff19dc149a3acedafb7f6d65"> 394</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kLanes = 1;</div><div class="line"><a name="l00395"></a><span class="lineno"> 395</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CUDA</span></div><div class="line"><a name="l00396"></a><span class="lineno"> 396</span>&#160;<span class="preprocessor">#if (CUDA_VERSION &gt;= 8000)</span></div><div class="line"><a name="l00397"></a><span class="lineno"> 397</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudaDataType_t kCudaFlag = CUDA_R_64F;</div><div class="line"><a name="l00398"></a><span class="lineno"> 398</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00399"></a><span class="lineno"> 399</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CUDNN</span></div><div class="line"><a name="l00400"></a><span class="lineno"> 400</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudnnDataType_t kCudnnFlag = CUDNN_DATA_DOUBLE;</div><div class="line"><a name="l00401"></a><span class="lineno"> 401</span>&#160; <span class="keyword">typedef</span> <span class="keywordtype">double</span> ScaleType;</div><div class="line"><a name="l00402"></a><span class="lineno"> 402</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00403"></a><span class="lineno"> 403</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00404"></a><span class="lineno"> 404</span>&#160;};</div><div class="line"><a name="l00405"></a><span class="lineno"> 405</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00406"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01half_1_1half__t_01_4.html"> 406</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1DataType.html">DataType</a>&lt;half::half_t&gt; {</div><div class="line"><a name="l00407"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01half_1_1half__t_01_4.html#a0c637cd624136613106ced1caf5c3b43"> 407</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kFlag = <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a37ab9e42757689b17620f5728296d5d4">kFloat16</a>;</div><div class="line"><a name="l00408"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01half_1_1half__t_01_4.html#a10fa4c69e1ef38e88804c7f02ca023ef"> 408</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kLanes = 1;</div><div class="line"><a name="l00409"></a><span class="lineno"> 409</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CUDA</span></div><div class="line"><a name="l00410"></a><span class="lineno"> 410</span>&#160;<span class="preprocessor">#if (CUDA_VERSION &gt;= 8000)</span></div><div class="line"><a name="l00411"></a><span class="lineno"> 411</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudaDataType_t kCudaFlag = CUDA_R_16F;</div><div class="line"><a name="l00412"></a><span class="lineno"> 412</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00413"></a><span class="lineno"> 413</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CUDNN</span></div><div class="line"><a name="l00414"></a><span class="lineno"> 414</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudnnDataType_t kCudnnFlag = CUDNN_DATA_HALF;</div><div class="line"><a name="l00415"></a><span class="lineno"> 415</span>&#160; <span class="keyword">typedef</span> <span class="keywordtype">float</span> ScaleType;</div><div class="line"><a name="l00416"></a><span class="lineno"> 416</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00417"></a><span class="lineno"> 417</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00418"></a><span class="lineno"> 418</span>&#160;};</div><div class="line"><a name="l00419"></a><span class="lineno"> 419</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00420"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01half_1_1half2__t_01_4.html"> 420</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1DataType.html">DataType</a>&lt;half::half2_t&gt; {</div><div class="line"><a name="l00421"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01half_1_1half2__t_01_4.html#a77f60e3970b5684cf52cf042789389f6"> 421</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kFlag = <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a37ab9e42757689b17620f5728296d5d4">kFloat16</a>;</div><div class="line"><a name="l00422"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01half_1_1half2__t_01_4.html#a32b20fb1fc69519c933ff32ec3f59f37"> 422</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kLanes = 2;</div><div class="line"><a name="l00423"></a><span class="lineno"> 423</span>&#160;};</div><div class="line"><a name="l00424"></a><span class="lineno"> 424</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00425"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01bfloat_1_1bf16__t_01_4.html"> 425</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1DataType.html">DataType</a>&lt;bfloat::bf16_t&gt; {</div><div class="line"><a name="l00426"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01bfloat_1_1bf16__t_01_4.html#abf8e679c7d024771f8b41f3e87ae044a"> 426</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kFlag = <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a2313be720271dd8ef9d3becbed309f2e">kBfloat16</a>;</div><div class="line"><a name="l00427"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01bfloat_1_1bf16__t_01_4.html#a4b583091e70524e4590811ade2c6770c"> 427</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kLanes = 1;</div><div class="line"><a name="l00428"></a><span class="lineno"> 428</span>&#160;};</div><div class="line"><a name="l00429"></a><span class="lineno"> 429</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00430"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01uint8__t_01_4.html"> 430</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1DataType.html">DataType</a>&lt;uint8_t&gt; {</div><div class="line"><a name="l00431"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01uint8__t_01_4.html#a3a760afb8012b5db5f75bfa1c5f5f1f8"> 431</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kFlag = <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a1a39d2f8230da3cb53528904c8a5fff0">kUint8</a>;</div><div class="line"><a name="l00432"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01uint8__t_01_4.html#a73bfeffab7e4d68994c298a80c68b536"> 432</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kLanes = 1;</div><div class="line"><a name="l00433"></a><span class="lineno"> 433</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CUDA</span></div><div class="line"><a name="l00434"></a><span class="lineno"> 434</span>&#160;<span class="preprocessor">#if (CUDA_VERSION &gt;= 8000)</span></div><div class="line"><a name="l00435"></a><span class="lineno"> 435</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudaDataType_t kCudaFlag = CUDA_R_8U;</div><div class="line"><a name="l00436"></a><span class="lineno"> 436</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00437"></a><span class="lineno"> 437</span>&#160;<span class="preprocessor">#if (MSHADOW_USE_CUDNN == 1 &amp;&amp; CUDNN_MAJOR &gt;= 6)</span></div><div class="line"><a name="l00438"></a><span class="lineno"> 438</span>&#160; <span class="comment">// no uint8 in cudnn for now</span></div><div class="line"><a name="l00439"></a><span class="lineno"> 439</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudnnDataType_t kCudnnFlag = CUDNN_DATA_INT8;</div><div class="line"><a name="l00440"></a><span class="lineno"> 440</span>&#160; <span class="keyword">typedef</span> uint8_t ScaleType;</div><div class="line"><a name="l00441"></a><span class="lineno"> 441</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00442"></a><span class="lineno"> 442</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00443"></a><span class="lineno"> 443</span>&#160;};</div><div class="line"><a name="l00444"></a><span class="lineno"> 444</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00445"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01int8__t_01_4.html"> 445</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1DataType.html">DataType</a>&lt;int8_t&gt; {</div><div class="line"><a name="l00446"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01int8__t_01_4.html#a5d224a971dcc10ced072758683ce3fbb"> 446</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kFlag = <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a020e3574a4ec06c8e0b23a1b8a93026c">kInt8</a>;</div><div class="line"><a name="l00447"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01int8__t_01_4.html#ab40b8f46826e7af9a45c1b05398705d2"> 447</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kLanes = 1;</div><div class="line"><a name="l00448"></a><span class="lineno"> 448</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CUDA</span></div><div class="line"><a name="l00449"></a><span class="lineno"> 449</span>&#160;<span class="preprocessor">#if (CUDA_VERSION &gt;= 8000)</span></div><div class="line"><a name="l00450"></a><span class="lineno"> 450</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudaDataType_t kCudaFlag = CUDA_R_8I;</div><div class="line"><a name="l00451"></a><span class="lineno"> 451</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00452"></a><span class="lineno"> 452</span>&#160;<span class="preprocessor">#if (MSHADOW_USE_CUDNN == 1 &amp;&amp; CUDNN_MAJOR &gt;= 6)</span></div><div class="line"><a name="l00453"></a><span class="lineno"> 453</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudnnDataType_t kCudnnFlag = CUDNN_DATA_INT8;</div><div class="line"><a name="l00454"></a><span class="lineno"> 454</span>&#160; <span class="keyword">typedef</span> int8_t ScaleType;</div><div class="line"><a name="l00455"></a><span class="lineno"> 455</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00456"></a><span class="lineno"> 456</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00457"></a><span class="lineno"> 457</span>&#160;};</div><div class="line"><a name="l00458"></a><span class="lineno"> 458</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00459"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01int32__t_01_4.html"> 459</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1DataType.html">DataType</a>&lt;int32_t&gt; {</div><div class="line"><a name="l00460"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01int32__t_01_4.html#a97dcb369c90d76a380bca80c62f23be3"> 460</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kFlag = <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a4fbb02e389c3126918b505cd01188368">kInt32</a>;</div><div class="line"><a name="l00461"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01int32__t_01_4.html#a0f5130ae65b507a23e7bd8c3098b7a1e"> 461</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kLanes = 1;</div><div class="line"><a name="l00462"></a><span class="lineno"> 462</span>&#160;<span class="preprocessor">#if MSHADOW_USE_CUDA</span></div><div class="line"><a name="l00463"></a><span class="lineno"> 463</span>&#160;<span class="preprocessor">#if (CUDA_VERSION &gt;= 8000)</span></div><div class="line"><a name="l00464"></a><span class="lineno"> 464</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudaDataType_t kCudaFlag = CUDA_R_32I;</div><div class="line"><a name="l00465"></a><span class="lineno"> 465</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00466"></a><span class="lineno"> 466</span>&#160;<span class="preprocessor">#if (MSHADOW_USE_CUDNN == 1 &amp;&amp; CUDNN_MAJOR &gt;= 6)</span></div><div class="line"><a name="l00467"></a><span class="lineno"> 467</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudnnDataType_t kCudnnFlag = CUDNN_DATA_INT32;</div><div class="line"><a name="l00468"></a><span class="lineno"> 468</span>&#160; <span class="keyword">typedef</span> int32_t ScaleType;</div><div class="line"><a name="l00469"></a><span class="lineno"> 469</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00470"></a><span class="lineno"> 470</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00471"></a><span class="lineno"> 471</span>&#160;};</div><div class="line"><a name="l00472"></a><span class="lineno"> 472</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00473"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01int64__t_01_4.html"> 473</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1DataType.html">DataType</a>&lt;int64_t&gt; {</div><div class="line"><a name="l00474"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01int64__t_01_4.html#aed15ad327b09b35a4a6d7e52cb8c25aa"> 474</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kFlag = <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1accdd431fb941a9158baa00e7c5f3dc23">kInt64</a>;</div><div class="line"><a name="l00475"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01int64__t_01_4.html#ac21b9b3c8bc8edb01e183ebf97d05a09"> 475</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kLanes = 1;</div><div class="line"><a name="l00476"></a><span class="lineno"> 476</span>&#160;};</div><div class="line"><a name="l00477"></a><span class="lineno"> 477</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00478"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01bool_01_4.html"> 478</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1DataType.html">DataType</a>&lt;bool&gt; {</div><div class="line"><a name="l00479"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01bool_01_4.html#a01e3a14bc3d13155ad0bf31927a197b4"> 479</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kFlag = <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1ad2f7fcc5a34a6b27898cfd5d1626882a">kBool</a>;</div><div class="line"><a name="l00480"></a><span class="lineno"><a class="line" href="structmshadow_1_1DataType_3_01bool_01_4.html#a1510a26bddc961b00ad25a2870db47db"> 480</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kLanes = 1;</div><div class="line"><a name="l00481"></a><span class="lineno"> 481</span>&#160;};</div><div class="line"><a name="l00482"></a><span class="lineno"> 482</span>&#160;</div><div class="line"><a name="l00484"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a143ad1a73ba518ef0aad29d36f2569ee"> 484</a></span>&#160;<span class="keyword">const</span> <span class="keywordtype">int</span> <a class="code" href="namespacemshadow.html#a143ad1a73ba518ef0aad29d36f2569ee">default_type_flag</a> = <a class="code" href="structmshadow_1_1DataType.html">DataType&lt;default_real_t&gt;::kFlag</a>;</div><div class="line"><a name="l00485"></a><span class="lineno"> 485</span>&#160;</div><div class="line"><a name="l00487"></a><span class="lineno"><a class="line" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4"> 487</a></span>&#160;<span class="keyword">enum</span> <a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4">LayoutFlag</a> {</div><div class="line"><a name="l00488"></a><span class="lineno"><a class="line" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4ae633c123a9c9897779d5c00ea5381775"> 488</a></span>&#160; <a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4ae633c123a9c9897779d5c00ea5381775">kNCHW</a> = 0,</div><div class="line"><a name="l00489"></a><span class="lineno"><a class="line" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4ad9ef54b427a838279a62e95204aa3281"> 489</a></span>&#160; <a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4ad9ef54b427a838279a62e95204aa3281">kNHWC</a>,</div><div class="line"><a name="l00490"></a><span class="lineno"><a class="line" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a6e334c4df779fcc6fa6b24411fce1289"> 490</a></span>&#160; <a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a6e334c4df779fcc6fa6b24411fce1289">kCHWN</a>,</div><div class="line"><a name="l00491"></a><span class="lineno"> 491</span>&#160;</div><div class="line"><a name="l00492"></a><span class="lineno"><a class="line" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a0cfb685a803481d9ff4fe19d813b261a"> 492</a></span>&#160; <a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a0cfb685a803481d9ff4fe19d813b261a">kNCW</a> = 1 &lt;&lt; 3,</div><div class="line"><a name="l00493"></a><span class="lineno"><a class="line" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a3f4908b910c47da082d60aa719c43fc3"> 493</a></span>&#160; <a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a3f4908b910c47da082d60aa719c43fc3">kNWC</a>,</div><div class="line"><a name="l00494"></a><span class="lineno"><a class="line" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4ae5189456ea58c60d8c546ab8bd1a2c08"> 494</a></span>&#160; <a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4ae5189456ea58c60d8c546ab8bd1a2c08">kCWN</a>,</div><div class="line"><a name="l00495"></a><span class="lineno"> 495</span>&#160;</div><div class="line"><a name="l00496"></a><span class="lineno"><a class="line" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4aa332dc48875dac0ef29ef245e5609822"> 496</a></span>&#160; <a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4aa332dc48875dac0ef29ef245e5609822">kNCDHW</a> = 1 &lt;&lt; 5,</div><div class="line"><a name="l00497"></a><span class="lineno"><a class="line" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a37c45177ee0fe2468d562a9e5e3e38dd"> 497</a></span>&#160; <a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a37c45177ee0fe2468d562a9e5e3e38dd">kNDHWC</a>,</div><div class="line"><a name="l00498"></a><span class="lineno"><a class="line" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a30ea75730b725ac965fb4e43c34622d8"> 498</a></span>&#160; <a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a30ea75730b725ac965fb4e43c34622d8">kCDHWN</a></div><div class="line"><a name="l00499"></a><span class="lineno"> 499</span>&#160;};</div><div class="line"><a name="l00500"></a><span class="lineno"> 500</span>&#160;</div><div class="line"><a name="l00501"></a><span class="lineno"> 501</span>&#160;<span class="keyword">template</span>&lt;<span class="keywordtype">int</span> layout&gt;</div><div class="line"><a name="l00502"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType.html"> 502</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1LayoutType.html">LayoutType</a>;</div><div class="line"><a name="l00503"></a><span class="lineno"> 503</span>&#160;</div><div class="line"><a name="l00504"></a><span class="lineno"> 504</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00505"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType_3_01kNCHW_01_4.html"> 505</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1LayoutType.html">LayoutType</a>&lt;<a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4ae633c123a9c9897779d5c00ea5381775">kNCHW</a>&gt; {</div><div class="line"><a name="l00506"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType_3_01kNCHW_01_4.html#a9244a6553f6801877a321ec815f01ae8"> 506</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> index_t kNdim = 4;</div><div class="line"><a name="l00507"></a><span class="lineno"> 507</span>&#160;<span class="preprocessor">#if (MSHADOW_USE_CUDA &amp;&amp; MSHADOW_USE_CUDNN == 1 &amp;&amp; CUDNN_MAJOR &gt;= 4)</span></div><div class="line"><a name="l00508"></a><span class="lineno"> 508</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudnnTensorFormat_t kCudnnFlag = CUDNN_TENSOR_NCHW;</div><div class="line"><a name="l00509"></a><span class="lineno"> 509</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00510"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType_3_01kNCHW_01_4.html#a493ac509b0bc6c405466e665af218292"> 510</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kCudnnFlag = -1;</div><div class="line"><a name="l00511"></a><span class="lineno"> 511</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00512"></a><span class="lineno"> 512</span>&#160;};</div><div class="line"><a name="l00513"></a><span class="lineno"> 513</span>&#160;</div><div class="line"><a name="l00514"></a><span class="lineno"> 514</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00515"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType_3_01kNHWC_01_4.html"> 515</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1LayoutType.html">LayoutType</a>&lt;<a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4ad9ef54b427a838279a62e95204aa3281">kNHWC</a>&gt; {</div><div class="line"><a name="l00516"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType_3_01kNHWC_01_4.html#a809055ce2162321e9a4326651ee4c897"> 516</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> index_t kNdim = 4;</div><div class="line"><a name="l00517"></a><span class="lineno"> 517</span>&#160;<span class="preprocessor">#if (MSHADOW_USE_CUDA &amp;&amp; MSHADOW_USE_CUDNN == 1 &amp;&amp; CUDNN_MAJOR &gt;= 4)</span></div><div class="line"><a name="l00518"></a><span class="lineno"> 518</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudnnTensorFormat_t kCudnnFlag = CUDNN_TENSOR_NHWC;</div><div class="line"><a name="l00519"></a><span class="lineno"> 519</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00520"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType_3_01kNHWC_01_4.html#a9bc9929da63ab8dfbd4c8171624cf485"> 520</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kCudnnFlag = -1;</div><div class="line"><a name="l00521"></a><span class="lineno"> 521</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00522"></a><span class="lineno"> 522</span>&#160;};</div><div class="line"><a name="l00523"></a><span class="lineno"> 523</span>&#160;</div><div class="line"><a name="l00525"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a36590a455cab713cf4bbb115c4dba247"> 525</a></span>&#160;<span class="keyword">const</span> <span class="keywordtype">int</span> <a class="code" href="namespacemshadow.html#a36590a455cab713cf4bbb115c4dba247">default_layout</a> = <a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4ae633c123a9c9897779d5c00ea5381775">kNCHW</a>;</div><div class="line"><a name="l00526"></a><span class="lineno"> 526</span>&#160;</div><div class="line"><a name="l00527"></a><span class="lineno"> 527</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00528"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType_3_01kNCDHW_01_4.html"> 528</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1LayoutType.html">LayoutType</a>&lt;<a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4aa332dc48875dac0ef29ef245e5609822">kNCDHW</a>&gt; {</div><div class="line"><a name="l00529"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType_3_01kNCDHW_01_4.html#a5cebe847b04e020d4b89e8ccfeda39af"> 529</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> index_t kNdim = 5;</div><div class="line"><a name="l00530"></a><span class="lineno"> 530</span>&#160;<span class="preprocessor">#if (MSHADOW_USE_CUDA &amp;&amp; MSHADOW_USE_CUDNN == 1 &amp;&amp; CUDNN_MAJOR &gt;= 4)</span></div><div class="line"><a name="l00531"></a><span class="lineno"> 531</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudnnTensorFormat_t kCudnnFlag = CUDNN_TENSOR_NCHW;</div><div class="line"><a name="l00532"></a><span class="lineno"> 532</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00533"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType_3_01kNCDHW_01_4.html#a593764b7925e07d3becd851404f4ccd0"> 533</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kCudnnFlag = -1;</div><div class="line"><a name="l00534"></a><span class="lineno"> 534</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00535"></a><span class="lineno"> 535</span>&#160;};</div><div class="line"><a name="l00536"></a><span class="lineno"> 536</span>&#160;</div><div class="line"><a name="l00537"></a><span class="lineno"> 537</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00538"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType_3_01kNDHWC_01_4.html"> 538</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1LayoutType.html">LayoutType</a>&lt;<a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a37c45177ee0fe2468d562a9e5e3e38dd">kNDHWC</a>&gt; {</div><div class="line"><a name="l00539"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType_3_01kNDHWC_01_4.html#ad8442031a3dbf59b4c8be28b58c0c3ff"> 539</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> index_t kNdim = 5;</div><div class="line"><a name="l00540"></a><span class="lineno"> 540</span>&#160;<span class="preprocessor">#if (MSHADOW_USE_CUDA &amp;&amp; MSHADOW_USE_CUDNN == 1 &amp;&amp; CUDNN_MAJOR &gt;= 4)</span></div><div class="line"><a name="l00541"></a><span class="lineno"> 541</span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> cudnnTensorFormat_t kCudnnFlag = CUDNN_TENSOR_NHWC;</div><div class="line"><a name="l00542"></a><span class="lineno"> 542</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00543"></a><span class="lineno"><a class="line" href="structmshadow_1_1LayoutType_3_01kNDHWC_01_4.html#aacf7a3b6c883d5a9864bbd0a2430ec01"> 543</a></span>&#160; <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> kCudnnFlag = -1;</div><div class="line"><a name="l00544"></a><span class="lineno"> 544</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00545"></a><span class="lineno"> 545</span>&#160;};</div><div class="line"><a name="l00546"></a><span class="lineno"> 546</span>&#160;</div><div class="line"><a name="l00548"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a29fa60cc6436415a699971c1a3fd760a"> 548</a></span>&#160;<span class="keyword">const</span> <span class="keywordtype">int</span> <a class="code" href="namespacemshadow.html#a29fa60cc6436415a699971c1a3fd760a">default_layout_5d</a> = <a class="code" href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4aa332dc48875dac0ef29ef245e5609822">kNCDHW</a>;</div><div class="line"><a name="l00549"></a><span class="lineno"> 549</span>&#160;</div><div class="line"><a name="l00551"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1op.html"> 551</a></span>&#160;<span class="keyword">namespace </span>op {</div><div class="line"><a name="l00552"></a><span class="lineno"> 552</span>&#160;<span class="comment">// binary operator</span></div><div class="line"><a name="l00554"></a><span class="lineno"><a class="line" href="structmshadow_1_1op_1_1mul.html"> 554</a></span>&#160;<span class="comment"></span><span class="keyword">struct </span><a class="code" href="structmshadow_1_1op_1_1mul.html">mul</a>{</div><div class="line"><a name="l00556"></a><span class="lineno"> 556</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00557"></a><span class="lineno"><a class="line" href="structmshadow_1_1op_1_1mul.html#a38a7497e4f710d7da3f5b9563d754b21"> 557</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> DType <a class="code" href="structmshadow_1_1op_1_1mul.html#a38a7497e4f710d7da3f5b9563d754b21">Map</a>(DType a, DType b) {</div><div class="line"><a name="l00558"></a><span class="lineno"> 558</span>&#160; <span class="keywordflow">return</span> a * b;</div><div class="line"><a name="l00559"></a><span class="lineno"> 559</span>&#160; }</div><div class="line"><a name="l00560"></a><span class="lineno"> 560</span>&#160;};</div><div class="line"><a name="l00562"></a><span class="lineno"><a class="line" href="structmshadow_1_1op_1_1plus.html"> 562</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1op_1_1plus.html">plus</a> {</div><div class="line"><a name="l00564"></a><span class="lineno"> 564</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00565"></a><span class="lineno"><a class="line" href="structmshadow_1_1op_1_1plus.html#a83fb5b1656992c6fd442a819de83b292"> 565</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> DType <a class="code" href="structmshadow_1_1op_1_1plus.html#a83fb5b1656992c6fd442a819de83b292">Map</a>(DType a, DType b) {</div><div class="line"><a name="l00566"></a><span class="lineno"> 566</span>&#160; <span class="keywordflow">return</span> a + b;</div><div class="line"><a name="l00567"></a><span class="lineno"> 567</span>&#160; }</div><div class="line"><a name="l00568"></a><span class="lineno"> 568</span>&#160;};</div><div class="line"><a name="l00570"></a><span class="lineno"><a class="line" href="structmshadow_1_1op_1_1minus.html"> 570</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1op_1_1minus.html">minus</a> {</div><div class="line"><a name="l00572"></a><span class="lineno"> 572</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00573"></a><span class="lineno"><a class="line" href="structmshadow_1_1op_1_1minus.html#a29e530a31da95225c916e13f1bbcbca6"> 573</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> DType <a class="code" href="structmshadow_1_1op_1_1minus.html#a29e530a31da95225c916e13f1bbcbca6">Map</a>(DType a, DType b) {</div><div class="line"><a name="l00574"></a><span class="lineno"> 574</span>&#160; <span class="keywordflow">return</span> a - b;</div><div class="line"><a name="l00575"></a><span class="lineno"> 575</span>&#160; }</div><div class="line"><a name="l00576"></a><span class="lineno"> 576</span>&#160;};</div><div class="line"><a name="l00578"></a><span class="lineno"><a class="line" href="structmshadow_1_1op_1_1div.html"> 578</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1op_1_1div.html">div</a> {</div><div class="line"><a name="l00580"></a><span class="lineno"> 580</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00581"></a><span class="lineno"><a class="line" href="structmshadow_1_1op_1_1div.html#a5ad9c92273fb4c1a29fc3eb3fba3ae5a"> 581</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> DType <a class="code" href="structmshadow_1_1op_1_1div.html#a5ad9c92273fb4c1a29fc3eb3fba3ae5a">Map</a>(DType a, DType b) {</div><div class="line"><a name="l00582"></a><span class="lineno"> 582</span>&#160; <span class="keywordflow">return</span> a / b;</div><div class="line"><a name="l00583"></a><span class="lineno"> 583</span>&#160; }</div><div class="line"><a name="l00584"></a><span class="lineno"> 584</span>&#160;};</div><div class="line"><a name="l00586"></a><span class="lineno"><a class="line" href="structmshadow_1_1op_1_1right.html"> 586</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1op_1_1right.html">right</a> {</div><div class="line"><a name="l00588"></a><span class="lineno"> 588</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00589"></a><span class="lineno"><a class="line" href="structmshadow_1_1op_1_1right.html#a9377077b54a983fd220a0ba0263227b3"> 589</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> DType <a class="code" href="structmshadow_1_1op_1_1right.html#a9377077b54a983fd220a0ba0263227b3">Map</a>(DType a, DType b) {</div><div class="line"><a name="l00590"></a><span class="lineno"> 590</span>&#160; <span class="keywordflow">return</span> b;</div><div class="line"><a name="l00591"></a><span class="lineno"> 591</span>&#160; }</div><div class="line"><a name="l00592"></a><span class="lineno"> 592</span>&#160;};</div><div class="line"><a name="l00593"></a><span class="lineno"> 593</span>&#160;<span class="comment">// unary operator/ function: example</span></div><div class="line"><a name="l00594"></a><span class="lineno"> 594</span>&#160;<span class="comment">// these operators can be defined by user,</span></div><div class="line"><a name="l00595"></a><span class="lineno"> 595</span>&#160;<span class="comment">// in the same style as binary and unary operator</span></div><div class="line"><a name="l00596"></a><span class="lineno"> 596</span>&#160;<span class="comment">// to use, simply write F&lt;op::identity&gt;( src )</span></div><div class="line"><a name="l00598"></a><span class="lineno"><a class="line" href="structmshadow_1_1op_1_1identity.html"> 598</a></span>&#160;<span class="comment"></span><span class="keyword">struct </span><a class="code" href="structmshadow_1_1op_1_1identity.html">identity</a>{</div><div class="line"><a name="l00600"></a><span class="lineno"> 600</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00601"></a><span class="lineno"><a class="line" href="structmshadow_1_1op_1_1identity.html#a260f8047dca47cb16ff0adaf16f5e8e6"> 601</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> DType <a class="code" href="structmshadow_1_1op_1_1identity.html#a260f8047dca47cb16ff0adaf16f5e8e6">Map</a>(DType a) {</div><div class="line"><a name="l00602"></a><span class="lineno"> 602</span>&#160; <span class="keywordflow">return</span> a;</div><div class="line"><a name="l00603"></a><span class="lineno"> 603</span>&#160; }</div><div class="line"><a name="l00604"></a><span class="lineno"> 604</span>&#160;};</div><div class="line"><a name="l00605"></a><span class="lineno"> 605</span>&#160;} <span class="comment">// namespace op</span></div><div class="line"><a name="l00607"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1sv.html"> 607</a></span>&#160;<span class="comment"></span><span class="keyword">namespace </span>sv {</div><div class="line"><a name="l00609"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1saveto.html"> 609</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1sv_1_1saveto.html">saveto</a> {</div><div class="line"><a name="l00611"></a><span class="lineno"> 611</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00612"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1saveto.html#af99e9c2ec6d116febb41fc73d201d80e"> 612</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1sv_1_1saveto.html#af99e9c2ec6d116febb41fc73d201d80e">Save</a>(DType &amp;a, DType b) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00613"></a><span class="lineno"> 613</span>&#160; a = b;</div><div class="line"><a name="l00614"></a><span class="lineno"> 614</span>&#160; }</div><div class="line"><a name="l00616"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1saveto.html#aaf49b727bb5fe9098081c265100cb340"> 616</a></span>&#160; <span class="keyword">inline</span> <span class="keyword">static</span> default_real_t <a class="code" href="structmshadow_1_1sv_1_1saveto.html#aaf49b727bb5fe9098081c265100cb340">AlphaBLAS</a>(<span class="keywordtype">void</span>) { <span class="keywordflow">return</span> 1.0f; }</div><div class="line"><a name="l00618"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1saveto.html#a4dab404c405fe7476eadbd02e727738b"> 618</a></span>&#160; <span class="keyword">inline</span> <span class="keyword">static</span> default_real_t <a class="code" href="structmshadow_1_1sv_1_1saveto.html#a4dab404c405fe7476eadbd02e727738b">BetaBLAS</a>(<span class="keywordtype">void</span>) { <span class="keywordflow">return</span> 0.0f; }</div><div class="line"><a name="l00620"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1saveto.html#ac78ceb69e8291f8fa767c2eda2a732a5"> 620</a></span>&#160; <span class="keyword">typedef</span> <a class="code" href="structmshadow_1_1op_1_1right.html">op::right</a> <a class="code" href="structmshadow_1_1sv_1_1saveto.html#ac78ceb69e8291f8fa767c2eda2a732a5">OPType</a>;</div><div class="line"><a name="l00621"></a><span class="lineno"> 621</span>&#160;};</div><div class="line"><a name="l00623"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1plusto.html"> 623</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1sv_1_1plusto.html">plusto</a> {</div><div class="line"><a name="l00625"></a><span class="lineno"> 625</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00626"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1plusto.html#ac7556832c791c8d048cbb7fd606f6e8e"> 626</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1sv_1_1plusto.html#ac7556832c791c8d048cbb7fd606f6e8e">Save</a>(DType &amp;a, DType b) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00627"></a><span class="lineno"> 627</span>&#160; a += b;</div><div class="line"><a name="l00628"></a><span class="lineno"> 628</span>&#160; }</div><div class="line"><a name="l00630"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1plusto.html#a9acc887f74cce8e18f1a86818154ca1c"> 630</a></span>&#160; <span class="keyword">inline</span> <span class="keyword">static</span> default_real_t <a class="code" href="structmshadow_1_1sv_1_1plusto.html#a9acc887f74cce8e18f1a86818154ca1c">AlphaBLAS</a>(<span class="keywordtype">void</span>) { <span class="keywordflow">return</span> 1.0f; }</div><div class="line"><a name="l00632"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1plusto.html#a916ea217bd0200ab7b23a4e2ac26887f"> 632</a></span>&#160; <span class="keyword">inline</span> <span class="keyword">static</span> default_real_t <a class="code" href="structmshadow_1_1sv_1_1plusto.html#a916ea217bd0200ab7b23a4e2ac26887f">BetaBLAS</a>(<span class="keywordtype">void</span>) { <span class="keywordflow">return</span> 1.0f; }</div><div class="line"><a name="l00634"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1plusto.html#a0b3849b290f3207a59b8975e2b29b065"> 634</a></span>&#160; <span class="keyword">typedef</span> <a class="code" href="structmshadow_1_1op_1_1plus.html">op::plus</a> <a class="code" href="structmshadow_1_1sv_1_1plusto.html#a0b3849b290f3207a59b8975e2b29b065">OPType</a>;</div><div class="line"><a name="l00635"></a><span class="lineno"> 635</span>&#160;};</div><div class="line"><a name="l00637"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1minusto.html"> 637</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1sv_1_1minusto.html">minusto</a> {</div><div class="line"><a name="l00639"></a><span class="lineno"> 639</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00640"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1minusto.html#a50bab98db98ee42cd377f2e2f02e37ca"> 640</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1sv_1_1minusto.html#a50bab98db98ee42cd377f2e2f02e37ca">Save</a>(DType &amp;a, DType b) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00641"></a><span class="lineno"> 641</span>&#160; a -= b;</div><div class="line"><a name="l00642"></a><span class="lineno"> 642</span>&#160; }</div><div class="line"><a name="l00644"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1minusto.html#a0da791365b9910dd337e228888521127"> 644</a></span>&#160; <span class="keyword">inline</span> <span class="keyword">static</span> default_real_t <a class="code" href="structmshadow_1_1sv_1_1minusto.html#a0da791365b9910dd337e228888521127">AlphaBLAS</a>(<span class="keywordtype">void</span>) { <span class="keywordflow">return</span> -1.0f; }</div><div class="line"><a name="l00646"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1minusto.html#a48fae34ea7d461ced6ac9c98c5e38019"> 646</a></span>&#160; <span class="keyword">inline</span> <span class="keyword">static</span> default_real_t <a class="code" href="structmshadow_1_1sv_1_1minusto.html#a48fae34ea7d461ced6ac9c98c5e38019">BetaBLAS</a>(<span class="keywordtype">void</span>) { <span class="keywordflow">return</span> 1.0f; }</div><div class="line"><a name="l00648"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1minusto.html#ac9baef2b9d3a92b962c9ad7f7ee1122d"> 648</a></span>&#160; <span class="keyword">typedef</span> <a class="code" href="structmshadow_1_1op_1_1minus.html">op::minus</a> <a class="code" href="structmshadow_1_1sv_1_1minusto.html#ac9baef2b9d3a92b962c9ad7f7ee1122d">OPType</a>;</div><div class="line"><a name="l00649"></a><span class="lineno"> 649</span>&#160;};</div><div class="line"><a name="l00651"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1multo.html"> 651</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1sv_1_1multo.html">multo</a> {</div><div class="line"><a name="l00653"></a><span class="lineno"> 653</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00654"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1multo.html#ab3b6328d24ef3ce0cf5c0329e254f193"> 654</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1sv_1_1multo.html#ab3b6328d24ef3ce0cf5c0329e254f193">Save</a>(DType &amp;a, DType b) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00655"></a><span class="lineno"> 655</span>&#160; a *= b;</div><div class="line"><a name="l00656"></a><span class="lineno"> 656</span>&#160; }</div><div class="line"><a name="l00658"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1multo.html#acc47e9c85d6e583e5785ba0f62fa4431"> 658</a></span>&#160; <span class="keyword">typedef</span> <a class="code" href="structmshadow_1_1op_1_1mul.html">op::mul</a> <a class="code" href="structmshadow_1_1sv_1_1multo.html#acc47e9c85d6e583e5785ba0f62fa4431">OPType</a>;</div><div class="line"><a name="l00659"></a><span class="lineno"> 659</span>&#160;};</div><div class="line"><a name="l00661"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1divto.html"> 661</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1sv_1_1divto.html">divto</a> {</div><div class="line"><a name="l00663"></a><span class="lineno"> 663</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00664"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1divto.html#aaa2299b2a710d1b5d61b6dc6f44c9339"> 664</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1sv_1_1divto.html#aaa2299b2a710d1b5d61b6dc6f44c9339">Save</a>(DType&amp; a, DType b) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00665"></a><span class="lineno"> 665</span>&#160; a /= b;</div><div class="line"><a name="l00666"></a><span class="lineno"> 666</span>&#160; }</div><div class="line"><a name="l00668"></a><span class="lineno"><a class="line" href="structmshadow_1_1sv_1_1divto.html#ab8864c99eea0286fce8f5a8f791f0f33"> 668</a></span>&#160; <span class="keyword">typedef</span> <a class="code" href="structmshadow_1_1op_1_1div.html">op::div</a> <a class="code" href="structmshadow_1_1sv_1_1divto.html#ab8864c99eea0286fce8f5a8f791f0f33">OPType</a>;</div><div class="line"><a name="l00669"></a><span class="lineno"> 669</span>&#160;};</div><div class="line"><a name="l00670"></a><span class="lineno"> 670</span>&#160;} <span class="comment">// namespace sv</span></div><div class="line"><a name="l00671"></a><span class="lineno"> 671</span>&#160;</div><div class="line"><a name="l00672"></a><span class="lineno"> 672</span>&#160;<span class="preprocessor">#ifndef __CUDA_ARCH__</span></div><div class="line"><a name="l00673"></a><span class="lineno"> 673</span>&#160;<span class="keyword">using</span> std::isnan;</div><div class="line"><a name="l00674"></a><span class="lineno"> 674</span>&#160;<span class="keyword">using</span> std::isinf;</div><div class="line"><a name="l00675"></a><span class="lineno"> 675</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00676"></a><span class="lineno"> 676</span>&#160;</div><div class="line"><a name="l00680"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1isnan__typed.html"> 680</a></span>&#160;<span class="keyword">namespace </span>isnan_typed {</div><div class="line"><a name="l00681"></a><span class="lineno"> 681</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00682"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1isnan__typed.html#a31da61266fae8c9ca52df015d132b759"> 682</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">bool</span> <a class="code" href="namespacemshadow_1_1isnan__typed.html#abae8abe8600d9f57faddd8e59ad9ed50">IsNan</a>(<span class="keyword">volatile</span> DType val) {</div><div class="line"><a name="l00683"></a><span class="lineno"> 683</span>&#160; <span class="keywordflow">return</span> <span class="keyword">false</span>;</div><div class="line"><a name="l00684"></a><span class="lineno"> 684</span>&#160; }</div><div class="line"><a name="l00685"></a><span class="lineno"> 685</span>&#160; <span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00686"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1isnan__typed.html#ad4b4eb847832e78bfa17be14f68c43d9"> 686</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">bool</span> <a class="code" href="namespacemshadow_1_1isnan__typed.html#abae8abe8600d9f57faddd8e59ad9ed50">IsNan</a>(<span class="keyword">volatile</span> <span class="keywordtype">float</span> val) {</div><div class="line"><a name="l00687"></a><span class="lineno"> 687</span>&#160; <span class="keywordflow">return</span> isnan(val);</div><div class="line"><a name="l00688"></a><span class="lineno"> 688</span>&#160; }</div><div class="line"><a name="l00689"></a><span class="lineno"> 689</span>&#160; <span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00690"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1isnan__typed.html#a85d9d2f79f833f934cd5f14821347c9d"> 690</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">bool</span> <a class="code" href="namespacemshadow_1_1isnan__typed.html#abae8abe8600d9f57faddd8e59ad9ed50">IsNan</a>(<span class="keyword">volatile</span> <span class="keywordtype">double</span> val) {</div><div class="line"><a name="l00691"></a><span class="lineno"> 691</span>&#160; <span class="keywordflow">return</span> isnan(val);</div><div class="line"><a name="l00692"></a><span class="lineno"> 692</span>&#160; }</div><div class="line"><a name="l00693"></a><span class="lineno"> 693</span>&#160; <span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00694"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1isnan__typed.html#ac1bcb29820df6644b2a72b230969a9d1"> 694</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">bool</span> <a class="code" href="namespacemshadow_1_1isnan__typed.html#abae8abe8600d9f57faddd8e59ad9ed50">IsNan</a>(<span class="keyword">volatile</span> <span class="keywordtype">long</span> <span class="keywordtype">double</span> val) {</div><div class="line"><a name="l00695"></a><span class="lineno"> 695</span>&#160; <span class="keywordflow">return</span> isnan(val);</div><div class="line"><a name="l00696"></a><span class="lineno"> 696</span>&#160; }</div><div class="line"><a name="l00697"></a><span class="lineno"> 697</span>&#160; <span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00698"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1isnan__typed.html#abae8abe8600d9f57faddd8e59ad9ed50"> 698</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">bool</span> <a class="code" href="namespacemshadow_1_1isnan__typed.html#abae8abe8600d9f57faddd8e59ad9ed50">IsNan</a>(<span class="keyword">volatile</span> mshadow::half::half_t val) {</div><div class="line"><a name="l00699"></a><span class="lineno"> 699</span>&#160; <span class="keywordflow">return</span> (val.half_ &amp; (~<a class="code" href="half_8h.html#a4068a67a48bb294a6bf436e28be90de9">MSHADOW_HALF_SIGN_BIT</a>)) &gt; <a class="code" href="half_8h.html#afdc51a9766b6923a3742828222103e3d">MSHADOW_HALF_EXPONENT_BITS</a>;</div><div class="line"><a name="l00700"></a><span class="lineno"> 700</span>&#160; }</div><div class="line"><a name="l00701"></a><span class="lineno"> 701</span>&#160;} <span class="comment">// namespace isnan_typed</span></div><div class="line"><a name="l00702"></a><span class="lineno"> 702</span>&#160;</div><div class="line"><a name="l00706"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1isinf__typed.html"> 706</a></span>&#160;<span class="keyword">namespace </span>isinf_typed {</div><div class="line"><a name="l00707"></a><span class="lineno"> 707</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00708"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1isinf__typed.html#a5208c13b479de37653fc08402f08e56d"> 708</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">bool</span> <a class="code" href="namespacemshadow_1_1isinf__typed.html#a9300383296ccfacbfec50a6b8d33d557">IsInf</a>(<span class="keyword">volatile</span> DType val) {</div><div class="line"><a name="l00709"></a><span class="lineno"> 709</span>&#160; <span class="keywordflow">return</span> <span class="keyword">false</span>;</div><div class="line"><a name="l00710"></a><span class="lineno"> 710</span>&#160; }</div><div class="line"><a name="l00711"></a><span class="lineno"> 711</span>&#160; <span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00712"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1isinf__typed.html#afb2055fccae27375062b8561a052eca1"> 712</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">bool</span> <a class="code" href="namespacemshadow_1_1isinf__typed.html#a9300383296ccfacbfec50a6b8d33d557">IsInf</a>(<span class="keyword">volatile</span> <span class="keywordtype">float</span> val) {</div><div class="line"><a name="l00713"></a><span class="lineno"> 713</span>&#160; <span class="keywordflow">return</span> isinf(val);</div><div class="line"><a name="l00714"></a><span class="lineno"> 714</span>&#160; }</div><div class="line"><a name="l00715"></a><span class="lineno"> 715</span>&#160; <span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00716"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1isinf__typed.html#a5f845acb36e946a8b8451ee674a582b8"> 716</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">bool</span> <a class="code" href="namespacemshadow_1_1isinf__typed.html#a9300383296ccfacbfec50a6b8d33d557">IsInf</a>(<span class="keyword">volatile</span> <span class="keywordtype">double</span> val) {</div><div class="line"><a name="l00717"></a><span class="lineno"> 717</span>&#160; <span class="keywordflow">return</span> isinf(val);</div><div class="line"><a name="l00718"></a><span class="lineno"> 718</span>&#160; }</div><div class="line"><a name="l00719"></a><span class="lineno"> 719</span>&#160; <span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00720"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1isinf__typed.html#a05067eb40dc864fa670aad5a8f843568"> 720</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">bool</span> <a class="code" href="namespacemshadow_1_1isinf__typed.html#a9300383296ccfacbfec50a6b8d33d557">IsInf</a>(<span class="keyword">volatile</span> <span class="keywordtype">long</span> <span class="keywordtype">double</span> val) {</div><div class="line"><a name="l00721"></a><span class="lineno"> 721</span>&#160; <span class="keywordflow">return</span> isinf(val);</div><div class="line"><a name="l00722"></a><span class="lineno"> 722</span>&#160; }</div><div class="line"><a name="l00723"></a><span class="lineno"> 723</span>&#160; <span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00724"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1isinf__typed.html#a9300383296ccfacbfec50a6b8d33d557"> 724</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">bool</span> <a class="code" href="namespacemshadow_1_1isinf__typed.html#a9300383296ccfacbfec50a6b8d33d557">IsInf</a>(<span class="keyword">volatile</span> mshadow::half::half_t val) {</div><div class="line"><a name="l00725"></a><span class="lineno"> 725</span>&#160; <span class="keywordflow">return</span> (val.half_ &amp; (~<a class="code" href="half_8h.html#a4068a67a48bb294a6bf436e28be90de9">MSHADOW_HALF_SIGN_BIT</a>)) == <a class="code" href="half_8h.html#afdc51a9766b6923a3742828222103e3d">MSHADOW_HALF_EXPONENT_BITS</a>;</div><div class="line"><a name="l00726"></a><span class="lineno"> 726</span>&#160; }</div><div class="line"><a name="l00727"></a><span class="lineno"> 727</span>&#160;} <span class="comment">// namespace isinf_typed</span></div><div class="line"><a name="l00728"></a><span class="lineno"> 728</span>&#160;</div><div class="line"><a name="l00730"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red.html"> 730</a></span>&#160;<span class="keyword">namespace </span>red {</div><div class="line"><a name="l00731"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html"> 731</a></span>&#160;<span class="keyword">namespace </span>limits {</div><div class="line"><a name="l00736"></a><span class="lineno"> 736</span>&#160;<span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00737"></a><span class="lineno"> 737</span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> DType <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a5244fd39689a5526efa712f85579b148">MinValue</a>(<span class="keywordtype">void</span>);</div><div class="line"><a name="l00739"></a><span class="lineno"> 739</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00740"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a232631c75acb76794420d172a5cc335e"> 740</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">float</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a232631c75acb76794420d172a5cc335e">MinValue&lt;float&gt;</a>(void) {</div><div class="line"><a name="l00741"></a><span class="lineno"> 741</span>&#160; <span class="keywordflow">return</span> -FLT_MAX;</div><div class="line"><a name="l00742"></a><span class="lineno"> 742</span>&#160;}</div><div class="line"><a name="l00744"></a><span class="lineno"> 744</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00745"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a34f7a97ddbac1b447e39603de7c6f965"> 745</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">double</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a34f7a97ddbac1b447e39603de7c6f965">MinValue&lt;double&gt;</a>(void) {</div><div class="line"><a name="l00746"></a><span class="lineno"> 746</span>&#160; <span class="keywordflow">return</span> -DBL_MAX;</div><div class="line"><a name="l00747"></a><span class="lineno"> 747</span>&#160;}</div><div class="line"><a name="l00749"></a><span class="lineno"> 749</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00750"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a8642a9f6501c79c3a7ff8d8d473e5ec2"> 750</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> half::half_t MinValue&lt;half::half_t&gt;(void) {</div><div class="line"><a name="l00751"></a><span class="lineno"> 751</span>&#160; <span class="keywordflow">return</span> <a class="code" href="half_8h.html#a6961c70512f3780000b1ee5691363da3">MSHADOW_HALF_MIN</a>;</div><div class="line"><a name="l00752"></a><span class="lineno"> 752</span>&#160;}</div><div class="line"><a name="l00754"></a><span class="lineno"> 754</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00755"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a1b4ec57952b90b03665ad88d5fa0639f"> 755</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> bfloat::bf16_t MinValue&lt;bfloat::bf16_t&gt;(void) {</div><div class="line"><a name="l00756"></a><span class="lineno"> 756</span>&#160; <span class="keywordflow">return</span> <a class="code" href="bfloat_8h.html#ab31d5d1e2e21e0fc5dd6f40e276fdd43">MSHADOW_BF16_MIN</a>;</div><div class="line"><a name="l00757"></a><span class="lineno"> 757</span>&#160;}</div><div class="line"><a name="l00759"></a><span class="lineno"> 759</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00760"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a5ada516b5bd58791f170586cfdd9ae2f"> 760</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> uint8_t <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a5ada516b5bd58791f170586cfdd9ae2f">MinValue&lt;uint8_t&gt;</a>(void) {</div><div class="line"><a name="l00761"></a><span class="lineno"> 761</span>&#160; <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00762"></a><span class="lineno"> 762</span>&#160;}</div><div class="line"><a name="l00764"></a><span class="lineno"> 764</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00765"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a55d9bb33517b6c82d04555acba79680a"> 765</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> int8_t <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a55d9bb33517b6c82d04555acba79680a">MinValue&lt;int8_t&gt;</a>(void) {</div><div class="line"><a name="l00766"></a><span class="lineno"> 766</span>&#160; <span class="keywordflow">return</span> SCHAR_MIN;</div><div class="line"><a name="l00767"></a><span class="lineno"> 767</span>&#160;}</div><div class="line"><a name="l00769"></a><span class="lineno"> 769</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00770"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a1e417de4a028b2628d6bb5b6af1244dc"> 770</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">int</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a1e417de4a028b2628d6bb5b6af1244dc">MinValue&lt;int32_t&gt;</a>(void) {</div><div class="line"><a name="l00771"></a><span class="lineno"> 771</span>&#160; <span class="keywordflow">return</span> INT_MIN;</div><div class="line"><a name="l00772"></a><span class="lineno"> 772</span>&#160;}</div><div class="line"><a name="l00774"></a><span class="lineno"> 774</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00775"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a56182d9842b841740da7eefb60916cf9"> 775</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> int64_t <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a56182d9842b841740da7eefb60916cf9">MinValue&lt;int64_t&gt;</a>(void) {</div><div class="line"><a name="l00776"></a><span class="lineno"> 776</span>&#160; <span class="keywordflow">return</span> LLONG_MIN;</div><div class="line"><a name="l00777"></a><span class="lineno"> 777</span>&#160;}</div><div class="line"><a name="l00779"></a><span class="lineno"> 779</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00780"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a1adf2b0a158ad07a93b21f11e6aa3150"> 780</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">bool</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a1adf2b0a158ad07a93b21f11e6aa3150">MinValue&lt;bool&gt;</a>(void) {</div><div class="line"><a name="l00781"></a><span class="lineno"> 781</span>&#160; <span class="keywordflow">return</span> <span class="keyword">false</span>;</div><div class="line"><a name="l00782"></a><span class="lineno"> 782</span>&#160;}</div><div class="line"><a name="l00784"></a><span class="lineno"> 784</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00785"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#ab06124f184da5683a517e02bcf2d6b9d"> 785</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#ab06124f184da5683a517e02bcf2d6b9d">MinValue&lt;unsigned int&gt;</a>(void) {</div><div class="line"><a name="l00786"></a><span class="lineno"> 786</span>&#160; <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00787"></a><span class="lineno"> 787</span>&#160;}</div><div class="line"><a name="l00788"></a><span class="lineno"> 788</span>&#160;</div><div class="line"><a name="l00793"></a><span class="lineno"> 793</span>&#160;<span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00794"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a6b0a333f168fa9d54d2f13caabd595e0"> 794</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> DType <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a6b0a333f168fa9d54d2f13caabd595e0">NegInfValue</a>(<span class="keywordtype">void</span>) {</div><div class="line"><a name="l00795"></a><span class="lineno"> 795</span>&#160; <span class="keywordflow">return</span> MinValue&lt;DType&gt;();</div><div class="line"><a name="l00796"></a><span class="lineno"> 796</span>&#160;}</div><div class="line"><a name="l00798"></a><span class="lineno"> 798</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00799"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#af43c87655a8a1531462fa86bc7cc902e"> 799</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">float</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#af43c87655a8a1531462fa86bc7cc902e">NegInfValue&lt;float&gt;</a>(void) {</div><div class="line"><a name="l00800"></a><span class="lineno"> 800</span>&#160; <span class="keywordflow">return</span> -HUGE_VALF;</div><div class="line"><a name="l00801"></a><span class="lineno"> 801</span>&#160;}</div><div class="line"><a name="l00803"></a><span class="lineno"> 803</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00804"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a3784eade98f040fe074543259fe7164e"> 804</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">double</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a3784eade98f040fe074543259fe7164e">NegInfValue&lt;double&gt;</a>(void) {</div><div class="line"><a name="l00805"></a><span class="lineno"> 805</span>&#160; <span class="keywordflow">return</span> -HUGE_VAL;</div><div class="line"><a name="l00806"></a><span class="lineno"> 806</span>&#160;}</div><div class="line"><a name="l00808"></a><span class="lineno"> 808</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00809"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#ad1bc78ffe1a46fc55d3ab44c4f8648b4"> 809</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> half::half_t NegInfValue&lt;half::half_t&gt;(void) {</div><div class="line"><a name="l00810"></a><span class="lineno"> 810</span>&#160; <span class="keywordflow">return</span> half::half_t::Binary(</div><div class="line"><a name="l00811"></a><span class="lineno"> 811</span>&#160; <a class="code" href="half_8h.html#a4068a67a48bb294a6bf436e28be90de9">MSHADOW_HALF_SIGN_BIT</a> | <a class="code" href="half_8h.html#afdc51a9766b6923a3742828222103e3d">MSHADOW_HALF_EXPONENT_BITS</a>);</div><div class="line"><a name="l00812"></a><span class="lineno"> 812</span>&#160;}</div><div class="line"><a name="l00813"></a><span class="lineno"> 813</span>&#160;</div><div class="line"><a name="l00818"></a><span class="lineno"> 818</span>&#160;<span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00819"></a><span class="lineno"> 819</span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> DType <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a993a69000bf5e0a5d13ef149a3311a78">MaxValue</a>(<span class="keywordtype">void</span>);</div><div class="line"><a name="l00821"></a><span class="lineno"> 821</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00822"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a6262f9d4a98d7ddc205cb0b19af4a316"> 822</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">float</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a6262f9d4a98d7ddc205cb0b19af4a316">MaxValue&lt;float&gt;</a>(void) {</div><div class="line"><a name="l00823"></a><span class="lineno"> 823</span>&#160; <span class="keywordflow">return</span> FLT_MAX;</div><div class="line"><a name="l00824"></a><span class="lineno"> 824</span>&#160;}</div><div class="line"><a name="l00826"></a><span class="lineno"> 826</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00827"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a4fdc4629369e455063f9d084570f276a"> 827</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">double</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a4fdc4629369e455063f9d084570f276a">MaxValue&lt;double&gt;</a>(void) {</div><div class="line"><a name="l00828"></a><span class="lineno"> 828</span>&#160; <span class="keywordflow">return</span> DBL_MAX;</div><div class="line"><a name="l00829"></a><span class="lineno"> 829</span>&#160;}</div><div class="line"><a name="l00831"></a><span class="lineno"> 831</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00832"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a045099a4f837139379f6d164bf663770"> 832</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> half::half_t MaxValue&lt;half::half_t&gt;(void) {</div><div class="line"><a name="l00833"></a><span class="lineno"> 833</span>&#160; <span class="keywordflow">return</span> <a class="code" href="half_8h.html#acd26d7558448d4ce6889283913627b31">MSHADOW_HALF_MAX</a>;</div><div class="line"><a name="l00834"></a><span class="lineno"> 834</span>&#160;}</div><div class="line"><a name="l00836"></a><span class="lineno"> 836</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00837"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#ae8f74d17008d30efc4a2de04d0294502"> 837</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> bfloat::bf16_t MaxValue&lt;bfloat::bf16_t&gt;(void) {</div><div class="line"><a name="l00838"></a><span class="lineno"> 838</span>&#160; <span class="keywordflow">return</span> <a class="code" href="bfloat_8h.html#a3d5d63ecb7104078d465a0074f9d9059">MSHADOW_BF16_MAX</a>;</div><div class="line"><a name="l00839"></a><span class="lineno"> 839</span>&#160;}</div><div class="line"><a name="l00841"></a><span class="lineno"> 841</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00842"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a853288dcb013f16211eb9ce107ccba3e"> 842</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> uint8_t <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a853288dcb013f16211eb9ce107ccba3e">MaxValue&lt;uint8_t&gt;</a>(void) {</div><div class="line"><a name="l00843"></a><span class="lineno"> 843</span>&#160; <span class="keywordflow">return</span> UCHAR_MAX;</div><div class="line"><a name="l00844"></a><span class="lineno"> 844</span>&#160;}</div><div class="line"><a name="l00846"></a><span class="lineno"> 846</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00847"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#affcf917b2d5206e3ddeec7e5f0ee995e"> 847</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> int8_t <a class="code" href="namespacemshadow_1_1red_1_1limits.html#affcf917b2d5206e3ddeec7e5f0ee995e">MaxValue&lt;int8_t&gt;</a>(void) {</div><div class="line"><a name="l00848"></a><span class="lineno"> 848</span>&#160; <span class="keywordflow">return</span> SCHAR_MAX;</div><div class="line"><a name="l00849"></a><span class="lineno"> 849</span>&#160;}</div><div class="line"><a name="l00851"></a><span class="lineno"> 851</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00852"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#ad5c922e935e2efb47bb238c56ff8a38b"> 852</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">int</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#ad5c922e935e2efb47bb238c56ff8a38b">MaxValue&lt;int32_t&gt;</a>(void) {</div><div class="line"><a name="l00853"></a><span class="lineno"> 853</span>&#160; <span class="keywordflow">return</span> INT_MAX;</div><div class="line"><a name="l00854"></a><span class="lineno"> 854</span>&#160;}</div><div class="line"><a name="l00856"></a><span class="lineno"> 856</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00857"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#ab4d32d18fb83ed9fe3b2773e0bf8d508"> 857</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> int64_t <a class="code" href="namespacemshadow_1_1red_1_1limits.html#ab4d32d18fb83ed9fe3b2773e0bf8d508">MaxValue&lt;int64_t&gt;</a>(void) {</div><div class="line"><a name="l00858"></a><span class="lineno"> 858</span>&#160; <span class="keywordflow">return</span> LLONG_MAX;</div><div class="line"><a name="l00859"></a><span class="lineno"> 859</span>&#160;}</div><div class="line"><a name="l00861"></a><span class="lineno"> 861</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00862"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#acc5e8630b2b3d865291c02b16c7b09c1"> 862</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">bool</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#acc5e8630b2b3d865291c02b16c7b09c1">MaxValue&lt;bool&gt;</a>(void) {</div><div class="line"><a name="l00863"></a><span class="lineno"> 863</span>&#160; <span class="keywordflow">return</span> <span class="keyword">true</span>;</div><div class="line"><a name="l00864"></a><span class="lineno"> 864</span>&#160;}</div><div class="line"><a name="l00866"></a><span class="lineno"> 866</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00867"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a78426e39f8f6170f709965da5aa2d118"> 867</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> uint32_t <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a78426e39f8f6170f709965da5aa2d118">MaxValue&lt;uint32_t&gt;</a>(void) {</div><div class="line"><a name="l00868"></a><span class="lineno"> 868</span>&#160; <span class="keywordflow">return</span> -1;</div><div class="line"><a name="l00869"></a><span class="lineno"> 869</span>&#160;}</div><div class="line"><a name="l00870"></a><span class="lineno"> 870</span>&#160;</div><div class="line"><a name="l00875"></a><span class="lineno"> 875</span>&#160;<span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00876"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a64ef2d1a92579d312b18fb04aaed0d4e"> 876</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> DType <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a64ef2d1a92579d312b18fb04aaed0d4e">PosInfValue</a>(<span class="keywordtype">void</span>) {</div><div class="line"><a name="l00877"></a><span class="lineno"> 877</span>&#160; <span class="keywordflow">return</span> MaxValue&lt;DType&gt;();</div><div class="line"><a name="l00878"></a><span class="lineno"> 878</span>&#160;}</div><div class="line"><a name="l00880"></a><span class="lineno"> 880</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00881"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a77b7882d6cafca4b12908e2fff2302ed"> 881</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">float</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a77b7882d6cafca4b12908e2fff2302ed">PosInfValue&lt;float&gt;</a>(void) {</div><div class="line"><a name="l00882"></a><span class="lineno"> 882</span>&#160; <span class="keywordflow">return</span> HUGE_VALF;</div><div class="line"><a name="l00883"></a><span class="lineno"> 883</span>&#160;}</div><div class="line"><a name="l00885"></a><span class="lineno"> 885</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00886"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a194ad52f15262c4acde6f4720f039858"> 886</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keywordtype">double</span> <a class="code" href="namespacemshadow_1_1red_1_1limits.html#a194ad52f15262c4acde6f4720f039858">PosInfValue&lt;double&gt;</a>(void) {</div><div class="line"><a name="l00887"></a><span class="lineno"> 887</span>&#160; <span class="keywordflow">return</span> HUGE_VAL;</div><div class="line"><a name="l00888"></a><span class="lineno"> 888</span>&#160;}</div><div class="line"><a name="l00890"></a><span class="lineno"> 890</span>&#160;<span class="keyword">template</span>&lt;&gt;</div><div class="line"><a name="l00891"></a><span class="lineno"><a class="line" href="namespacemshadow_1_1red_1_1limits.html#a3ff7cabb9493716594e29aff48bcc60b"> 891</a></span>&#160;<a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> half::half_t PosInfValue&lt;half::half_t&gt;(void) {</div><div class="line"><a name="l00892"></a><span class="lineno"> 892</span>&#160; <span class="keywordflow">return</span> half::half_t::Binary(<a class="code" href="half_8h.html#afdc51a9766b6923a3742828222103e3d">MSHADOW_HALF_EXPONENT_BITS</a>);</div><div class="line"><a name="l00893"></a><span class="lineno"> 893</span>&#160;}</div><div class="line"><a name="l00894"></a><span class="lineno"> 894</span>&#160;</div><div class="line"><a name="l00895"></a><span class="lineno"> 895</span>&#160;} <span class="comment">// namespace limits</span></div><div class="line"><a name="l00896"></a><span class="lineno"> 896</span>&#160;</div><div class="line"><a name="l00898"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1sum.html"> 898</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1red_1_1sum.html">sum</a> {</div><div class="line"><a name="l00900"></a><span class="lineno"> 900</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00901"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1sum.html#abd56e307635333d02fc0f22726dbed28"> 901</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1sum.html#abd56e307635333d02fc0f22726dbed28">Reduce</a>(<span class="keyword">volatile</span> DType&amp; dst, <span class="keyword">volatile</span> DType src) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00902"></a><span class="lineno"> 902</span>&#160; dst += src;</div><div class="line"><a name="l00903"></a><span class="lineno"> 903</span>&#160; }</div><div class="line"><a name="l00905"></a><span class="lineno"> 905</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00906"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1sum.html#a36583c3bb79bbfe107b7c9480e80d5e7"> 906</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1sum.html#a36583c3bb79bbfe107b7c9480e80d5e7">Reduce</a>(<span class="keyword">volatile</span> DType&amp; dst, <span class="keyword">volatile</span> DType src, <span class="keyword">volatile</span> DType&amp; residual) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00907"></a><span class="lineno"> 907</span>&#160; DType y = src - residual;</div><div class="line"><a name="l00908"></a><span class="lineno"> 908</span>&#160; DType t = dst + y;</div><div class="line"><a name="l00909"></a><span class="lineno"> 909</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacemshadow_1_1isinf__typed.html#a5208c13b479de37653fc08402f08e56d">isinf_typed::IsInf</a>(t)) {</div><div class="line"><a name="l00910"></a><span class="lineno"> 910</span>&#160; residual = 0;</div><div class="line"><a name="l00911"></a><span class="lineno"> 911</span>&#160; } <span class="keywordflow">else</span> {</div><div class="line"><a name="l00912"></a><span class="lineno"> 912</span>&#160; residual = (t - dst) - y;</div><div class="line"><a name="l00913"></a><span class="lineno"> 913</span>&#160; }</div><div class="line"><a name="l00914"></a><span class="lineno"> 914</span>&#160; dst = t;</div><div class="line"><a name="l00915"></a><span class="lineno"> 915</span>&#160; }</div><div class="line"><a name="l00917"></a><span class="lineno"> 917</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00918"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1sum.html#aa05b8713dd5973cac465420e52f67dda"> 918</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1sum.html#aa05b8713dd5973cac465420e52f67dda">Merge</a>(<span class="keyword">volatile</span> DType&amp; dst_val, <span class="keyword">volatile</span> DType&amp; src_val) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00919"></a><span class="lineno"> 919</span>&#160; Reduce(dst_val, src_val);</div><div class="line"><a name="l00920"></a><span class="lineno"> 920</span>&#160; }</div><div class="line"><a name="l00922"></a><span class="lineno"> 922</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00923"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1sum.html#abdbdd852a7eb8460458f24fea8ca7714"> 923</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1sum.html#abdbdd852a7eb8460458f24fea8ca7714">Merge</a>(<span class="keyword">volatile</span> DType&amp; dst_val, <span class="keyword">volatile</span> DType&amp; dst_residual, <span class="keyword">volatile</span> DType&amp; src_val, <span class="keyword">volatile</span> DType&amp; src_residual) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00924"></a><span class="lineno"> 924</span>&#160; DType t1 = dst_val + src_val;</div><div class="line"><a name="l00925"></a><span class="lineno"> 925</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacemshadow_1_1isinf__typed.html#a5208c13b479de37653fc08402f08e56d">isinf_typed::IsInf</a>(t1)) {</div><div class="line"><a name="l00926"></a><span class="lineno"> 926</span>&#160; dst_val = t1;</div><div class="line"><a name="l00927"></a><span class="lineno"> 927</span>&#160; dst_residual = 0;</div><div class="line"><a name="l00928"></a><span class="lineno"> 928</span>&#160; } <span class="keywordflow">else</span> {</div><div class="line"><a name="l00929"></a><span class="lineno"> 929</span>&#160; DType e = t1 - dst_val;</div><div class="line"><a name="l00930"></a><span class="lineno"> 930</span>&#160; DType t2 = ((src_val - e) + (dst_val - (t1 - e))) + dst_residual + src_residual;</div><div class="line"><a name="l00931"></a><span class="lineno"> 931</span>&#160; dst_val = t1 + t2;</div><div class="line"><a name="l00932"></a><span class="lineno"> 932</span>&#160; dst_residual = t2 - (dst_val - t1);</div><div class="line"><a name="l00933"></a><span class="lineno"> 933</span>&#160; }</div><div class="line"><a name="l00934"></a><span class="lineno"> 934</span>&#160; }</div><div class="line"><a name="l00936"></a><span class="lineno"> 936</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00937"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1sum.html#a511c1d4add93f26810e6a53c0ff106d0"> 937</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1sum.html#a511c1d4add93f26810e6a53c0ff106d0">Finalize</a>(<span class="keyword">volatile</span> DType&amp; dst) {} <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00939"></a><span class="lineno"> 939</span>&#160;<span class="comment"></span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00940"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1sum.html#af024e58661dffc3043fdab0ac6424659"> 940</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1sum.html#af024e58661dffc3043fdab0ac6424659">Finalize</a>(<span class="keyword">volatile</span> DType&amp; dst, <span class="keyword">volatile</span> DType&amp; residual) {} <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00945"></a><span class="lineno"> 945</span>&#160;<span class="comment"></span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00946"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1sum.html#a351d0e761cb9944c4d98919535754142"> 946</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> DType <a class="code" href="structmshadow_1_1red_1_1sum.html#a351d0e761cb9944c4d98919535754142">PartialGrad</a>(DType redres, DType redsrc) {</div><div class="line"><a name="l00947"></a><span class="lineno"> 947</span>&#160; <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l00948"></a><span class="lineno"> 948</span>&#160; }</div><div class="line"><a name="l00952"></a><span class="lineno"> 952</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00953"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1sum.html#aedc5b032275b8d11fc95fae2545cc2cb"> 953</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1sum.html#aedc5b032275b8d11fc95fae2545cc2cb">SetInitValue</a>(DType &amp;initv) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00954"></a><span class="lineno"> 954</span>&#160; initv = 0;</div><div class="line"><a name="l00955"></a><span class="lineno"> 955</span>&#160; }</div><div class="line"><a name="l00959"></a><span class="lineno"> 959</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00960"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1sum.html#a351e35f2cbf0f8e7e08c5f23b70f3c3f"> 960</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1sum.html#a351e35f2cbf0f8e7e08c5f23b70f3c3f">SetInitValue</a>(DType &amp;initv, DType &amp;residual) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00961"></a><span class="lineno"> 961</span>&#160; SetInitValue(initv);</div><div class="line"><a name="l00962"></a><span class="lineno"> 962</span>&#160; residual = 0;</div><div class="line"><a name="l00963"></a><span class="lineno"> 963</span>&#160; }</div><div class="line"><a name="l00964"></a><span class="lineno"> 964</span>&#160;};</div><div class="line"><a name="l00966"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1maximum.html"> 966</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1red_1_1maximum.html">maximum</a> {</div><div class="line"><a name="l00968"></a><span class="lineno"> 968</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00969"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1maximum.html#a99b1074ecd03f849cbdcfbad8df8ed2b"> 969</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1maximum.html#a99b1074ecd03f849cbdcfbad8df8ed2b">Reduce</a>(<span class="keyword">volatile</span> DType&amp; dst, <span class="keyword">volatile</span> DType src) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00970"></a><span class="lineno"> 970</span>&#160; <span class="keywordflow">if</span> (!<a class="code" href="namespacemshadow_1_1isnan__typed.html#a31da61266fae8c9ca52df015d132b759">isnan_typed::IsNan</a>(dst)) {</div><div class="line"><a name="l00971"></a><span class="lineno"> 971</span>&#160; <span class="keywordflow">if</span> (!(dst &gt;= src)) dst = src;</div><div class="line"><a name="l00972"></a><span class="lineno"> 972</span>&#160; }</div><div class="line"><a name="l00973"></a><span class="lineno"> 973</span>&#160; }</div><div class="line"><a name="l00975"></a><span class="lineno"> 975</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00976"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1maximum.html#a96aaae5db92ec7a3a8a5740265394a35"> 976</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1maximum.html#a96aaae5db92ec7a3a8a5740265394a35">Reduce</a>(<span class="keyword">volatile</span> DType&amp; dst, <span class="keyword">volatile</span> DType src, <span class="keyword">volatile</span> DType &amp;none) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00977"></a><span class="lineno"> 977</span>&#160; Reduce(dst, src);</div><div class="line"><a name="l00978"></a><span class="lineno"> 978</span>&#160; }</div><div class="line"><a name="l00980"></a><span class="lineno"> 980</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00981"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1maximum.html#a5c74a9cf04436607f101428cb8fd4326"> 981</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1maximum.html#a5c74a9cf04436607f101428cb8fd4326">Merge</a>(<span class="keyword">volatile</span> DType&amp; dst_val, <span class="keyword">volatile</span> DType&amp; src_val) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00982"></a><span class="lineno"> 982</span>&#160; Reduce(dst_val, src_val);</div><div class="line"><a name="l00983"></a><span class="lineno"> 983</span>&#160; }</div><div class="line"><a name="l00985"></a><span class="lineno"> 985</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00986"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1maximum.html#a88b427b9289c2c00736887449ed67d0a"> 986</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1maximum.html#a88b427b9289c2c00736887449ed67d0a">Merge</a>(<span class="keyword">volatile</span> DType&amp; dst_val, <span class="keyword">volatile</span> DType&amp; dst_residual, <span class="keyword">volatile</span> DType&amp; src_val, <span class="keyword">volatile</span> DType&amp; src_residual) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00987"></a><span class="lineno"> 987</span>&#160; Reduce(dst_val, src_val);</div><div class="line"><a name="l00988"></a><span class="lineno"> 988</span>&#160; }</div><div class="line"><a name="l00990"></a><span class="lineno"> 990</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00991"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1maximum.html#a97c5d96eac2849f458678742738f1ce0"> 991</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1maximum.html#a97c5d96eac2849f458678742738f1ce0">Finalize</a>(<span class="keyword">volatile</span> DType&amp; dst) {} <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00993"></a><span class="lineno"> 993</span>&#160;<span class="comment"></span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l00994"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1maximum.html#a99c8021ef1da714c052bfdf1f4e41280"> 994</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1maximum.html#a99c8021ef1da714c052bfdf1f4e41280">Finalize</a>(<span class="keyword">volatile</span> DType&amp; dst, <span class="keyword">volatile</span> DType&amp; residual) {} <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l00999"></a><span class="lineno"> 999</span>&#160;<span class="comment"></span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l01000"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1maximum.html#ac2d455ca3b4eb12554eb31ed6a1387b7"> 1000</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> DType <a class="code" href="structmshadow_1_1red_1_1maximum.html#ac2d455ca3b4eb12554eb31ed6a1387b7">PartialGrad</a>(DType redres, DType redsrc) {</div><div class="line"><a name="l01001"></a><span class="lineno"> 1001</span>&#160; <span class="keywordflow">return</span> redres == redsrc ? 1: 0;</div><div class="line"><a name="l01002"></a><span class="lineno"> 1002</span>&#160; }</div><div class="line"><a name="l01006"></a><span class="lineno"> 1006</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l01007"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1maximum.html#a1bffb78fd1c64479b82e9a4ffccab69e"> 1007</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1maximum.html#a1bffb78fd1c64479b82e9a4ffccab69e">SetInitValue</a>(DType &amp;initv) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l01008"></a><span class="lineno"> 1008</span>&#160; initv = limits::NegInfValue&lt;DType&gt;();</div><div class="line"><a name="l01009"></a><span class="lineno"> 1009</span>&#160; }</div><div class="line"><a name="l01013"></a><span class="lineno"> 1013</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l01014"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1maximum.html#a6f5613dfb9c095420b5fe322aa2ab1ed"> 1014</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1maximum.html#a6f5613dfb9c095420b5fe322aa2ab1ed">SetInitValue</a>(DType &amp;initv, DType &amp;none) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l01015"></a><span class="lineno"> 1015</span>&#160; SetInitValue(initv);</div><div class="line"><a name="l01016"></a><span class="lineno"> 1016</span>&#160; }</div><div class="line"><a name="l01017"></a><span class="lineno"> 1017</span>&#160;};</div><div class="line"><a name="l01019"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1minimum.html"> 1019</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structmshadow_1_1red_1_1minimum.html">minimum</a> {</div><div class="line"><a name="l01021"></a><span class="lineno"> 1021</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l01022"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1minimum.html#aa000adb90fad1fb429a05b1c6c8b836b"> 1022</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1minimum.html#aa000adb90fad1fb429a05b1c6c8b836b">Reduce</a>(<span class="keyword">volatile</span> DType&amp; dst, <span class="keyword">volatile</span> DType src) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l01023"></a><span class="lineno"> 1023</span>&#160; <span class="keywordflow">if</span> (!<a class="code" href="namespacemshadow_1_1isnan__typed.html#a31da61266fae8c9ca52df015d132b759">isnan_typed::IsNan</a>(dst)) {</div><div class="line"><a name="l01024"></a><span class="lineno"> 1024</span>&#160; <span class="keywordflow">if</span> (!(dst &lt;= src)) dst = src;</div><div class="line"><a name="l01025"></a><span class="lineno"> 1025</span>&#160; }</div><div class="line"><a name="l01026"></a><span class="lineno"> 1026</span>&#160; }</div><div class="line"><a name="l01028"></a><span class="lineno"> 1028</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l01029"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1minimum.html#a01e4946a88167d905c14b39d3965e03c"> 1029</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1minimum.html#a01e4946a88167d905c14b39d3965e03c">Reduce</a>(<span class="keyword">volatile</span> DType&amp; dst, <span class="keyword">volatile</span> DType src, <span class="keyword">volatile</span> DType &amp;none) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l01030"></a><span class="lineno"> 1030</span>&#160; Reduce(dst, src);</div><div class="line"><a name="l01031"></a><span class="lineno"> 1031</span>&#160; }</div><div class="line"><a name="l01033"></a><span class="lineno"> 1033</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l01034"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1minimum.html#a9485035d020c53f31eadf7e34adc37f0"> 1034</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1minimum.html#a9485035d020c53f31eadf7e34adc37f0">Merge</a>(<span class="keyword">volatile</span> DType&amp; dst_val, <span class="keyword">volatile</span> DType&amp; src_val) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l01035"></a><span class="lineno"> 1035</span>&#160; Reduce(dst_val, src_val);</div><div class="line"><a name="l01036"></a><span class="lineno"> 1036</span>&#160; }</div><div class="line"><a name="l01038"></a><span class="lineno"> 1038</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l01039"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1minimum.html#af14bfabf30b3f4bffdcd0827679d0390"> 1039</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1minimum.html#af14bfabf30b3f4bffdcd0827679d0390">Merge</a>(<span class="keyword">volatile</span> DType&amp; dst_val, <span class="keyword">volatile</span> DType&amp; dst_residual, <span class="keyword">volatile</span> DType&amp; src_val, <span class="keyword">volatile</span> DType&amp; src_residual) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l01040"></a><span class="lineno"> 1040</span>&#160; Reduce(dst_val, src_val);</div><div class="line"><a name="l01041"></a><span class="lineno"> 1041</span>&#160; }</div><div class="line"><a name="l01043"></a><span class="lineno"> 1043</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l01044"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1minimum.html#aebd011f117a63fea3cd494ee2138b634"> 1044</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1minimum.html#aebd011f117a63fea3cd494ee2138b634">Finalize</a>(<span class="keyword">volatile</span> DType&amp; dst) {} <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l01046"></a><span class="lineno"> 1046</span>&#160;<span class="comment"></span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l01047"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1minimum.html#ae844649225377caf827a51ef0d080515"> 1047</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1minimum.html#ae844649225377caf827a51ef0d080515">Finalize</a>(<span class="keyword">volatile</span> DType&amp; dst, <span class="keyword">volatile</span> DType&amp; residual) {} <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l01052"></a><span class="lineno"> 1052</span>&#160;<span class="comment"></span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l01053"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1minimum.html#aa3f7b2a1f96f77caca258e8c594f67bd"> 1053</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> DType <a class="code" href="structmshadow_1_1red_1_1minimum.html#aa3f7b2a1f96f77caca258e8c594f67bd">PartialGrad</a>(DType redres, DType redsrc) {</div><div class="line"><a name="l01054"></a><span class="lineno"> 1054</span>&#160; <span class="keywordflow">return</span> redres == redsrc ? 1: 0;</div><div class="line"><a name="l01055"></a><span class="lineno"> 1055</span>&#160; }</div><div class="line"><a name="l01059"></a><span class="lineno"> 1059</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l01060"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1minimum.html#acbda7fe80fa3754a57b967e11a8ee44f"> 1060</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1minimum.html#acbda7fe80fa3754a57b967e11a8ee44f">SetInitValue</a>(DType &amp;initv) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l01061"></a><span class="lineno"> 1061</span>&#160; initv = limits::PosInfValue&lt;DType&gt;();</div><div class="line"><a name="l01062"></a><span class="lineno"> 1062</span>&#160; }</div><div class="line"><a name="l01066"></a><span class="lineno"> 1066</span>&#160; <span class="keyword">template</span>&lt;<span class="keyword">typename</span> DType&gt;</div><div class="line"><a name="l01067"></a><span class="lineno"><a class="line" href="structmshadow_1_1red_1_1minimum.html#aba3be24837548e8f5a48178889ec2132"> 1067</a></span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="structmshadow_1_1red_1_1minimum.html#aba3be24837548e8f5a48178889ec2132">SetInitValue</a>(DType &amp;initv, DType &amp;none) { <span class="comment">// NOLINT(*)</span></div><div class="line"><a name="l01068"></a><span class="lineno"> 1068</span>&#160; SetInitValue(initv);</div><div class="line"><a name="l01069"></a><span class="lineno"> 1069</span>&#160; }</div><div class="line"><a name="l01070"></a><span class="lineno"> 1070</span>&#160;};</div><div class="line"><a name="l01071"></a><span class="lineno"> 1071</span>&#160;} <span class="comment">// namespace red</span></div><div class="line"><a name="l01072"></a><span class="lineno"> 1072</span>&#160;</div><div class="line"><a name="l01073"></a><span class="lineno"> 1073</span>&#160;<span class="preprocessor">#ifndef __NVCC__</span></div><div class="line"><a name="l01074"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#af67c41c06afea92ccf285ae8501e2316"> 1074</a></span>&#160;<span class="preprocessor">#define MSHADOW_TYPE_SWITCH(type, DType, ...) \</span></div><div class="line"><a name="l01075"></a><span class="lineno"> 1075</span>&#160;<span class="preprocessor"> switch (type) { \</span></div><div class="line"><a name="l01076"></a><span class="lineno"> 1076</span>&#160;<span class="preprocessor"> case mshadow::kFloat32: \</span></div><div class="line"><a name="l01077"></a><span class="lineno"> 1077</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01078"></a><span class="lineno"> 1078</span>&#160;<span class="preprocessor"> typedef float DType; \</span></div><div class="line"><a name="l01079"></a><span class="lineno"> 1079</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01080"></a><span class="lineno"> 1080</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01081"></a><span class="lineno"> 1081</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01082"></a><span class="lineno"> 1082</span>&#160;<span class="preprocessor"> case mshadow::kFloat64: \</span></div><div class="line"><a name="l01083"></a><span class="lineno"> 1083</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01084"></a><span class="lineno"> 1084</span>&#160;<span class="preprocessor"> typedef double DType; \</span></div><div class="line"><a name="l01085"></a><span class="lineno"> 1085</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01086"></a><span class="lineno"> 1086</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01087"></a><span class="lineno"> 1087</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01088"></a><span class="lineno"> 1088</span>&#160;<span class="preprocessor"> case mshadow::kFloat16: \</span></div><div class="line"><a name="l01089"></a><span class="lineno"> 1089</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01090"></a><span class="lineno"> 1090</span>&#160;<span class="preprocessor"> typedef mshadow::half::half_t DType; \</span></div><div class="line"><a name="l01091"></a><span class="lineno"> 1091</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01092"></a><span class="lineno"> 1092</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01093"></a><span class="lineno"> 1093</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01094"></a><span class="lineno"> 1094</span>&#160;<span class="preprocessor"> case mshadow::kBfloat16: \</span></div><div class="line"><a name="l01095"></a><span class="lineno"> 1095</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01096"></a><span class="lineno"> 1096</span>&#160;<span class="preprocessor"> typedef mshadow::bfloat::bf16_t DType; \</span></div><div class="line"><a name="l01097"></a><span class="lineno"> 1097</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01098"></a><span class="lineno"> 1098</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01099"></a><span class="lineno"> 1099</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01100"></a><span class="lineno"> 1100</span>&#160;<span class="preprocessor"> case mshadow::kUint8: \</span></div><div class="line"><a name="l01101"></a><span class="lineno"> 1101</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01102"></a><span class="lineno"> 1102</span>&#160;<span class="preprocessor"> typedef uint8_t DType; \</span></div><div class="line"><a name="l01103"></a><span class="lineno"> 1103</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01104"></a><span class="lineno"> 1104</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01105"></a><span class="lineno"> 1105</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01106"></a><span class="lineno"> 1106</span>&#160;<span class="preprocessor"> case mshadow::kInt8: \</span></div><div class="line"><a name="l01107"></a><span class="lineno"> 1107</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01108"></a><span class="lineno"> 1108</span>&#160;<span class="preprocessor"> typedef int8_t DType; \</span></div><div class="line"><a name="l01109"></a><span class="lineno"> 1109</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01110"></a><span class="lineno"> 1110</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01111"></a><span class="lineno"> 1111</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01112"></a><span class="lineno"> 1112</span>&#160;<span class="preprocessor"> case mshadow::kInt32: \</span></div><div class="line"><a name="l01113"></a><span class="lineno"> 1113</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01114"></a><span class="lineno"> 1114</span>&#160;<span class="preprocessor"> typedef int32_t DType; \</span></div><div class="line"><a name="l01115"></a><span class="lineno"> 1115</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01116"></a><span class="lineno"> 1116</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01117"></a><span class="lineno"> 1117</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01118"></a><span class="lineno"> 1118</span>&#160;<span class="preprocessor"> case mshadow::kInt64: \</span></div><div class="line"><a name="l01119"></a><span class="lineno"> 1119</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01120"></a><span class="lineno"> 1120</span>&#160;<span class="preprocessor"> typedef int64_t DType; \</span></div><div class="line"><a name="l01121"></a><span class="lineno"> 1121</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01122"></a><span class="lineno"> 1122</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01123"></a><span class="lineno"> 1123</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01124"></a><span class="lineno"> 1124</span>&#160;<span class="preprocessor"> default: \</span></div><div class="line"><a name="l01125"></a><span class="lineno"> 1125</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;Unknown type enum &quot; &lt;&lt; type; \</span></div><div class="line"><a name="l01126"></a><span class="lineno"> 1126</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l01127"></a><span class="lineno"> 1127</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l01128"></a><span class="lineno"> 1128</span>&#160;<span class="preprocessor">#define MSHADOW_TYPE_SWITCH(type, DType, ...) \</span></div><div class="line"><a name="l01129"></a><span class="lineno"> 1129</span>&#160;<span class="preprocessor"> switch (type) { \</span></div><div class="line"><a name="l01130"></a><span class="lineno"> 1130</span>&#160;<span class="preprocessor"> case mshadow::kFloat32: \</span></div><div class="line"><a name="l01131"></a><span class="lineno"> 1131</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01132"></a><span class="lineno"> 1132</span>&#160;<span class="preprocessor"> typedef float DType; \</span></div><div class="line"><a name="l01133"></a><span class="lineno"> 1133</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01134"></a><span class="lineno"> 1134</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01135"></a><span class="lineno"> 1135</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01136"></a><span class="lineno"> 1136</span>&#160;<span class="preprocessor"> case mshadow::kFloat64: \</span></div><div class="line"><a name="l01137"></a><span class="lineno"> 1137</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01138"></a><span class="lineno"> 1138</span>&#160;<span class="preprocessor"> typedef double DType; \</span></div><div class="line"><a name="l01139"></a><span class="lineno"> 1139</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01140"></a><span class="lineno"> 1140</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01141"></a><span class="lineno"> 1141</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01142"></a><span class="lineno"> 1142</span>&#160;<span class="preprocessor"> case mshadow::kFloat16: \</span></div><div class="line"><a name="l01143"></a><span class="lineno"> 1143</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01144"></a><span class="lineno"> 1144</span>&#160;<span class="preprocessor"> typedef mshadow::half::half_t DType; \</span></div><div class="line"><a name="l01145"></a><span class="lineno"> 1145</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01146"></a><span class="lineno"> 1146</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01147"></a><span class="lineno"> 1147</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01148"></a><span class="lineno"> 1148</span>&#160;<span class="preprocessor"> case mshadow::kUint8: \</span></div><div class="line"><a name="l01149"></a><span class="lineno"> 1149</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01150"></a><span class="lineno"> 1150</span>&#160;<span class="preprocessor"> typedef uint8_t DType; \</span></div><div class="line"><a name="l01151"></a><span class="lineno"> 1151</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01152"></a><span class="lineno"> 1152</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01153"></a><span class="lineno"> 1153</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01154"></a><span class="lineno"> 1154</span>&#160;<span class="preprocessor"> case mshadow::kInt8: \</span></div><div class="line"><a name="l01155"></a><span class="lineno"> 1155</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01156"></a><span class="lineno"> 1156</span>&#160;<span class="preprocessor"> typedef int8_t DType; \</span></div><div class="line"><a name="l01157"></a><span class="lineno"> 1157</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01158"></a><span class="lineno"> 1158</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01159"></a><span class="lineno"> 1159</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01160"></a><span class="lineno"> 1160</span>&#160;<span class="preprocessor"> case mshadow::kInt32: \</span></div><div class="line"><a name="l01161"></a><span class="lineno"> 1161</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01162"></a><span class="lineno"> 1162</span>&#160;<span class="preprocessor"> typedef int32_t DType; \</span></div><div class="line"><a name="l01163"></a><span class="lineno"> 1163</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01164"></a><span class="lineno"> 1164</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01165"></a><span class="lineno"> 1165</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01166"></a><span class="lineno"> 1166</span>&#160;<span class="preprocessor"> case mshadow::kInt64: \</span></div><div class="line"><a name="l01167"></a><span class="lineno"> 1167</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01168"></a><span class="lineno"> 1168</span>&#160;<span class="preprocessor"> typedef int64_t DType; \</span></div><div class="line"><a name="l01169"></a><span class="lineno"> 1169</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01170"></a><span class="lineno"> 1170</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01171"></a><span class="lineno"> 1171</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01172"></a><span class="lineno"> 1172</span>&#160;<span class="preprocessor"> default: \</span></div><div class="line"><a name="l01173"></a><span class="lineno"> 1173</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;Unknown type enum &quot; &lt;&lt; type; \</span></div><div class="line"><a name="l01174"></a><span class="lineno"> 1174</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l01175"></a><span class="lineno"> 1175</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l01176"></a><span class="lineno"> 1176</span>&#160;</div><div class="line"><a name="l01177"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#aa64d490fe5bbc0ec7b9fe44fb1edaf72"> 1177</a></span>&#160;<span class="preprocessor">#define MSHADOW_TYPE_SWITCH_WITH_HALF2(type, DType, ...) \</span></div><div class="line"><a name="l01178"></a><span class="lineno"> 1178</span>&#160;<span class="preprocessor"> switch (type) { \</span></div><div class="line"><a name="l01179"></a><span class="lineno"> 1179</span>&#160;<span class="preprocessor"> case mshadow::kFloat32: \</span></div><div class="line"><a name="l01180"></a><span class="lineno"> 1180</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01181"></a><span class="lineno"> 1181</span>&#160;<span class="preprocessor"> typedef float DType; \</span></div><div class="line"><a name="l01182"></a><span class="lineno"> 1182</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01183"></a><span class="lineno"> 1183</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01184"></a><span class="lineno"> 1184</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01185"></a><span class="lineno"> 1185</span>&#160;<span class="preprocessor"> case mshadow::kFloat64: \</span></div><div class="line"><a name="l01186"></a><span class="lineno"> 1186</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01187"></a><span class="lineno"> 1187</span>&#160;<span class="preprocessor"> typedef double DType; \</span></div><div class="line"><a name="l01188"></a><span class="lineno"> 1188</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01189"></a><span class="lineno"> 1189</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01190"></a><span class="lineno"> 1190</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01191"></a><span class="lineno"> 1191</span>&#160;<span class="preprocessor"> case mshadow::kFloat16: \</span></div><div class="line"><a name="l01192"></a><span class="lineno"> 1192</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01193"></a><span class="lineno"> 1193</span>&#160;<span class="preprocessor"> typedef mshadow::half::half2_t DType; \</span></div><div class="line"><a name="l01194"></a><span class="lineno"> 1194</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01195"></a><span class="lineno"> 1195</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01196"></a><span class="lineno"> 1196</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01197"></a><span class="lineno"> 1197</span>&#160;<span class="preprocessor"> case mshadow::kUint8: \</span></div><div class="line"><a name="l01198"></a><span class="lineno"> 1198</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01199"></a><span class="lineno"> 1199</span>&#160;<span class="preprocessor"> typedef uint8_t DType; \</span></div><div class="line"><a name="l01200"></a><span class="lineno"> 1200</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01201"></a><span class="lineno"> 1201</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01202"></a><span class="lineno"> 1202</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01203"></a><span class="lineno"> 1203</span>&#160;<span class="preprocessor"> case mshadow::kInt32: \</span></div><div class="line"><a name="l01204"></a><span class="lineno"> 1204</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01205"></a><span class="lineno"> 1205</span>&#160;<span class="preprocessor"> typedef int32_t DType; \</span></div><div class="line"><a name="l01206"></a><span class="lineno"> 1206</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01207"></a><span class="lineno"> 1207</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01208"></a><span class="lineno"> 1208</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01209"></a><span class="lineno"> 1209</span>&#160;<span class="preprocessor"> case mshadow::kInt64: \</span></div><div class="line"><a name="l01210"></a><span class="lineno"> 1210</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01211"></a><span class="lineno"> 1211</span>&#160;<span class="preprocessor"> typedef int64_t DType; \</span></div><div class="line"><a name="l01212"></a><span class="lineno"> 1212</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01213"></a><span class="lineno"> 1213</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01214"></a><span class="lineno"> 1214</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01215"></a><span class="lineno"> 1215</span>&#160;<span class="preprocessor"> default: \</span></div><div class="line"><a name="l01216"></a><span class="lineno"> 1216</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;Unknown type enum &quot; &lt;&lt; type; \</span></div><div class="line"><a name="l01217"></a><span class="lineno"> 1217</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l01218"></a><span class="lineno"> 1218</span>&#160;</div><div class="line"><a name="l01219"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a3654cd812cf6a0011b78ef28c52e2f88"> 1219</a></span>&#160;<span class="preprocessor">#define MSHADOW_SGL_DBL_TYPE_SWITCH(type, DType, ...) \</span></div><div class="line"><a name="l01220"></a><span class="lineno"> 1220</span>&#160;<span class="preprocessor"> switch (type) { \</span></div><div class="line"><a name="l01221"></a><span class="lineno"> 1221</span>&#160;<span class="preprocessor"> case mshadow::kFloat32: \</span></div><div class="line"><a name="l01222"></a><span class="lineno"> 1222</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01223"></a><span class="lineno"> 1223</span>&#160;<span class="preprocessor"> typedef float DType; \</span></div><div class="line"><a name="l01224"></a><span class="lineno"> 1224</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01225"></a><span class="lineno"> 1225</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01226"></a><span class="lineno"> 1226</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01227"></a><span class="lineno"> 1227</span>&#160;<span class="preprocessor"> case mshadow::kFloat64: \</span></div><div class="line"><a name="l01228"></a><span class="lineno"> 1228</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01229"></a><span class="lineno"> 1229</span>&#160;<span class="preprocessor"> typedef double DType; \</span></div><div class="line"><a name="l01230"></a><span class="lineno"> 1230</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01231"></a><span class="lineno"> 1231</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01232"></a><span class="lineno"> 1232</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01233"></a><span class="lineno"> 1233</span>&#160;<span class="preprocessor"> default: \</span></div><div class="line"><a name="l01234"></a><span class="lineno"> 1234</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only supports &quot; \</span></div><div class="line"><a name="l01235"></a><span class="lineno"> 1235</span>&#160;<span class="preprocessor"> &quot;32-bit and 64-bit floating point&quot;; \</span></div><div class="line"><a name="l01236"></a><span class="lineno"> 1236</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l01237"></a><span class="lineno"> 1237</span>&#160;</div><div class="line"><a name="l01238"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a07e61e376e92683d0266b7b2cfdaaf6b"> 1238</a></span>&#160;<span class="preprocessor">#define MSHADOW_REAL_TYPE_SWITCH(type, DType, ...) \</span></div><div class="line"><a name="l01239"></a><span class="lineno"> 1239</span>&#160;<span class="preprocessor"> switch (type) { \</span></div><div class="line"><a name="l01240"></a><span class="lineno"> 1240</span>&#160;<span class="preprocessor"> case mshadow::kFloat32: \</span></div><div class="line"><a name="l01241"></a><span class="lineno"> 1241</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01242"></a><span class="lineno"> 1242</span>&#160;<span class="preprocessor"> typedef float DType; \</span></div><div class="line"><a name="l01243"></a><span class="lineno"> 1243</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01244"></a><span class="lineno"> 1244</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01245"></a><span class="lineno"> 1245</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01246"></a><span class="lineno"> 1246</span>&#160;<span class="preprocessor"> case mshadow::kFloat64: \</span></div><div class="line"><a name="l01247"></a><span class="lineno"> 1247</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01248"></a><span class="lineno"> 1248</span>&#160;<span class="preprocessor"> typedef double DType; \</span></div><div class="line"><a name="l01249"></a><span class="lineno"> 1249</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01250"></a><span class="lineno"> 1250</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01251"></a><span class="lineno"> 1251</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01252"></a><span class="lineno"> 1252</span>&#160;<span class="preprocessor"> case mshadow::kFloat16: \</span></div><div class="line"><a name="l01253"></a><span class="lineno"> 1253</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01254"></a><span class="lineno"> 1254</span>&#160;<span class="preprocessor"> typedef mshadow::half::half_t DType; \</span></div><div class="line"><a name="l01255"></a><span class="lineno"> 1255</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01256"></a><span class="lineno"> 1256</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01257"></a><span class="lineno"> 1257</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01258"></a><span class="lineno"> 1258</span>&#160;<span class="preprocessor"> case mshadow::kUint8: \</span></div><div class="line"><a name="l01259"></a><span class="lineno"> 1259</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only support &quot; \</span></div><div class="line"><a name="l01260"></a><span class="lineno"> 1260</span>&#160;<span class="preprocessor"> &quot;floating point types not uint8&quot;; \</span></div><div class="line"><a name="l01261"></a><span class="lineno"> 1261</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01262"></a><span class="lineno"> 1262</span>&#160;<span class="preprocessor"> case mshadow::kInt8: \</span></div><div class="line"><a name="l01263"></a><span class="lineno"> 1263</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only support &quot; \</span></div><div class="line"><a name="l01264"></a><span class="lineno"> 1264</span>&#160;<span class="preprocessor"> &quot;floating point types not int8&quot;; \</span></div><div class="line"><a name="l01265"></a><span class="lineno"> 1265</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01266"></a><span class="lineno"> 1266</span>&#160;<span class="preprocessor"> case mshadow::kInt32: \</span></div><div class="line"><a name="l01267"></a><span class="lineno"> 1267</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only support &quot; \</span></div><div class="line"><a name="l01268"></a><span class="lineno"> 1268</span>&#160;<span class="preprocessor"> &quot;floating point types, not int32&quot;;\</span></div><div class="line"><a name="l01269"></a><span class="lineno"> 1269</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01270"></a><span class="lineno"> 1270</span>&#160;<span class="preprocessor"> case mshadow::kInt64: \</span></div><div class="line"><a name="l01271"></a><span class="lineno"> 1271</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only support &quot; \</span></div><div class="line"><a name="l01272"></a><span class="lineno"> 1272</span>&#160;<span class="preprocessor"> &quot;floating point types, not int64&quot;;\</span></div><div class="line"><a name="l01273"></a><span class="lineno"> 1273</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01274"></a><span class="lineno"> 1274</span>&#160;<span class="preprocessor"> default: \</span></div><div class="line"><a name="l01275"></a><span class="lineno"> 1275</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;Unknown type enum &quot; &lt;&lt; type; \</span></div><div class="line"><a name="l01276"></a><span class="lineno"> 1276</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l01277"></a><span class="lineno"> 1277</span>&#160;</div><div class="line"><a name="l01278"></a><span class="lineno"> 1278</span>&#160;<span class="preprocessor">#ifndef __NVCC__</span></div><div class="line"><a name="l01279"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a5675a926d37704ceb4b997cbc19dabc2"> 1279</a></span>&#160;<span class="preprocessor">#define MSHADOW_REAL_TYPE_SWITCH_EX(type$, DType$, DLargeType$, ...) \</span></div><div class="line"><a name="l01280"></a><span class="lineno"> 1280</span>&#160;<span class="preprocessor"> switch (type$) { \</span></div><div class="line"><a name="l01281"></a><span class="lineno"> 1281</span>&#160;<span class="preprocessor"> case mshadow::kFloat32: \</span></div><div class="line"><a name="l01282"></a><span class="lineno"> 1282</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01283"></a><span class="lineno"> 1283</span>&#160;<span class="preprocessor"> typedef float DType$; \</span></div><div class="line"><a name="l01284"></a><span class="lineno"> 1284</span>&#160;<span class="preprocessor"> typedef float DLargeType$; \</span></div><div class="line"><a name="l01285"></a><span class="lineno"> 1285</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01286"></a><span class="lineno"> 1286</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01287"></a><span class="lineno"> 1287</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01288"></a><span class="lineno"> 1288</span>&#160;<span class="preprocessor"> case mshadow::kFloat64: \</span></div><div class="line"><a name="l01289"></a><span class="lineno"> 1289</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01290"></a><span class="lineno"> 1290</span>&#160;<span class="preprocessor"> typedef double DType$; \</span></div><div class="line"><a name="l01291"></a><span class="lineno"> 1291</span>&#160;<span class="preprocessor"> typedef double DLargeType$; \</span></div><div class="line"><a name="l01292"></a><span class="lineno"> 1292</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01293"></a><span class="lineno"> 1293</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01294"></a><span class="lineno"> 1294</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01295"></a><span class="lineno"> 1295</span>&#160;<span class="preprocessor"> case mshadow::kFloat16: \</span></div><div class="line"><a name="l01296"></a><span class="lineno"> 1296</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01297"></a><span class="lineno"> 1297</span>&#160;<span class="preprocessor"> typedef mshadow::half::half_t DType$; \</span></div><div class="line"><a name="l01298"></a><span class="lineno"> 1298</span>&#160;<span class="preprocessor"> typedef float DLargeType$; \</span></div><div class="line"><a name="l01299"></a><span class="lineno"> 1299</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01300"></a><span class="lineno"> 1300</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01301"></a><span class="lineno"> 1301</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01302"></a><span class="lineno"> 1302</span>&#160;<span class="preprocessor"> case mshadow::kBfloat16: \</span></div><div class="line"><a name="l01303"></a><span class="lineno"> 1303</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01304"></a><span class="lineno"> 1304</span>&#160;<span class="preprocessor"> typedef mshadow::bfloat::bf16_t DType$; \</span></div><div class="line"><a name="l01305"></a><span class="lineno"> 1305</span>&#160;<span class="preprocessor"> typedef float DLargeType$; \</span></div><div class="line"><a name="l01306"></a><span class="lineno"> 1306</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01307"></a><span class="lineno"> 1307</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01308"></a><span class="lineno"> 1308</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01309"></a><span class="lineno"> 1309</span>&#160;<span class="preprocessor"> case mshadow::kUint8: \</span></div><div class="line"><a name="l01310"></a><span class="lineno"> 1310</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only support &quot; \</span></div><div class="line"><a name="l01311"></a><span class="lineno"> 1311</span>&#160;<span class="preprocessor"> &quot;floating point types not uint8&quot;; \</span></div><div class="line"><a name="l01312"></a><span class="lineno"> 1312</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01313"></a><span class="lineno"> 1313</span>&#160;<span class="preprocessor"> case mshadow::kInt8: \</span></div><div class="line"><a name="l01314"></a><span class="lineno"> 1314</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only support &quot; \</span></div><div class="line"><a name="l01315"></a><span class="lineno"> 1315</span>&#160;<span class="preprocessor"> &quot;floating point types not int8&quot;; \</span></div><div class="line"><a name="l01316"></a><span class="lineno"> 1316</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01317"></a><span class="lineno"> 1317</span>&#160;<span class="preprocessor"> case mshadow::kInt32: \</span></div><div class="line"><a name="l01318"></a><span class="lineno"> 1318</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only support &quot; \</span></div><div class="line"><a name="l01319"></a><span class="lineno"> 1319</span>&#160;<span class="preprocessor"> &quot;floating point types, not int32&quot;;\</span></div><div class="line"><a name="l01320"></a><span class="lineno"> 1320</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01321"></a><span class="lineno"> 1321</span>&#160;<span class="preprocessor"> case mshadow::kInt64: \</span></div><div class="line"><a name="l01322"></a><span class="lineno"> 1322</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only support &quot; \</span></div><div class="line"><a name="l01323"></a><span class="lineno"> 1323</span>&#160;<span class="preprocessor"> &quot;floating point types, not int64&quot;;\</span></div><div class="line"><a name="l01324"></a><span class="lineno"> 1324</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01325"></a><span class="lineno"> 1325</span>&#160;<span class="preprocessor"> default: \</span></div><div class="line"><a name="l01326"></a><span class="lineno"> 1326</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;Unknown type enum &quot; &lt;&lt; type$; \</span></div><div class="line"><a name="l01327"></a><span class="lineno"> 1327</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l01328"></a><span class="lineno"> 1328</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l01329"></a><span class="lineno"> 1329</span>&#160;<span class="preprocessor">#define MSHADOW_REAL_TYPE_SWITCH_EX(type$, DType$, DLargeType$, ...) \</span></div><div class="line"><a name="l01330"></a><span class="lineno"> 1330</span>&#160;<span class="preprocessor"> switch (type$) { \</span></div><div class="line"><a name="l01331"></a><span class="lineno"> 1331</span>&#160;<span class="preprocessor"> case mshadow::kFloat32: \</span></div><div class="line"><a name="l01332"></a><span class="lineno"> 1332</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01333"></a><span class="lineno"> 1333</span>&#160;<span class="preprocessor"> typedef float DType$; \</span></div><div class="line"><a name="l01334"></a><span class="lineno"> 1334</span>&#160;<span class="preprocessor"> typedef float DLargeType$; \</span></div><div class="line"><a name="l01335"></a><span class="lineno"> 1335</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01336"></a><span class="lineno"> 1336</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01337"></a><span class="lineno"> 1337</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01338"></a><span class="lineno"> 1338</span>&#160;<span class="preprocessor"> case mshadow::kFloat64: \</span></div><div class="line"><a name="l01339"></a><span class="lineno"> 1339</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01340"></a><span class="lineno"> 1340</span>&#160;<span class="preprocessor"> typedef double DType$; \</span></div><div class="line"><a name="l01341"></a><span class="lineno"> 1341</span>&#160;<span class="preprocessor"> typedef double DLargeType$; \</span></div><div class="line"><a name="l01342"></a><span class="lineno"> 1342</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01343"></a><span class="lineno"> 1343</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01344"></a><span class="lineno"> 1344</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01345"></a><span class="lineno"> 1345</span>&#160;<span class="preprocessor"> case mshadow::kFloat16: \</span></div><div class="line"><a name="l01346"></a><span class="lineno"> 1346</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01347"></a><span class="lineno"> 1347</span>&#160;<span class="preprocessor"> typedef mshadow::half::half_t DType$; \</span></div><div class="line"><a name="l01348"></a><span class="lineno"> 1348</span>&#160;<span class="preprocessor"> typedef float DLargeType$; \</span></div><div class="line"><a name="l01349"></a><span class="lineno"> 1349</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01350"></a><span class="lineno"> 1350</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01351"></a><span class="lineno"> 1351</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01352"></a><span class="lineno"> 1352</span>&#160;<span class="preprocessor"> case mshadow::kUint8: \</span></div><div class="line"><a name="l01353"></a><span class="lineno"> 1353</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only support &quot; \</span></div><div class="line"><a name="l01354"></a><span class="lineno"> 1354</span>&#160;<span class="preprocessor"> &quot;floating point types not uint8&quot;; \</span></div><div class="line"><a name="l01355"></a><span class="lineno"> 1355</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01356"></a><span class="lineno"> 1356</span>&#160;<span class="preprocessor"> case mshadow::kInt8: \</span></div><div class="line"><a name="l01357"></a><span class="lineno"> 1357</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only support &quot; \</span></div><div class="line"><a name="l01358"></a><span class="lineno"> 1358</span>&#160;<span class="preprocessor"> &quot;floating point types not int8&quot;; \</span></div><div class="line"><a name="l01359"></a><span class="lineno"> 1359</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01360"></a><span class="lineno"> 1360</span>&#160;<span class="preprocessor"> case mshadow::kInt32: \</span></div><div class="line"><a name="l01361"></a><span class="lineno"> 1361</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only support &quot; \</span></div><div class="line"><a name="l01362"></a><span class="lineno"> 1362</span>&#160;<span class="preprocessor"> &quot;floating point types, not int32&quot;;\</span></div><div class="line"><a name="l01363"></a><span class="lineno"> 1363</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01364"></a><span class="lineno"> 1364</span>&#160;<span class="preprocessor"> case mshadow::kInt64: \</span></div><div class="line"><a name="l01365"></a><span class="lineno"> 1365</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;This operation only support &quot; \</span></div><div class="line"><a name="l01366"></a><span class="lineno"> 1366</span>&#160;<span class="preprocessor"> &quot;floating point types, not int64&quot;;\</span></div><div class="line"><a name="l01367"></a><span class="lineno"> 1367</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01368"></a><span class="lineno"> 1368</span>&#160;<span class="preprocessor"> default: \</span></div><div class="line"><a name="l01369"></a><span class="lineno"> 1369</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;Unknown type enum &quot; &lt;&lt; type$; \</span></div><div class="line"><a name="l01370"></a><span class="lineno"> 1370</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l01371"></a><span class="lineno"> 1371</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l01372"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#ad91ac184f854a56c21d06fafae8b93c6"> 1372</a></span>&#160;<span class="preprocessor">#define MSHADOW_LAYOUT_SWITCH(layout, Layout, ...) \</span></div><div class="line"><a name="l01373"></a><span class="lineno"> 1373</span>&#160;<span class="preprocessor"> switch (layout) { \</span></div><div class="line"><a name="l01374"></a><span class="lineno"> 1374</span>&#160;<span class="preprocessor"> case mshadow::kNCHW: \</span></div><div class="line"><a name="l01375"></a><span class="lineno"> 1375</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01376"></a><span class="lineno"> 1376</span>&#160;<span class="preprocessor"> const int Layout = kNCHW; \</span></div><div class="line"><a name="l01377"></a><span class="lineno"> 1377</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01378"></a><span class="lineno"> 1378</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01379"></a><span class="lineno"> 1379</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01380"></a><span class="lineno"> 1380</span>&#160;<span class="preprocessor"> case mshadow::kNHWC: \</span></div><div class="line"><a name="l01381"></a><span class="lineno"> 1381</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01382"></a><span class="lineno"> 1382</span>&#160;<span class="preprocessor"> const int Layout = kNHWC; \</span></div><div class="line"><a name="l01383"></a><span class="lineno"> 1383</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01384"></a><span class="lineno"> 1384</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01385"></a><span class="lineno"> 1385</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01386"></a><span class="lineno"> 1386</span>&#160;<span class="preprocessor"> case mshadow::kNCDHW: \</span></div><div class="line"><a name="l01387"></a><span class="lineno"> 1387</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01388"></a><span class="lineno"> 1388</span>&#160;<span class="preprocessor"> const int Layout = kNCDHW; \</span></div><div class="line"><a name="l01389"></a><span class="lineno"> 1389</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01390"></a><span class="lineno"> 1390</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01391"></a><span class="lineno"> 1391</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01392"></a><span class="lineno"> 1392</span>&#160;<span class="preprocessor"> case mshadow::kNDHWC: \</span></div><div class="line"><a name="l01393"></a><span class="lineno"> 1393</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01394"></a><span class="lineno"> 1394</span>&#160;<span class="preprocessor"> const int Layout = kNDHWC; \</span></div><div class="line"><a name="l01395"></a><span class="lineno"> 1395</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01396"></a><span class="lineno"> 1396</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01397"></a><span class="lineno"> 1397</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01398"></a><span class="lineno"> 1398</span>&#160;<span class="preprocessor"> default: \</span></div><div class="line"><a name="l01399"></a><span class="lineno"> 1399</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;Unknown layout enum &quot; &lt;&lt; layout; \</span></div><div class="line"><a name="l01400"></a><span class="lineno"> 1400</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l01401"></a><span class="lineno"> 1401</span>&#160;</div><div class="line"><a name="l01406"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#ae3f6108e48f51f98cd491fcded1d8ae0"> 1406</a></span>&#160;<span class="preprocessor">#define MSHADOW_IDX_TYPE_SWITCH(type, DType, ...) \</span></div><div class="line"><a name="l01407"></a><span class="lineno"> 1407</span>&#160;<span class="preprocessor"> switch (type) { \</span></div><div class="line"><a name="l01408"></a><span class="lineno"> 1408</span>&#160;<span class="preprocessor"> case mshadow::kInt64: \</span></div><div class="line"><a name="l01409"></a><span class="lineno"> 1409</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01410"></a><span class="lineno"> 1410</span>&#160;<span class="preprocessor"> typedef int64_t DType; \</span></div><div class="line"><a name="l01411"></a><span class="lineno"> 1411</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01412"></a><span class="lineno"> 1412</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01413"></a><span class="lineno"> 1413</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01414"></a><span class="lineno"> 1414</span>&#160;<span class="preprocessor"> default: \</span></div><div class="line"><a name="l01415"></a><span class="lineno"> 1415</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;Unknown type enum &quot; &lt;&lt; type; \</span></div><div class="line"><a name="l01416"></a><span class="lineno"> 1416</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l01417"></a><span class="lineno"> 1417</span>&#160;</div><div class="line"><a name="l01418"></a><span class="lineno"><a class="line" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a2c0869fdb46669460e7c56cec04dfaa7"> 1418</a></span>&#160;<span class="preprocessor">#define MSHADOW_TYPE_SWITCH_WITH_BOOL(type, DType, ...) \</span></div><div class="line"><a name="l01419"></a><span class="lineno"> 1419</span>&#160;<span class="preprocessor"> switch (type) { \</span></div><div class="line"><a name="l01420"></a><span class="lineno"> 1420</span>&#160;<span class="preprocessor"> case mshadow::kFloat32: \</span></div><div class="line"><a name="l01421"></a><span class="lineno"> 1421</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01422"></a><span class="lineno"> 1422</span>&#160;<span class="preprocessor"> typedef float DType; \</span></div><div class="line"><a name="l01423"></a><span class="lineno"> 1423</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01424"></a><span class="lineno"> 1424</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01425"></a><span class="lineno"> 1425</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01426"></a><span class="lineno"> 1426</span>&#160;<span class="preprocessor"> case mshadow::kFloat64: \</span></div><div class="line"><a name="l01427"></a><span class="lineno"> 1427</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01428"></a><span class="lineno"> 1428</span>&#160;<span class="preprocessor"> typedef double DType; \</span></div><div class="line"><a name="l01429"></a><span class="lineno"> 1429</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01430"></a><span class="lineno"> 1430</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01431"></a><span class="lineno"> 1431</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01432"></a><span class="lineno"> 1432</span>&#160;<span class="preprocessor"> case mshadow::kFloat16: \</span></div><div class="line"><a name="l01433"></a><span class="lineno"> 1433</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01434"></a><span class="lineno"> 1434</span>&#160;<span class="preprocessor"> typedef mshadow::half::half_t DType; \</span></div><div class="line"><a name="l01435"></a><span class="lineno"> 1435</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01436"></a><span class="lineno"> 1436</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01437"></a><span class="lineno"> 1437</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01438"></a><span class="lineno"> 1438</span>&#160;<span class="preprocessor"> case mshadow::kBfloat16: \</span></div><div class="line"><a name="l01439"></a><span class="lineno"> 1439</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01440"></a><span class="lineno"> 1440</span>&#160;<span class="preprocessor"> typedef mshadow::bfloat::bf16_t DType; \</span></div><div class="line"><a name="l01441"></a><span class="lineno"> 1441</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01442"></a><span class="lineno"> 1442</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01443"></a><span class="lineno"> 1443</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01444"></a><span class="lineno"> 1444</span>&#160;<span class="preprocessor"> case mshadow::kUint8: \</span></div><div class="line"><a name="l01445"></a><span class="lineno"> 1445</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01446"></a><span class="lineno"> 1446</span>&#160;<span class="preprocessor"> typedef uint8_t DType; \</span></div><div class="line"><a name="l01447"></a><span class="lineno"> 1447</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01448"></a><span class="lineno"> 1448</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01449"></a><span class="lineno"> 1449</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01450"></a><span class="lineno"> 1450</span>&#160;<span class="preprocessor"> case mshadow::kInt8: \</span></div><div class="line"><a name="l01451"></a><span class="lineno"> 1451</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01452"></a><span class="lineno"> 1452</span>&#160;<span class="preprocessor"> typedef int8_t DType; \</span></div><div class="line"><a name="l01453"></a><span class="lineno"> 1453</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01454"></a><span class="lineno"> 1454</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01455"></a><span class="lineno"> 1455</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01456"></a><span class="lineno"> 1456</span>&#160;<span class="preprocessor"> case mshadow::kInt32: \</span></div><div class="line"><a name="l01457"></a><span class="lineno"> 1457</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01458"></a><span class="lineno"> 1458</span>&#160;<span class="preprocessor"> typedef int32_t DType; \</span></div><div class="line"><a name="l01459"></a><span class="lineno"> 1459</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01460"></a><span class="lineno"> 1460</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01461"></a><span class="lineno"> 1461</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01462"></a><span class="lineno"> 1462</span>&#160;<span class="preprocessor"> case mshadow::kInt64: \</span></div><div class="line"><a name="l01463"></a><span class="lineno"> 1463</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01464"></a><span class="lineno"> 1464</span>&#160;<span class="preprocessor"> typedef int64_t DType; \</span></div><div class="line"><a name="l01465"></a><span class="lineno"> 1465</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01466"></a><span class="lineno"> 1466</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01467"></a><span class="lineno"> 1467</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01468"></a><span class="lineno"> 1468</span>&#160;<span class="preprocessor"> case mshadow::kBool: \</span></div><div class="line"><a name="l01469"></a><span class="lineno"> 1469</span>&#160;<span class="preprocessor"> { \</span></div><div class="line"><a name="l01470"></a><span class="lineno"> 1470</span>&#160;<span class="preprocessor"> typedef bool DType; \</span></div><div class="line"><a name="l01471"></a><span class="lineno"> 1471</span>&#160;<span class="preprocessor"> {__VA_ARGS__} \</span></div><div class="line"><a name="l01472"></a><span class="lineno"> 1472</span>&#160;<span class="preprocessor"> } \</span></div><div class="line"><a name="l01473"></a><span class="lineno"> 1473</span>&#160;<span class="preprocessor"> break; \</span></div><div class="line"><a name="l01474"></a><span class="lineno"> 1474</span>&#160;<span class="preprocessor"> default: \</span></div><div class="line"><a name="l01475"></a><span class="lineno"> 1475</span>&#160;<span class="preprocessor"> LOG(FATAL) &lt;&lt; &quot;Unknown type enum &quot; &lt;&lt; type; \</span></div><div class="line"><a name="l01476"></a><span class="lineno"> 1476</span>&#160;<span class="preprocessor"> }</span></div><div class="line"><a name="l01477"></a><span class="lineno"> 1477</span>&#160;</div><div class="line"><a name="l01479"></a><span class="lineno"><a class="line" href="namespacemshadow.html#a2e0671a4ac1729d7f8996ba091f8e07c"> 1479</a></span>&#160;<span class="keyword">inline</span> <span class="keywordtype">size_t</span> <a class="code" href="namespacemshadow.html#a2e0671a4ac1729d7f8996ba091f8e07c">mshadow_sizeof</a>(<span class="keywordtype">int</span> type) {</div><div class="line"><a name="l01480"></a><span class="lineno"> 1480</span>&#160; <span class="keywordtype">int</span> size = 0;</div><div class="line"><a name="l01481"></a><span class="lineno"> 1481</span>&#160; <a class="code" href="3rdparty_2mshadow_2mshadow_2base_8h.html#a2c0869fdb46669460e7c56cec04dfaa7">MSHADOW_TYPE_SWITCH_WITH_BOOL</a>(type, DType, size = <span class="keyword">sizeof</span>(DType););</div><div class="line"><a name="l01482"></a><span class="lineno"> 1482</span>&#160; <span class="keywordflow">return</span> size;</div><div class="line"><a name="l01483"></a><span class="lineno"> 1483</span>&#160;}</div><div class="line"><a name="l01484"></a><span class="lineno"> 1484</span>&#160;</div><div class="line"><a name="l01485"></a><span class="lineno"> 1485</span>&#160;<span class="comment">/*/ \brief get string with the type name from type enum */</span></div><div class="line"><a name="l01486"></a><span class="lineno"><a class="line" href="namespacemshadow.html#af5aa21f20dbeaa38194b4dadbd37a072"> 1486</a></span>&#160;<span class="keyword">inline</span> std::string <a class="code" href="namespacemshadow.html#af5aa21f20dbeaa38194b4dadbd37a072">dtype_string</a>(<span class="keyword">const</span> <span class="keywordtype">int</span> dtype) {</div><div class="line"><a name="l01487"></a><span class="lineno"> 1487</span>&#160; <span class="keywordflow">switch</span> (dtype) {</div><div class="line"><a name="l01488"></a><span class="lineno"> 1488</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a404a5fd26328cf46170f6eb3424c9633">mshadow::kFloat32</a>:</div><div class="line"><a name="l01489"></a><span class="lineno"> 1489</span>&#160; <span class="keywordflow">return</span> <span class="stringliteral">&quot;float&quot;</span>;</div><div class="line"><a name="l01490"></a><span class="lineno"> 1490</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a1f5a1c62216cbd2200443d501924cf28">mshadow::kFloat64</a>:</div><div class="line"><a name="l01491"></a><span class="lineno"> 1491</span>&#160; <span class="keywordflow">return</span> <span class="stringliteral">&quot;double&quot;</span>;</div><div class="line"><a name="l01492"></a><span class="lineno"> 1492</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a37ab9e42757689b17620f5728296d5d4">mshadow::kFloat16</a>:</div><div class="line"><a name="l01493"></a><span class="lineno"> 1493</span>&#160; <span class="keywordflow">return</span> <span class="stringliteral">&quot;half&quot;</span>;</div><div class="line"><a name="l01494"></a><span class="lineno"> 1494</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a1a39d2f8230da3cb53528904c8a5fff0">mshadow::kUint8</a>:</div><div class="line"><a name="l01495"></a><span class="lineno"> 1495</span>&#160; <span class="keywordflow">return</span> <span class="stringliteral">&quot;unsigned char&quot;</span>;</div><div class="line"><a name="l01496"></a><span class="lineno"> 1496</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a020e3574a4ec06c8e0b23a1b8a93026c">mshadow::kInt8</a>:</div><div class="line"><a name="l01497"></a><span class="lineno"> 1497</span>&#160; <span class="keywordflow">return</span> <span class="stringliteral">&quot;char&quot;</span>;</div><div class="line"><a name="l01498"></a><span class="lineno"> 1498</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a4fbb02e389c3126918b505cd01188368">mshadow::kInt32</a>:</div><div class="line"><a name="l01499"></a><span class="lineno"> 1499</span>&#160; <span class="keywordflow">return</span> <span class="stringliteral">&quot;int&quot;</span>;</div><div class="line"><a name="l01500"></a><span class="lineno"> 1500</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1accdd431fb941a9158baa00e7c5f3dc23">mshadow::kInt64</a>:</div><div class="line"><a name="l01501"></a><span class="lineno"> 1501</span>&#160; <span class="keywordflow">return</span> <span class="stringliteral">&quot;long long&quot;</span>;</div><div class="line"><a name="l01502"></a><span class="lineno"> 1502</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1ad2f7fcc5a34a6b27898cfd5d1626882a">mshadow::kBool</a>:</div><div class="line"><a name="l01503"></a><span class="lineno"> 1503</span>&#160; <span class="keywordflow">return</span> <span class="stringliteral">&quot;bool&quot;</span>;</div><div class="line"><a name="l01504"></a><span class="lineno"> 1504</span>&#160; <span class="keywordflow">default</span>:</div><div class="line"><a name="l01505"></a><span class="lineno"> 1505</span>&#160; LOG(FATAL) &lt;&lt; <span class="stringliteral">&quot;Unknown type enum &quot;</span> &lt;&lt; dtype;</div><div class="line"><a name="l01506"></a><span class="lineno"> 1506</span>&#160; }</div><div class="line"><a name="l01507"></a><span class="lineno"> 1507</span>&#160; <span class="keywordflow">return</span> <span class="stringliteral">&quot;unknown&quot;</span>;</div><div class="line"><a name="l01508"></a><span class="lineno"> 1508</span>&#160;}</div><div class="line"><a name="l01509"></a><span class="lineno"> 1509</span>&#160;</div><div class="line"><a name="l01510"></a><span class="lineno"> 1510</span>&#160;} <span class="comment">// namespace mshadow</span></div><div class="line"><a name="l01511"></a><span class="lineno"> 1511</span>&#160;<span class="preprocessor">#endif // MSHADOW_BASE_H_</span></div><div class="ttc" id="structmshadow_1_1red_1_1minimum_html_ae844649225377caf827a51ef0d080515"><div class="ttname"><a href="structmshadow_1_1red_1_1minimum.html#ae844649225377caf827a51ef0d080515">mshadow::red::minimum::Finalize</a></div><div class="ttdeci">static MSHADOW_XINLINE void Finalize(volatile DType &amp;dst, volatile DType &amp;residual)</div><div class="ttdoc">finalize reduction </div><div class="ttdef"><b>Definition:</b> base.h:1047</div></div>
<div class="ttc" id="3rdparty_2mshadow_2mshadow_2base_8h_html_a2c0869fdb46669460e7c56cec04dfaa7"><div class="ttname"><a href="3rdparty_2mshadow_2mshadow_2base_8h.html#a2c0869fdb46669460e7c56cec04dfaa7">MSHADOW_TYPE_SWITCH_WITH_BOOL</a></div><div class="ttdeci">#define MSHADOW_TYPE_SWITCH_WITH_BOOL(type, DType,...)</div><div class="ttdef"><b>Definition:</b> base.h:1418</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1a404a5fd26328cf46170f6eb3424c9633"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a404a5fd26328cf46170f6eb3424c9633">mshadow::kFloat32</a></div><div class="ttdef"><b>Definition:</b> base.h:359</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1minimum_html_aa3f7b2a1f96f77caca258e8c594f67bd"><div class="ttname"><a href="structmshadow_1_1red_1_1minimum.html#aa3f7b2a1f96f77caca258e8c594f67bd">mshadow::red::minimum::PartialGrad</a></div><div class="ttdeci">static MSHADOW_XINLINE DType PartialGrad(DType redres, DType redsrc)</div><div class="ttdoc">calculate gradient of redres with respect to redsrc, redres: reduced result, redsrc: one of reduction...</div><div class="ttdef"><b>Definition:</b> base.h:1053</div></div>
<div class="ttc" id="namespacemshadow_html_a143ad1a73ba518ef0aad29d36f2569ee"><div class="ttname"><a href="namespacemshadow.html#a143ad1a73ba518ef0aad29d36f2569ee">mshadow::default_type_flag</a></div><div class="ttdeci">const int default_type_flag</div><div class="ttdoc">type enum value for default real type </div><div class="ttdef"><b>Definition:</b> base.h:484</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1maximum_html_a99c8021ef1da714c052bfdf1f4e41280"><div class="ttname"><a href="structmshadow_1_1red_1_1maximum.html#a99c8021ef1da714c052bfdf1f4e41280">mshadow::red::maximum::Finalize</a></div><div class="ttdeci">static MSHADOW_XINLINE void Finalize(volatile DType &amp;dst, volatile DType &amp;residual)</div><div class="ttdoc">finalize reduction </div><div class="ttdef"><b>Definition:</b> base.h:994</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a993a69000bf5e0a5d13ef149a3311a78"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a993a69000bf5e0a5d13ef149a3311a78">mshadow::red::limits::MaxValue</a></div><div class="ttdeci">MSHADOW_XINLINE DType MaxValue(void)</div><div class="ttdoc">maximum value of certain types </div></div>
<div class="ttc" id="namespacemshadow_html_abbe2dc827052234b64ab2d40a5b2fdb4aa332dc48875dac0ef29ef245e5609822"><div class="ttname"><a href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4aa332dc48875dac0ef29ef245e5609822">mshadow::kNCDHW</a></div><div class="ttdef"><b>Definition:</b> base.h:496</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_affcf917b2d5206e3ddeec7e5f0ee995e"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#affcf917b2d5206e3ddeec7e5f0ee995e">mshadow::red::limits::MaxValue&lt; int8_t &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE int8_t MaxValue&lt; int8_t &gt;(void)</div><div class="ttdoc">maximum value of int8_t </div><div class="ttdef"><b>Definition:</b> base.h:847</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1minusto_html_a48fae34ea7d461ced6ac9c98c5e38019"><div class="ttname"><a href="structmshadow_1_1sv_1_1minusto.html#a48fae34ea7d461ced6ac9c98c5e38019">mshadow::sv::minusto::BetaBLAS</a></div><div class="ttdeci">static default_real_t BetaBLAS(void)</div><div class="ttdoc">helper constant to use BLAS, beta </div><div class="ttdef"><b>Definition:</b> base.h:646</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_af43c87655a8a1531462fa86bc7cc902e"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#af43c87655a8a1531462fa86bc7cc902e">mshadow::red::limits::NegInfValue&lt; float &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE float NegInfValue&lt; float &gt;(void)</div><div class="ttdoc">negative infinity value of float </div><div class="ttdef"><b>Definition:</b> base.h:799</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1plusto_html_ac7556832c791c8d048cbb7fd606f6e8e"><div class="ttname"><a href="structmshadow_1_1sv_1_1plusto.html#ac7556832c791c8d048cbb7fd606f6e8e">mshadow::sv::plusto::Save</a></div><div class="ttdeci">static MSHADOW_XINLINE void Save(DType &amp;a, DType b)</div><div class="ttdoc">save b to a using save method </div><div class="ttdef"><b>Definition:</b> base.h:626</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a1e417de4a028b2628d6bb5b6af1244dc"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a1e417de4a028b2628d6bb5b6af1244dc">mshadow::red::limits::MinValue&lt; int32_t &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE int MinValue&lt; int32_t &gt;(void)</div><div class="ttdoc">minimum value of int32_t </div><div class="ttdef"><b>Definition:</b> base.h:770</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1minusto_html_a50bab98db98ee42cd377f2e2f02e37ca"><div class="ttname"><a href="structmshadow_1_1sv_1_1minusto.html#a50bab98db98ee42cd377f2e2f02e37ca">mshadow::sv::minusto::Save</a></div><div class="ttdeci">static MSHADOW_XINLINE void Save(DType &amp;a, DType b)</div><div class="ttdoc">save b to a using save method </div><div class="ttdef"><b>Definition:</b> base.h:640</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a232631c75acb76794420d172a5cc335e"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a232631c75acb76794420d172a5cc335e">mshadow::red::limits::MinValue&lt; float &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE float MinValue&lt; float &gt;(void)</div><div class="ttdoc">minimum value of float </div><div class="ttdef"><b>Definition:</b> base.h:740</div></div>
<div class="ttc" id="half2_8h_html"><div class="ttname"><a href="half2_8h.html">half2.h</a></div><div class="ttdoc">definition of vector float16, half2 type. </div></div>
<div class="ttc" id="structmshadow_1_1red_1_1sum_html_a351d0e761cb9944c4d98919535754142"><div class="ttname"><a href="structmshadow_1_1red_1_1sum.html#a351d0e761cb9944c4d98919535754142">mshadow::red::sum::PartialGrad</a></div><div class="ttdeci">static MSHADOW_XINLINE DType PartialGrad(DType redres, DType redsrc)</div><div class="ttdoc">calculate gradient of redres with respect to redsrc, redres: reduced result, redsrc: one of reduction...</div><div class="ttdef"><b>Definition:</b> base.h:946</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1sum_html_a351e35f2cbf0f8e7e08c5f23b70f3c3f"><div class="ttname"><a href="structmshadow_1_1red_1_1sum.html#a351e35f2cbf0f8e7e08c5f23b70f3c3f">mshadow::red::sum::SetInitValue</a></div><div class="ttdeci">static MSHADOW_XINLINE void SetInitValue(DType &amp;initv, DType &amp;residual)</div><div class="ttdoc">set the initial value during reduction </div><div class="ttdef"><b>Definition:</b> base.h:960</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a78426e39f8f6170f709965da5aa2d118"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a78426e39f8f6170f709965da5aa2d118">mshadow::red::limits::MaxValue&lt; uint32_t &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE uint32_t MaxValue&lt; uint32_t &gt;(void)</div><div class="ttdoc">maximum value of uint32_t </div><div class="ttdef"><b>Definition:</b> base.h:867</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1saveto_html"><div class="ttname"><a href="structmshadow_1_1sv_1_1saveto.html">mshadow::sv::saveto</a></div><div class="ttdoc">save to saver: = </div><div class="ttdef"><b>Definition:</b> base.h:609</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a5ada516b5bd58791f170586cfdd9ae2f"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a5ada516b5bd58791f170586cfdd9ae2f">mshadow::red::limits::MinValue&lt; uint8_t &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE uint8_t MinValue&lt; uint8_t &gt;(void)</div><div class="ttdoc">minimum value of uint8_t </div><div class="ttdef"><b>Definition:</b> base.h:760</div></div>
<div class="ttc" id="namespacemshadow_1_1isinf__typed_html_a5208c13b479de37653fc08402f08e56d"><div class="ttname"><a href="namespacemshadow_1_1isinf__typed.html#a5208c13b479de37653fc08402f08e56d">mshadow::isinf_typed::IsInf</a></div><div class="ttdeci">MSHADOW_XINLINE bool IsInf(volatile DType val)</div><div class="ttdef"><b>Definition:</b> base.h:708</div></div>
<div class="ttc" id="bfloat_8h_html"><div class="ttname"><a href="bfloat_8h.html">bfloat.h</a></div><div class="ttdoc">definition of bfloat type. </div></div>
<div class="ttc" id="half_8h_html"><div class="ttname"><a href="half_8h.html">half.h</a></div><div class="ttdoc">definition of half (float16) type. </div></div>
<div class="ttc" id="structmshadow_1_1red_1_1maximum_html_ac2d455ca3b4eb12554eb31ed6a1387b7"><div class="ttname"><a href="structmshadow_1_1red_1_1maximum.html#ac2d455ca3b4eb12554eb31ed6a1387b7">mshadow::red::maximum::PartialGrad</a></div><div class="ttdeci">static MSHADOW_XINLINE DType PartialGrad(DType redres, DType redsrc)</div><div class="ttdoc">calculate gradient of redres with respect to redsrc, redres: reduced result, redsrc: one of reduction...</div><div class="ttdef"><b>Definition:</b> base.h:1000</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1maximum_html_a96aaae5db92ec7a3a8a5740265394a35"><div class="ttname"><a href="structmshadow_1_1red_1_1maximum.html#a96aaae5db92ec7a3a8a5740265394a35">mshadow::red::maximum::Reduce</a></div><div class="ttdeci">static MSHADOW_XINLINE void Reduce(volatile DType &amp;dst, volatile DType src, volatile DType &amp;none)</div><div class="ttdoc">do reduction into dst </div><div class="ttdef"><b>Definition:</b> base.h:976</div></div>
<div class="ttc" id="half_8h_html_afdc51a9766b6923a3742828222103e3d"><div class="ttname"><a href="half_8h.html#afdc51a9766b6923a3742828222103e3d">MSHADOW_HALF_EXPONENT_BITS</a></div><div class="ttdeci">#define MSHADOW_HALF_EXPONENT_BITS</div><div class="ttdef"><b>Definition:</b> half.h:371</div></div>
<div class="ttc" id="structmshadow_1_1op_1_1div_html"><div class="ttname"><a href="structmshadow_1_1op_1_1div.html">mshadow::op::div</a></div><div class="ttdoc">divide operator </div><div class="ttdef"><b>Definition:</b> base.h:578</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a6b0a333f168fa9d54d2f13caabd595e0"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a6b0a333f168fa9d54d2f13caabd595e0">mshadow::red::limits::NegInfValue</a></div><div class="ttdeci">MSHADOW_XINLINE DType NegInfValue(void)</div><div class="ttdoc">negative infinity of certain types </div><div class="ttdef"><b>Definition:</b> base.h:794</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1multo_html_ab3b6328d24ef3ce0cf5c0329e254f193"><div class="ttname"><a href="structmshadow_1_1sv_1_1multo.html#ab3b6328d24ef3ce0cf5c0329e254f193">mshadow::sv::multo::Save</a></div><div class="ttdeci">static MSHADOW_XINLINE void Save(DType &amp;a, DType b)</div><div class="ttdoc">save b to a using save method </div><div class="ttdef"><b>Definition:</b> base.h:654</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a77b7882d6cafca4b12908e2fff2302ed"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a77b7882d6cafca4b12908e2fff2302ed">mshadow::red::limits::PosInfValue&lt; float &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE float PosInfValue&lt; float &gt;(void)</div><div class="ttdoc">positive infinity value of float </div><div class="ttdef"><b>Definition:</b> base.h:881</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1sum_html_aedc5b032275b8d11fc95fae2545cc2cb"><div class="ttname"><a href="structmshadow_1_1red_1_1sum.html#aedc5b032275b8d11fc95fae2545cc2cb">mshadow::red::sum::SetInitValue</a></div><div class="ttdeci">static MSHADOW_XINLINE void SetInitValue(DType &amp;initv)</div><div class="ttdoc">set the initial value during reduction </div><div class="ttdef"><b>Definition:</b> base.h:953</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1saveto_html_ac78ceb69e8291f8fa767c2eda2a732a5"><div class="ttname"><a href="structmshadow_1_1sv_1_1saveto.html#ac78ceb69e8291f8fa767c2eda2a732a5">mshadow::sv::saveto::OPType</a></div><div class="ttdeci">op::right OPType</div><div class="ttdoc">corresponding binary operator type </div><div class="ttdef"><b>Definition:</b> base.h:620</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1minusto_html_ac9baef2b9d3a92b962c9ad7f7ee1122d"><div class="ttname"><a href="structmshadow_1_1sv_1_1minusto.html#ac9baef2b9d3a92b962c9ad7f7ee1122d">mshadow::sv::minusto::OPType</a></div><div class="ttdeci">op::minus OPType</div><div class="ttdoc">corresponding binary operator type </div><div class="ttdef"><b>Definition:</b> base.h:648</div></div>
<div class="ttc" id="structmshadow_1_1op_1_1div_html_a5ad9c92273fb4c1a29fc3eb3fba3ae5a"><div class="ttname"><a href="structmshadow_1_1op_1_1div.html#a5ad9c92273fb4c1a29fc3eb3fba3ae5a">mshadow::op::div::Map</a></div><div class="ttdeci">static MSHADOW_XINLINE DType Map(DType a, DType b)</div><div class="ttdoc">map a, b to result using defined operation </div><div class="ttdef"><b>Definition:</b> base.h:581</div></div>
<div class="ttc" id="namespacemshadow_1_1isnan__typed_html_abae8abe8600d9f57faddd8e59ad9ed50"><div class="ttname"><a href="namespacemshadow_1_1isnan__typed.html#abae8abe8600d9f57faddd8e59ad9ed50">mshadow::isnan_typed::IsNan</a></div><div class="ttdeci">MSHADOW_XINLINE bool IsNan(volatile mshadow::half::half_t val)</div><div class="ttdef"><b>Definition:</b> base.h:698</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1maximum_html_a6f5613dfb9c095420b5fe322aa2ab1ed"><div class="ttname"><a href="structmshadow_1_1red_1_1maximum.html#a6f5613dfb9c095420b5fe322aa2ab1ed">mshadow::red::maximum::SetInitValue</a></div><div class="ttdeci">static MSHADOW_XINLINE void SetInitValue(DType &amp;initv, DType &amp;none)</div><div class="ttdoc">set the initial value during reduction </div><div class="ttdef"><b>Definition:</b> base.h:1014</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1minimum_html_aa000adb90fad1fb429a05b1c6c8b836b"><div class="ttname"><a href="structmshadow_1_1red_1_1minimum.html#aa000adb90fad1fb429a05b1c6c8b836b">mshadow::red::minimum::Reduce</a></div><div class="ttdeci">static MSHADOW_XINLINE void Reduce(volatile DType &amp;dst, volatile DType src)</div><div class="ttdoc">do reduction into dst </div><div class="ttdef"><b>Definition:</b> base.h:1022</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1maximum_html_a99b1074ecd03f849cbdcfbad8df8ed2b"><div class="ttname"><a href="structmshadow_1_1red_1_1maximum.html#a99b1074ecd03f849cbdcfbad8df8ed2b">mshadow::red::maximum::Reduce</a></div><div class="ttdeci">static MSHADOW_XINLINE void Reduce(volatile DType &amp;dst, volatile DType src)</div><div class="ttdoc">do reduction into dst </div><div class="ttdef"><b>Definition:</b> base.h:969</div></div>
<div class="ttc" id="namespacemshadow_html_abbe2dc827052234b64ab2d40a5b2fdb4ae633c123a9c9897779d5c00ea5381775"><div class="ttname"><a href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4ae633c123a9c9897779d5c00ea5381775">mshadow::kNCHW</a></div><div class="ttdef"><b>Definition:</b> base.h:488</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1a36cfd4fc26c0ee29affa99a36db0db17"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a36cfd4fc26c0ee29affa99a36db0db17">mshadow::kInt16</a></div><div class="ttdef"><b>Definition:</b> base.h:367</div></div>
<div class="ttc" id="structmshadow_1_1op_1_1identity_html"><div class="ttname"><a href="structmshadow_1_1op_1_1identity.html">mshadow::op::identity</a></div><div class="ttdoc">identity function that maps a real number to it self </div><div class="ttdef"><b>Definition:</b> base.h:598</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1multo_html_acc47e9c85d6e583e5785ba0f62fa4431"><div class="ttname"><a href="structmshadow_1_1sv_1_1multo.html#acc47e9c85d6e583e5785ba0f62fa4431">mshadow::sv::multo::OPType</a></div><div class="ttdeci">op::mul OPType</div><div class="ttdoc">corresponding binary operator type </div><div class="ttdef"><b>Definition:</b> base.h:658</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1saveto_html_af99e9c2ec6d116febb41fc73d201d80e"><div class="ttname"><a href="structmshadow_1_1sv_1_1saveto.html#af99e9c2ec6d116febb41fc73d201d80e">mshadow::sv::saveto::Save</a></div><div class="ttdeci">static MSHADOW_XINLINE void Save(DType &amp;a, DType b)</div><div class="ttdoc">save b to a using save method </div><div class="ttdef"><b>Definition:</b> base.h:612</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1minusto_html_a0da791365b9910dd337e228888521127"><div class="ttname"><a href="structmshadow_1_1sv_1_1minusto.html#a0da791365b9910dd337e228888521127">mshadow::sv::minusto::AlphaBLAS</a></div><div class="ttdeci">static default_real_t AlphaBLAS(void)</div><div class="ttdoc">helper constant to use BLAS, alpha </div><div class="ttdef"><b>Definition:</b> base.h:644</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1sum_html_af024e58661dffc3043fdab0ac6424659"><div class="ttname"><a href="structmshadow_1_1red_1_1sum.html#af024e58661dffc3043fdab0ac6424659">mshadow::red::sum::Finalize</a></div><div class="ttdeci">static MSHADOW_XINLINE void Finalize(volatile DType &amp;dst, volatile DType &amp;residual)</div><div class="ttdoc">finalize reduction </div><div class="ttdef"><b>Definition:</b> base.h:940</div></div>
<div class="ttc" id="structmshadow_1_1LayoutType_html"><div class="ttname"><a href="structmshadow_1_1LayoutType.html">mshadow::LayoutType</a></div><div class="ttdef"><b>Definition:</b> base.h:502</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a55d9bb33517b6c82d04555acba79680a"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a55d9bb33517b6c82d04555acba79680a">mshadow::red::limits::MinValue&lt; int8_t &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE int8_t MinValue&lt; int8_t &gt;(void)</div><div class="ttdoc">minimum value of int8_t </div><div class="ttdef"><b>Definition:</b> base.h:765</div></div>
<div class="ttc" id="namespacemshadow_html_abbe2dc827052234b64ab2d40a5b2fdb4ad9ef54b427a838279a62e95204aa3281"><div class="ttname"><a href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4ad9ef54b427a838279a62e95204aa3281">mshadow::kNHWC</a></div><div class="ttdef"><b>Definition:</b> base.h:489</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1maximum_html_a97c5d96eac2849f458678742738f1ce0"><div class="ttname"><a href="structmshadow_1_1red_1_1maximum.html#a97c5d96eac2849f458678742738f1ce0">mshadow::red::maximum::Finalize</a></div><div class="ttdeci">static MSHADOW_XINLINE void Finalize(volatile DType &amp;dst)</div><div class="ttdoc">finalize reduction </div><div class="ttdef"><b>Definition:</b> base.h:991</div></div>
<div class="ttc" id="namespacemshadow_1_1isinf__typed_html_a9300383296ccfacbfec50a6b8d33d557"><div class="ttname"><a href="namespacemshadow_1_1isinf__typed.html#a9300383296ccfacbfec50a6b8d33d557">mshadow::isinf_typed::IsInf</a></div><div class="ttdeci">MSHADOW_XINLINE bool IsInf(volatile mshadow::half::half_t val)</div><div class="ttdef"><b>Definition:</b> base.h:724</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a1adf2b0a158ad07a93b21f11e6aa3150"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a1adf2b0a158ad07a93b21f11e6aa3150">mshadow::red::limits::MinValue&lt; bool &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE bool MinValue&lt; bool &gt;(void)</div><div class="ttdoc">minimum value of bool </div><div class="ttdef"><b>Definition:</b> base.h:780</div></div>
<div class="ttc" id="3rdparty_2mshadow_2mshadow_2base_8h_html_af205b8ab4d8733133d590df7d2639d69"><div class="ttname"><a href="3rdparty_2mshadow_2mshadow_2base_8h.html#af205b8ab4d8733133d590df7d2639d69">MSHADOW_XINLINE</a></div><div class="ttdeci">#define MSHADOW_XINLINE</div><div class="ttdef"><b>Definition:</b> base.h:230</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1sum_html_a36583c3bb79bbfe107b7c9480e80d5e7"><div class="ttname"><a href="structmshadow_1_1red_1_1sum.html#a36583c3bb79bbfe107b7c9480e80d5e7">mshadow::red::sum::Reduce</a></div><div class="ttdeci">static MSHADOW_XINLINE void Reduce(volatile DType &amp;dst, volatile DType src, volatile DType &amp;residual)</div><div class="ttdoc">do stable reduction into dst </div><div class="ttdef"><b>Definition:</b> base.h:906</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1divto_html_aaa2299b2a710d1b5d61b6dc6f44c9339"><div class="ttname"><a href="structmshadow_1_1sv_1_1divto.html#aaa2299b2a710d1b5d61b6dc6f44c9339">mshadow::sv::divto::Save</a></div><div class="ttdeci">static MSHADOW_XINLINE void Save(DType &amp;a, DType b)</div><div class="ttdoc">save b to a using save method </div><div class="ttdef"><b>Definition:</b> base.h:664</div></div>
<div class="ttc" id="namespacemshadow_html_ac4cba6b672478463350f7d84b47e99e3"><div class="ttname"><a href="namespacemshadow.html#ac4cba6b672478463350f7d84b47e99e3">mshadow::kRandBufferSize</a></div><div class="ttdeci">const unsigned kRandBufferSize</div><div class="ttdoc">buffer size for each random number generator </div><div class="ttdef"><b>Definition:</b> base.h:336</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a4fdc4629369e455063f9d084570f276a"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a4fdc4629369e455063f9d084570f276a">mshadow::red::limits::MaxValue&lt; double &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE double MaxValue&lt; double &gt;(void)</div><div class="ttdoc">maximum value of double </div><div class="ttdef"><b>Definition:</b> base.h:827</div></div>
<div class="ttc" id="namespacemshadow_1_1isnan__typed_html_a31da61266fae8c9ca52df015d132b759"><div class="ttname"><a href="namespacemshadow_1_1isnan__typed.html#a31da61266fae8c9ca52df015d132b759">mshadow::isnan_typed::IsNan</a></div><div class="ttdeci">MSHADOW_XINLINE bool IsNan(volatile DType val)</div><div class="ttdef"><b>Definition:</b> base.h:682</div></div>
<div class="ttc" id="namespacemshadow_html_a36590a455cab713cf4bbb115c4dba247"><div class="ttname"><a href="namespacemshadow.html#a36590a455cab713cf4bbb115c4dba247">mshadow::default_layout</a></div><div class="ttdeci">const int default_layout</div><div class="ttdoc">default layout for 4d tensor </div><div class="ttdef"><b>Definition:</b> base.h:525</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1minimum_html_aba3be24837548e8f5a48178889ec2132"><div class="ttname"><a href="structmshadow_1_1red_1_1minimum.html#aba3be24837548e8f5a48178889ec2132">mshadow::red::minimum::SetInitValue</a></div><div class="ttdeci">static MSHADOW_XINLINE void SetInitValue(DType &amp;initv, DType &amp;none)</div><div class="ttdoc">set the initial value during reduction </div><div class="ttdef"><b>Definition:</b> base.h:1067</div></div>
<div class="ttc" id="namespacemshadow_html_abbe2dc827052234b64ab2d40a5b2fdb4"><div class="ttname"><a href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4">mshadow::LayoutFlag</a></div><div class="ttdeci">LayoutFlag</div><div class="ttdef"><b>Definition:</b> base.h:487</div></div>
<div class="ttc" id="structmshadow_1_1op_1_1right_html"><div class="ttname"><a href="structmshadow_1_1op_1_1right.html">mshadow::op::right</a></div><div class="ttdoc">get rhs </div><div class="ttdef"><b>Definition:</b> base.h:586</div></div>
<div class="ttc" id="bfloat_8h_html_a3d5d63ecb7104078d465a0074f9d9059"><div class="ttname"><a href="bfloat_8h.html#a3d5d63ecb7104078d465a0074f9d9059">MSHADOW_BF16_MAX</a></div><div class="ttdeci">#define MSHADOW_BF16_MAX</div><div class="ttdef"><b>Definition:</b> bfloat.h:182</div></div>
<div class="ttc" id="namespacemshadow_html_af5aa21f20dbeaa38194b4dadbd37a072"><div class="ttname"><a href="namespacemshadow.html#af5aa21f20dbeaa38194b4dadbd37a072">mshadow::dtype_string</a></div><div class="ttdeci">std::string dtype_string(const int dtype)</div><div class="ttdef"><b>Definition:</b> base.h:1486</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1minusto_html"><div class="ttname"><a href="structmshadow_1_1sv_1_1minusto.html">mshadow::sv::minusto</a></div><div class="ttdoc">minus to saver: -= </div><div class="ttdef"><b>Definition:</b> base.h:637</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_ad5c922e935e2efb47bb238c56ff8a38b"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#ad5c922e935e2efb47bb238c56ff8a38b">mshadow::red::limits::MaxValue&lt; int32_t &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE int MaxValue&lt; int32_t &gt;(void)</div><div class="ttdoc">maximum value of int32_t </div><div class="ttdef"><b>Definition:</b> base.h:852</div></div>
<div class="ttc" id="namespacemshadow_html_adcbc2e1131386fccb1474b0bdf045926"><div class="ttname"><a href="namespacemshadow.html#adcbc2e1131386fccb1474b0bdf045926">mshadow::index_t</a></div><div class="ttdeci">int32_t index_t</div><div class="ttdoc">type that will be used for index </div><div class="ttdef"><b>Definition:</b> base.h:343</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1multo_html"><div class="ttname"><a href="structmshadow_1_1sv_1_1multo.html">mshadow::sv::multo</a></div><div class="ttdoc">multiply to saver: *= </div><div class="ttdef"><b>Definition:</b> base.h:651</div></div>
<div class="ttc" id="structmshadow_1_1op_1_1plus_html_a83fb5b1656992c6fd442a819de83b292"><div class="ttname"><a href="structmshadow_1_1op_1_1plus.html#a83fb5b1656992c6fd442a819de83b292">mshadow::op::plus::Map</a></div><div class="ttdeci">static MSHADOW_XINLINE DType Map(DType a, DType b)</div><div class="ttdoc">map a, b to result using defined operation </div><div class="ttdef"><b>Definition:</b> base.h:565</div></div>
<div class="ttc" id="namespacemshadow_html_a8afab1f2134d65e09679faa324ecf9ce"><div class="ttname"><a href="namespacemshadow.html#a8afab1f2134d65e09679faa324ecf9ce">mshadow::kPi</a></div><div class="ttdeci">const float kPi</div><div class="ttdoc">pi </div><div class="ttdef"><b>Definition:</b> base.h:338</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1a020e3574a4ec06c8e0b23a1b8a93026c"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a020e3574a4ec06c8e0b23a1b8a93026c">mshadow::kInt8</a></div><div class="ttdef"><b>Definition:</b> base.h:364</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1plusto_html_a0b3849b290f3207a59b8975e2b29b065"><div class="ttname"><a href="structmshadow_1_1sv_1_1plusto.html#a0b3849b290f3207a59b8975e2b29b065">mshadow::sv::plusto::OPType</a></div><div class="ttdeci">op::plus OPType</div><div class="ttdoc">corresponding binary operator type </div><div class="ttdef"><b>Definition:</b> base.h:634</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a6262f9d4a98d7ddc205cb0b19af4a316"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a6262f9d4a98d7ddc205cb0b19af4a316">mshadow::red::limits::MaxValue&lt; float &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE float MaxValue&lt; float &gt;(void)</div><div class="ttdoc">maximum value of float </div><div class="ttdef"><b>Definition:</b> base.h:822</div></div>
<div class="ttc" id="namespacemshadow_html_a10a73dbdb4a2b833495c2315b6da69ce"><div class="ttname"><a href="namespacemshadow.html#a10a73dbdb4a2b833495c2315b6da69ce">mshadow::default_real_t</a></div><div class="ttdeci">float default_real_t</div><div class="ttdoc">float point type that will be used in default by mshadow </div><div class="ttdef"><b>Definition:</b> base.h:355</div></div>
<div class="ttc" id="namespacemshadow_html_a29fa60cc6436415a699971c1a3fd760a"><div class="ttname"><a href="namespacemshadow.html#a29fa60cc6436415a699971c1a3fd760a">mshadow::default_layout_5d</a></div><div class="ttdeci">const int default_layout_5d</div><div class="ttdoc">default layout for 5d tensor </div><div class="ttdef"><b>Definition:</b> base.h:548</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1minimum_html_a01e4946a88167d905c14b39d3965e03c"><div class="ttname"><a href="structmshadow_1_1red_1_1minimum.html#a01e4946a88167d905c14b39d3965e03c">mshadow::red::minimum::Reduce</a></div><div class="ttdeci">static MSHADOW_XINLINE void Reduce(volatile DType &amp;dst, volatile DType src, volatile DType &amp;none)</div><div class="ttdoc">do reduction into dst </div><div class="ttdef"><b>Definition:</b> base.h:1029</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a56182d9842b841740da7eefb60916cf9"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a56182d9842b841740da7eefb60916cf9">mshadow::red::limits::MinValue&lt; int64_t &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE int64_t MinValue&lt; int64_t &gt;(void)</div><div class="ttdoc">minimum value of int64_t </div><div class="ttdef"><b>Definition:</b> base.h:775</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1minimum_html"><div class="ttname"><a href="structmshadow_1_1red_1_1minimum.html">mshadow::red::minimum</a></div><div class="ttdoc">minimum reducer </div><div class="ttdef"><b>Definition:</b> base.h:1019</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a34f7a97ddbac1b447e39603de7c6f965"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a34f7a97ddbac1b447e39603de7c6f965">mshadow::red::limits::MinValue&lt; double &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE double MinValue&lt; double &gt;(void)</div><div class="ttdoc">minimum value of double </div><div class="ttdef"><b>Definition:</b> base.h:745</div></div>
<div class="ttc" id="half_8h_html_a6961c70512f3780000b1ee5691363da3"><div class="ttname"><a href="half_8h.html#a6961c70512f3780000b1ee5691363da3">MSHADOW_HALF_MIN</a></div><div class="ttdeci">#define MSHADOW_HALF_MIN</div><div class="ttdoc">overloaded + operator for half_t </div><div class="ttdef"><b>Definition:</b> half.h:368</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1ad2f7fcc5a34a6b27898cfd5d1626882a"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1ad2f7fcc5a34a6b27898cfd5d1626882a">mshadow::kBool</a></div><div class="ttdef"><b>Definition:</b> base.h:366</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1a1f5a1c62216cbd2200443d501924cf28"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a1f5a1c62216cbd2200443d501924cf28">mshadow::kFloat64</a></div><div class="ttdef"><b>Definition:</b> base.h:360</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a5244fd39689a5526efa712f85579b148"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a5244fd39689a5526efa712f85579b148">mshadow::red::limits::MinValue</a></div><div class="ttdeci">MSHADOW_XINLINE DType MinValue(void)</div><div class="ttdoc">minimum value of certain types </div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1divto_html"><div class="ttname"><a href="structmshadow_1_1sv_1_1divto.html">mshadow::sv::divto</a></div><div class="ttdoc">divide to saver: /= </div><div class="ttdef"><b>Definition:</b> base.h:661</div></div>
<div class="ttc" id="structmshadow_1_1op_1_1mul_html_a38a7497e4f710d7da3f5b9563d754b21"><div class="ttname"><a href="structmshadow_1_1op_1_1mul.html#a38a7497e4f710d7da3f5b9563d754b21">mshadow::op::mul::Map</a></div><div class="ttdeci">static MSHADOW_XINLINE DType Map(DType a, DType b)</div><div class="ttdoc">map a, b to result using defined operation </div><div class="ttdef"><b>Definition:</b> base.h:557</div></div>
<div class="ttc" id="3rdparty_2mshadow_2mshadow_2base_8h_html_a5260fbd063fdb83af6cff734306ce856"><div class="ttname"><a href="3rdparty_2mshadow_2mshadow_2base_8h.html#a5260fbd063fdb83af6cff734306ce856">MSHADOW_HALF_BF_OPERATOR</a></div><div class="ttdeci">#define MSHADOW_HALF_BF_OPERATOR(RTYPE, OP)</div><div class="ttdef"><b>Definition:</b> base.h:307</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1minimum_html_aebd011f117a63fea3cd494ee2138b634"><div class="ttname"><a href="structmshadow_1_1red_1_1minimum.html#aebd011f117a63fea3cd494ee2138b634">mshadow::red::minimum::Finalize</a></div><div class="ttdeci">static MSHADOW_XINLINE void Finalize(volatile DType &amp;dst)</div><div class="ttdoc">finalize reduction </div><div class="ttdef"><b>Definition:</b> base.h:1044</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1a2c5f8f21a24725e29edad31e3ba75ade"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a2c5f8f21a24725e29edad31e3ba75ade">mshadow::kUint64</a></div><div class="ttdef"><b>Definition:</b> base.h:370</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a64ef2d1a92579d312b18fb04aaed0d4e"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a64ef2d1a92579d312b18fb04aaed0d4e">mshadow::red::limits::PosInfValue</a></div><div class="ttdeci">MSHADOW_XINLINE DType PosInfValue(void)</div><div class="ttdoc">positive infinity of certain types </div><div class="ttdef"><b>Definition:</b> base.h:876</div></div>
<div class="ttc" id="namespacemshadow_html_a2e0671a4ac1729d7f8996ba091f8e07c"><div class="ttname"><a href="namespacemshadow.html#a2e0671a4ac1729d7f8996ba091f8e07c">mshadow::mshadow_sizeof</a></div><div class="ttdeci">size_t mshadow_sizeof(int type)</div><div class="ttdoc">get data type size from type enum </div><div class="ttdef"><b>Definition:</b> base.h:1479</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1a4fbb02e389c3126918b505cd01188368"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a4fbb02e389c3126918b505cd01188368">mshadow::kInt32</a></div><div class="ttdef"><b>Definition:</b> base.h:363</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1maximum_html_a5c74a9cf04436607f101428cb8fd4326"><div class="ttname"><a href="structmshadow_1_1red_1_1maximum.html#a5c74a9cf04436607f101428cb8fd4326">mshadow::red::maximum::Merge</a></div><div class="ttdeci">static MSHADOW_XINLINE void Merge(volatile DType &amp;dst_val, volatile DType &amp;src_val)</div><div class="ttdoc">combine the results of two reducers </div><div class="ttdef"><b>Definition:</b> base.h:981</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a3784eade98f040fe074543259fe7164e"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a3784eade98f040fe074543259fe7164e">mshadow::red::limits::NegInfValue&lt; double &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE double NegInfValue&lt; double &gt;(void)</div><div class="ttdoc">negative infinity value of double </div><div class="ttdef"><b>Definition:</b> base.h:804</div></div>
<div class="ttc" id="structmshadow_1_1op_1_1identity_html_a260f8047dca47cb16ff0adaf16f5e8e6"><div class="ttname"><a href="structmshadow_1_1op_1_1identity.html#a260f8047dca47cb16ff0adaf16f5e8e6">mshadow::op::identity::Map</a></div><div class="ttdeci">static MSHADOW_XINLINE DType Map(DType a)</div><div class="ttdoc">map a to result using defined operation </div><div class="ttdef"><b>Definition:</b> base.h:601</div></div>
<div class="ttc" id="namespacemshadow_html_abbe2dc827052234b64ab2d40a5b2fdb4a37c45177ee0fe2468d562a9e5e3e38dd"><div class="ttname"><a href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a37c45177ee0fe2468d562a9e5e3e38dd">mshadow::kNDHWC</a></div><div class="ttdef"><b>Definition:</b> base.h:497</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1ad48a252ca3e6d2cbe89f1ba570d206a7"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1ad48a252ca3e6d2cbe89f1ba570d206a7">mshadow::kUint32</a></div><div class="ttdef"><b>Definition:</b> base.h:369</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1maximum_html"><div class="ttname"><a href="structmshadow_1_1red_1_1maximum.html">mshadow::red::maximum</a></div><div class="ttdoc">maximum reducer </div><div class="ttdef"><b>Definition:</b> base.h:966</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1sum_html_abdbdd852a7eb8460458f24fea8ca7714"><div class="ttname"><a href="structmshadow_1_1red_1_1sum.html#abdbdd852a7eb8460458f24fea8ca7714">mshadow::red::sum::Merge</a></div><div class="ttdeci">static MSHADOW_XINLINE void Merge(volatile DType &amp;dst_val, volatile DType &amp;dst_residual, volatile DType &amp;src_val, volatile DType &amp;src_residual)</div><div class="ttdoc">combine the results of two reducers </div><div class="ttdef"><b>Definition:</b> base.h:923</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1">mshadow::TypeFlag</a></div><div class="ttdeci">TypeFlag</div><div class="ttdoc">data type flag </div><div class="ttdef"><b>Definition:</b> base.h:358</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_ab4d32d18fb83ed9fe3b2773e0bf8d508"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#ab4d32d18fb83ed9fe3b2773e0bf8d508">mshadow::red::limits::MaxValue&lt; int64_t &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE int64_t MaxValue&lt; int64_t &gt;(void)</div><div class="ttdoc">maximum value of int64_t </div><div class="ttdef"><b>Definition:</b> base.h:857</div></div>
<div class="ttc" id="namespacemshadow_html_abbe2dc827052234b64ab2d40a5b2fdb4a0cfb685a803481d9ff4fe19d813b261a"><div class="ttname"><a href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a0cfb685a803481d9ff4fe19d813b261a">mshadow::kNCW</a></div><div class="ttdef"><b>Definition:</b> base.h:492</div></div>
<div class="ttc" id="namespacemshadow_html_abbe2dc827052234b64ab2d40a5b2fdb4a30ea75730b725ac965fb4e43c34622d8"><div class="ttname"><a href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a30ea75730b725ac965fb4e43c34622d8">mshadow::kCDHWN</a></div><div class="ttdef"><b>Definition:</b> base.h:498</div></div>
<div class="ttc" id="structmshadow_1_1op_1_1minus_html_a29e530a31da95225c916e13f1bbcbca6"><div class="ttname"><a href="structmshadow_1_1op_1_1minus.html#a29e530a31da95225c916e13f1bbcbca6">mshadow::op::minus::Map</a></div><div class="ttdeci">static MSHADOW_XINLINE DType Map(DType a, DType b)</div><div class="ttdoc">map a, b to result using defined operation </div><div class="ttdef"><b>Definition:</b> base.h:573</div></div>
<div class="ttc" id="structmshadow_1_1op_1_1plus_html"><div class="ttname"><a href="structmshadow_1_1op_1_1plus.html">mshadow::op::plus</a></div><div class="ttdoc">plus operator </div><div class="ttdef"><b>Definition:</b> base.h:562</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1saveto_html_aaf49b727bb5fe9098081c265100cb340"><div class="ttname"><a href="structmshadow_1_1sv_1_1saveto.html#aaf49b727bb5fe9098081c265100cb340">mshadow::sv::saveto::AlphaBLAS</a></div><div class="ttdeci">static default_real_t AlphaBLAS(void)</div><div class="ttdoc">helper constant to use BLAS, alpha </div><div class="ttdef"><b>Definition:</b> base.h:616</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1a1a39d2f8230da3cb53528904c8a5fff0"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a1a39d2f8230da3cb53528904c8a5fff0">mshadow::kUint8</a></div><div class="ttdef"><b>Definition:</b> base.h:362</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1plusto_html"><div class="ttname"><a href="structmshadow_1_1sv_1_1plusto.html">mshadow::sv::plusto</a></div><div class="ttdoc">save to saver: += </div><div class="ttdef"><b>Definition:</b> base.h:623</div></div>
<div class="ttc" id="namespacemshadow_html_abbe2dc827052234b64ab2d40a5b2fdb4ae5189456ea58c60d8c546ab8bd1a2c08"><div class="ttname"><a href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4ae5189456ea58c60d8c546ab8bd1a2c08">mshadow::kCWN</a></div><div class="ttdef"><b>Definition:</b> base.h:494</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1minimum_html_af14bfabf30b3f4bffdcd0827679d0390"><div class="ttname"><a href="structmshadow_1_1red_1_1minimum.html#af14bfabf30b3f4bffdcd0827679d0390">mshadow::red::minimum::Merge</a></div><div class="ttdeci">static MSHADOW_XINLINE void Merge(volatile DType &amp;dst_val, volatile DType &amp;dst_residual, volatile DType &amp;src_val, volatile DType &amp;src_residual)</div><div class="ttdoc">combine the results of two reducers </div><div class="ttdef"><b>Definition:</b> base.h:1039</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1sum_html"><div class="ttname"><a href="structmshadow_1_1red_1_1sum.html">mshadow::red::sum</a></div><div class="ttdoc">sum reducer </div><div class="ttdef"><b>Definition:</b> base.h:898</div></div>
<div class="ttc" id="namespacemshadow_html_abbe2dc827052234b64ab2d40a5b2fdb4a3f4908b910c47da082d60aa719c43fc3"><div class="ttname"><a href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a3f4908b910c47da082d60aa719c43fc3">mshadow::kNWC</a></div><div class="ttdef"><b>Definition:</b> base.h:493</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1sum_html_aa05b8713dd5973cac465420e52f67dda"><div class="ttname"><a href="structmshadow_1_1red_1_1sum.html#aa05b8713dd5973cac465420e52f67dda">mshadow::red::sum::Merge</a></div><div class="ttdeci">static MSHADOW_XINLINE void Merge(volatile DType &amp;dst_val, volatile DType &amp;src_val)</div><div class="ttdoc">combine the results of two reducers </div><div class="ttdef"><b>Definition:</b> base.h:918</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1plusto_html_a916ea217bd0200ab7b23a4e2ac26887f"><div class="ttname"><a href="structmshadow_1_1sv_1_1plusto.html#a916ea217bd0200ab7b23a4e2ac26887f">mshadow::sv::plusto::BetaBLAS</a></div><div class="ttdeci">static default_real_t BetaBLAS(void)</div><div class="ttdoc">helper constant to use BLAS, beta </div><div class="ttdef"><b>Definition:</b> base.h:632</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1maximum_html_a1bffb78fd1c64479b82e9a4ffccab69e"><div class="ttname"><a href="structmshadow_1_1red_1_1maximum.html#a1bffb78fd1c64479b82e9a4ffccab69e">mshadow::red::maximum::SetInitValue</a></div><div class="ttdeci">static MSHADOW_XINLINE void SetInitValue(DType &amp;initv)</div><div class="ttdoc">set the initial value during reduction </div><div class="ttdef"><b>Definition:</b> base.h:1007</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_ab06124f184da5683a517e02bcf2d6b9d"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#ab06124f184da5683a517e02bcf2d6b9d">mshadow::red::limits::MinValue&lt; unsigned int &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE unsigned int MinValue&lt; unsigned int &gt;(void)</div><div class="ttdoc">minimum value of unsigned int </div><div class="ttdef"><b>Definition:</b> base.h:785</div></div>
<div class="ttc" id="structmshadow_1_1op_1_1mul_html"><div class="ttname"><a href="structmshadow_1_1op_1_1mul.html">mshadow::op::mul</a></div><div class="ttdoc">mul operator </div><div class="ttdef"><b>Definition:</b> base.h:554</div></div>
<div class="ttc" id="half_8h_html_a4068a67a48bb294a6bf436e28be90de9"><div class="ttname"><a href="half_8h.html#a4068a67a48bb294a6bf436e28be90de9">MSHADOW_HALF_SIGN_BIT</a></div><div class="ttdeci">#define MSHADOW_HALF_SIGN_BIT</div><div class="ttdef"><b>Definition:</b> half.h:370</div></div>
<div class="ttc" id="half_8h_html_acd26d7558448d4ce6889283913627b31"><div class="ttname"><a href="half_8h.html#acd26d7558448d4ce6889283913627b31">MSHADOW_HALF_MAX</a></div><div class="ttdeci">#define MSHADOW_HALF_MAX</div><div class="ttdef"><b>Definition:</b> half.h:369</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1saveto_html_a4dab404c405fe7476eadbd02e727738b"><div class="ttname"><a href="structmshadow_1_1sv_1_1saveto.html#a4dab404c405fe7476eadbd02e727738b">mshadow::sv::saveto::BetaBLAS</a></div><div class="ttdeci">static default_real_t BetaBLAS(void)</div><div class="ttdoc">helper constant to use BLAS, beta </div><div class="ttdef"><b>Definition:</b> base.h:618</div></div>
<div class="ttc" id="structmshadow_1_1DataType_html"><div class="ttname"><a href="structmshadow_1_1DataType.html">mshadow::DataType</a></div><div class="ttdef"><b>Definition:</b> base.h:375</div></div>
<div class="ttc" id="namespacemshadow_html"><div class="ttname"><a href="namespacemshadow.html">mshadow</a></div><div class="ttdoc">overloaded + operator between half_t and bf16_t </div><div class="ttdef"><b>Definition:</b> base.h:334</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1aefe5e24a51079065b7707225c9289908"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1aefe5e24a51079065b7707225c9289908">mshadow::kUint16</a></div><div class="ttdef"><b>Definition:</b> base.h:368</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1minimum_html_acbda7fe80fa3754a57b967e11a8ee44f"><div class="ttname"><a href="structmshadow_1_1red_1_1minimum.html#acbda7fe80fa3754a57b967e11a8ee44f">mshadow::red::minimum::SetInitValue</a></div><div class="ttdeci">static MSHADOW_XINLINE void SetInitValue(DType &amp;initv)</div><div class="ttdoc">set the initial value during reduction </div><div class="ttdef"><b>Definition:</b> base.h:1060</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1a37ab9e42757689b17620f5728296d5d4"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a37ab9e42757689b17620f5728296d5d4">mshadow::kFloat16</a></div><div class="ttdef"><b>Definition:</b> base.h:361</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1a2313be720271dd8ef9d3becbed309f2e"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1a2313be720271dd8ef9d3becbed309f2e">mshadow::kBfloat16</a></div><div class="ttdef"><b>Definition:</b> base.h:371</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_acc5e8630b2b3d865291c02b16c7b09c1"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#acc5e8630b2b3d865291c02b16c7b09c1">mshadow::red::limits::MaxValue&lt; bool &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE bool MaxValue&lt; bool &gt;(void)</div><div class="ttdoc">maximum value of bool </div><div class="ttdef"><b>Definition:</b> base.h:862</div></div>
<div class="ttc" id="namespacemshadow_html_a936bbfe6aeead8902973c098b87f18c1accdd431fb941a9158baa00e7c5f3dc23"><div class="ttname"><a href="namespacemshadow.html#a936bbfe6aeead8902973c098b87f18c1accdd431fb941a9158baa00e7c5f3dc23">mshadow::kInt64</a></div><div class="ttdef"><b>Definition:</b> base.h:365</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1sum_html_abd56e307635333d02fc0f22726dbed28"><div class="ttname"><a href="structmshadow_1_1red_1_1sum.html#abd56e307635333d02fc0f22726dbed28">mshadow::red::sum::Reduce</a></div><div class="ttdeci">static MSHADOW_XINLINE void Reduce(volatile DType &amp;dst, volatile DType src)</div><div class="ttdoc">do reduction into dst </div><div class="ttdef"><b>Definition:</b> base.h:901</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a853288dcb013f16211eb9ce107ccba3e"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a853288dcb013f16211eb9ce107ccba3e">mshadow::red::limits::MaxValue&lt; uint8_t &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE uint8_t MaxValue&lt; uint8_t &gt;(void)</div><div class="ttdoc">maximum value of uint8_t </div><div class="ttdef"><b>Definition:</b> base.h:842</div></div>
<div class="ttc" id="namespacemshadow_html_abbe2dc827052234b64ab2d40a5b2fdb4a6e334c4df779fcc6fa6b24411fce1289"><div class="ttname"><a href="namespacemshadow.html#abbe2dc827052234b64ab2d40a5b2fdb4a6e334c4df779fcc6fa6b24411fce1289">mshadow::kCHWN</a></div><div class="ttdef"><b>Definition:</b> base.h:490</div></div>
<div class="ttc" id="structmshadow_1_1op_1_1right_html_a9377077b54a983fd220a0ba0263227b3"><div class="ttname"><a href="structmshadow_1_1op_1_1right.html#a9377077b54a983fd220a0ba0263227b3">mshadow::op::right::Map</a></div><div class="ttdeci">static MSHADOW_XINLINE DType Map(DType a, DType b)</div><div class="ttdoc">map a, b to result using defined operation </div><div class="ttdef"><b>Definition:</b> base.h:589</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1minimum_html_a9485035d020c53f31eadf7e34adc37f0"><div class="ttname"><a href="structmshadow_1_1red_1_1minimum.html#a9485035d020c53f31eadf7e34adc37f0">mshadow::red::minimum::Merge</a></div><div class="ttdeci">static MSHADOW_XINLINE void Merge(volatile DType &amp;dst_val, volatile DType &amp;src_val)</div><div class="ttdoc">combine the results of two reducers </div><div class="ttdef"><b>Definition:</b> base.h:1034</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1maximum_html_a88b427b9289c2c00736887449ed67d0a"><div class="ttname"><a href="structmshadow_1_1red_1_1maximum.html#a88b427b9289c2c00736887449ed67d0a">mshadow::red::maximum::Merge</a></div><div class="ttdeci">static MSHADOW_XINLINE void Merge(volatile DType &amp;dst_val, volatile DType &amp;dst_residual, volatile DType &amp;src_val, volatile DType &amp;src_residual)</div><div class="ttdoc">combine the results of two reducers </div><div class="ttdef"><b>Definition:</b> base.h:986</div></div>
<div class="ttc" id="structmshadow_1_1red_1_1sum_html_a511c1d4add93f26810e6a53c0ff106d0"><div class="ttname"><a href="structmshadow_1_1red_1_1sum.html#a511c1d4add93f26810e6a53c0ff106d0">mshadow::red::sum::Finalize</a></div><div class="ttdeci">static MSHADOW_XINLINE void Finalize(volatile DType &amp;dst)</div><div class="ttdoc">finalize reduction </div><div class="ttdef"><b>Definition:</b> base.h:937</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1plusto_html_a9acc887f74cce8e18f1a86818154ca1c"><div class="ttname"><a href="structmshadow_1_1sv_1_1plusto.html#a9acc887f74cce8e18f1a86818154ca1c">mshadow::sv::plusto::AlphaBLAS</a></div><div class="ttdeci">static default_real_t AlphaBLAS(void)</div><div class="ttdoc">helper constant to use BLAS, alpha </div><div class="ttdef"><b>Definition:</b> base.h:630</div></div>
<div class="ttc" id="namespacemshadow_html_aa94c153a2f8bcd10be82a4f5598ae5b9"><div class="ttname"><a href="namespacemshadow.html#aa94c153a2f8bcd10be82a4f5598ae5b9">mshadow::openmp_index_t</a></div><div class="ttdeci">index_t openmp_index_t</div><div class="ttdoc">openmp index for linux </div><div class="ttdef"><b>Definition:</b> base.h:351</div></div>
<div class="ttc" id="structmshadow_1_1op_1_1minus_html"><div class="ttname"><a href="structmshadow_1_1op_1_1minus.html">mshadow::op::minus</a></div><div class="ttdoc">minus operator </div><div class="ttdef"><b>Definition:</b> base.h:570</div></div>
<div class="ttc" id="namespacemshadow_1_1red_1_1limits_html_a194ad52f15262c4acde6f4720f039858"><div class="ttname"><a href="namespacemshadow_1_1red_1_1limits.html#a194ad52f15262c4acde6f4720f039858">mshadow::red::limits::PosInfValue&lt; double &gt;</a></div><div class="ttdeci">MSHADOW_XINLINE double PosInfValue&lt; double &gt;(void)</div><div class="ttdoc">positive infinity value of double </div><div class="ttdef"><b>Definition:</b> base.h:886</div></div>
<div class="ttc" id="structmshadow_1_1sv_1_1divto_html_ab8864c99eea0286fce8f5a8f791f0f33"><div class="ttname"><a href="structmshadow_1_1sv_1_1divto.html#ab8864c99eea0286fce8f5a8f791f0f33">mshadow::sv::divto::OPType</a></div><div class="ttdeci">op::div OPType</div><div class="ttdoc">corresponding binary operator type </div><div class="ttdef"><b>Definition:</b> base.h:668</div></div>
<div class="ttc" id="bfloat_8h_html_ab31d5d1e2e21e0fc5dd6f40e276fdd43"><div class="ttname"><a href="bfloat_8h.html#ab31d5d1e2e21e0fc5dd6f40e276fdd43">MSHADOW_BF16_MIN</a></div><div class="ttdeci">#define MSHADOW_BF16_MIN</div><div class="ttdoc">overloaded + operator for bf16_t </div><div class="ttdef"><b>Definition:</b> bfloat.h:181</div></div>
</div><!-- fragment --></div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated on Thu Jan 5 2023 00:58:41 for mxnet by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.13
</small></address>
</body>
</html>