163 lines
92 KiB
HTML
163 lines
92 KiB
HTML
<!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.14"/>
|
|
<meta name="viewport" content="width=device-width, initial-scale=1"/>
|
|
<title>Cutlass: tile_stream.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>
|
|
<script type="text/x-mathjax-config">
|
|
MathJax.Hub.Config({
|
|
extensions: ["tex2jax.js"],
|
|
jax: ["input/TeX","output/HTML-CSS"],
|
|
});
|
|
</script><script type="text/javascript" async src="http://cdn.mathjax.org/mathjax/latest/MathJax.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">Cutlass
|
|
</div>
|
|
<div id="projectbrief">CUDA Templates for Linear Algebra Subroutines and Solvers</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<!-- end header part -->
|
|
<!-- Generated by Doxygen 1.8.14 -->
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
var searchBox = new SearchBox("searchBox", "search",false,'Search');
|
|
/* @license-end */
|
|
</script>
|
|
<script type="text/javascript" src="menudata.js"></script>
|
|
<script type="text/javascript" src="menu.js"></script>
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
$(function() {
|
|
initMenu('',true,false,'search.php','Search');
|
|
$(document).ready(function() { init_search(); });
|
|
});
|
|
/* @license-end */</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_1417ee5ebebc309c36b7962f26a92c39.html">cutlass</a></li> </ul>
|
|
</div>
|
|
</div><!-- top -->
|
|
<div class="header">
|
|
<div class="headertitle">
|
|
<div class="title">tile_stream.h</div> </div>
|
|
</div><!--header-->
|
|
<div class="contents">
|
|
<a href="tile__stream_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"> 1</span> <span class="comment">/***************************************************************************************************</span></div><div class="line"><a name="l00002"></a><span class="lineno"> 2</span> <span class="comment"> * Copyright (c) 2017-2018, NVIDIA CORPORATION. All rights reserved.</span></div><div class="line"><a name="l00003"></a><span class="lineno"> 3</span> <span class="comment"> *</span></div><div class="line"><a name="l00004"></a><span class="lineno"> 4</span> <span class="comment"> * Redistribution and use in source and binary forms, with or without modification, are permitted</span></div><div class="line"><a name="l00005"></a><span class="lineno"> 5</span> <span class="comment"> * provided that the following conditions are met:</span></div><div class="line"><a name="l00006"></a><span class="lineno"> 6</span> <span class="comment"> * * Redistributions of source code must retain the above copyright notice, this list of</span></div><div class="line"><a name="l00007"></a><span class="lineno"> 7</span> <span class="comment"> * conditions and the following disclaimer.</span></div><div class="line"><a name="l00008"></a><span class="lineno"> 8</span> <span class="comment"> * * Redistributions in binary form must reproduce the above copyright notice, this list of</span></div><div class="line"><a name="l00009"></a><span class="lineno"> 9</span> <span class="comment"> * conditions and the following disclaimer in the documentation and/or other materials</span></div><div class="line"><a name="l00010"></a><span class="lineno"> 10</span> <span class="comment"> * provided with the distribution.</span></div><div class="line"><a name="l00011"></a><span class="lineno"> 11</span> <span class="comment"> * * Neither the name of the NVIDIA CORPORATION nor the names of its contributors may be used</span></div><div class="line"><a name="l00012"></a><span class="lineno"> 12</span> <span class="comment"> * to endorse or promote products derived from this software without specific prior written</span></div><div class="line"><a name="l00013"></a><span class="lineno"> 13</span> <span class="comment"> * permission.</span></div><div class="line"><a name="l00014"></a><span class="lineno"> 14</span> <span class="comment"> *</span></div><div class="line"><a name="l00015"></a><span class="lineno"> 15</span> <span class="comment"> * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR</span></div><div class="line"><a name="l00016"></a><span class="lineno"> 16</span> <span class="comment"> * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND</span></div><div class="line"><a name="l00017"></a><span class="lineno"> 17</span> <span class="comment"> * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL NVIDIA CORPORATION BE LIABLE</span></div><div class="line"><a name="l00018"></a><span class="lineno"> 18</span> <span class="comment"> * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,</span></div><div class="line"><a name="l00019"></a><span class="lineno"> 19</span> <span class="comment"> * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;</span></div><div class="line"><a name="l00020"></a><span class="lineno"> 20</span> <span class="comment"> * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,</span></div><div class="line"><a name="l00021"></a><span class="lineno"> 21</span> <span class="comment"> * STRICT LIABILITY, OR TOR (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE</span></div><div class="line"><a name="l00022"></a><span class="lineno"> 22</span> <span class="comment"> * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.</span></div><div class="line"><a name="l00023"></a><span class="lineno"> 23</span> <span class="comment"> *</span></div><div class="line"><a name="l00024"></a><span class="lineno"> 24</span> <span class="comment"> **************************************************************************************************/</span></div><div class="line"><a name="l00030"></a><span class="lineno"> 30</span> <span class="preprocessor">#pragma once</span></div><div class="line"><a name="l00031"></a><span class="lineno"> 31</span> </div><div class="line"><a name="l00032"></a><span class="lineno"> 32</span> <span class="comment">// clang-format off</span></div><div class="line"><a name="l00033"></a><span class="lineno"> 33</span> </div><div class="line"><a name="l00034"></a><span class="lineno"> 34</span> <span class="preprocessor">#include "<a class="code" href="convert_8h.html">cutlass/convert.h</a>"</span></div><div class="line"><a name="l00035"></a><span class="lineno"> 35</span> <span class="preprocessor">#include "<a class="code" href="tile__iterator_8h.html">cutlass/tile_iterator.h</a>"</span></div><div class="line"><a name="l00036"></a><span class="lineno"> 36</span> </div><div class="line"><a name="l00038"></a><span class="lineno"> 38</span> </div><div class="line"><a name="l00039"></a><span class="lineno"> 39</span> <span class="keyword">namespace </span><a class="code" href="namespacecutlass.html">cutlass</a> {</div><div class="line"><a name="l00040"></a><span class="lineno"> 40</span> </div><div class="line"><a name="l00042"></a><span class="lineno"> 42</span> </div><div class="line"><a name="l00044"></a><span class="lineno"> 44</span> <span class="keyword">template</span> <<span class="keyword">typename</span> Iterator_, <span class="keyword">typename</span> Transformer_ = Copy<<span class="keyword">typename</span> Iterator_::Fragment> ></div><div class="line"><a name="l00045"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html"> 45</a></span> <span class="keyword">struct </span><a class="code" href="structcutlass_1_1TileLoadStream.html">TileLoadStream</a> {</div><div class="line"><a name="l00046"></a><span class="lineno"> 46</span>  <span class="comment">//</span></div><div class="line"><a name="l00047"></a><span class="lineno"> 47</span>  <span class="comment">// Type definitions</span></div><div class="line"><a name="l00048"></a><span class="lineno"> 48</span>  <span class="comment">//</span></div><div class="line"><a name="l00049"></a><span class="lineno"> 49</span> </div><div class="line"><a name="l00051"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#a21234ea1d4e0ff5cd599c763035b967b"> 51</a></span>  <span class="keyword">typedef</span> Iterator_ <a class="code" href="structcutlass_1_1TileLoadStream.html#a21234ea1d4e0ff5cd599c763035b967b">Iterator</a>;</div><div class="line"><a name="l00052"></a><span class="lineno"> 52</span> </div><div class="line"><a name="l00054"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#ad531770d336b2541c303c19148ef5cd7"> 54</a></span>  <span class="keyword">typedef</span> Transformer_ <a class="code" href="structcutlass_1_1TileLoadStream.html#ad531770d336b2541c303c19148ef5cd7">Transformer</a>;</div><div class="line"><a name="l00055"></a><span class="lineno"> 55</span> </div><div class="line"><a name="l00057"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#aea86cbd64781caabeee293cfa2070e81"> 57</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> Iterator::Fragment <a class="code" href="structcutlass_1_1TileLoadStream.html#aea86cbd64781caabeee293cfa2070e81">Fragment</a>;</div><div class="line"><a name="l00058"></a><span class="lineno"> 58</span> </div><div class="line"><a name="l00060"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#a94cde8bcdcedc934cc14de19e43375d1"> 60</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> Transformer::OutputFragment <a class="code" href="structcutlass_1_1TileLoadStream.html#a94cde8bcdcedc934cc14de19e43375d1">TransformedFragment</a>;</div><div class="line"><a name="l00061"></a><span class="lineno"> 61</span> </div><div class="line"><a name="l00063"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#a8c9256c5cdd1fd129dbcc6536375aca7"> 63</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> Iterator::TensorRef <a class="code" href="structcutlass_1_1TileLoadStream.html#a8c9256c5cdd1fd129dbcc6536375aca7">TensorRef</a>;</div><div class="line"><a name="l00064"></a><span class="lineno"> 64</span> </div><div class="line"><a name="l00066"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream_1_1PredicateVector.html"> 66</a></span>  <span class="keyword">struct </span><a class="code" href="structcutlass_1_1TileLoadStream_1_1PredicateVector.html">PredicateVector</a> {};</div><div class="line"><a name="l00067"></a><span class="lineno"> 67</span> </div><div class="line"><a name="l00069"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#a90ca6bbd882e39b5624ee0cd17e0d652"> 69</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> Iterator::Index <a class="code" href="structcutlass_1_1TileLoadStream.html#a90ca6bbd882e39b5624ee0cd17e0d652">Index</a>;</div><div class="line"><a name="l00070"></a><span class="lineno"> 70</span> </div><div class="line"><a name="l00072"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream_1_1Params.html"> 72</a></span>  <span class="keyword">struct </span><a class="code" href="structcutlass_1_1TileLoadStream_1_1Params.html">Params</a> {</div><div class="line"><a name="l00074"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream_1_1Params.html#a0430f377595718291f84ef62eb6f4e57"> 74</a></span>  <span class="keyword">typename</span> Iterator::Params <a class="code" href="structcutlass_1_1TileLoadStream_1_1Params.html#a0430f377595718291f84ef62eb6f4e57">iterator</a>;</div><div class="line"><a name="l00075"></a><span class="lineno"> 75</span> </div><div class="line"><a name="l00076"></a><span class="lineno"> 76</span>  <span class="comment">//</span></div><div class="line"><a name="l00077"></a><span class="lineno"> 77</span>  <span class="comment">// Methods</span></div><div class="line"><a name="l00078"></a><span class="lineno"> 78</span>  <span class="comment">//</span></div><div class="line"><a name="l00079"></a><span class="lineno"> 79</span> </div><div class="line"><a name="l00081"></a><span class="lineno"> 81</span>  <a class="code" href="cutlass_8h.html#a28c2443a142676d3d71effdae1a986b1">CUTLASS_HOST_DEVICE</a></div><div class="line"><a name="l00082"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream_1_1Params.html#a90772ac34f8c49f049eb62fada0a2165"> 82</a></span>  <a class="code" href="structcutlass_1_1TileLoadStream_1_1Params.html#a90772ac34f8c49f049eb62fada0a2165">Params</a>() {}</div><div class="line"><a name="l00083"></a><span class="lineno"> 83</span> </div><div class="line"><a name="l00085"></a><span class="lineno"> 85</span>  <a class="code" href="cutlass_8h.html#a28c2443a142676d3d71effdae1a986b1">CUTLASS_HOST_DEVICE</a></div><div class="line"><a name="l00086"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream_1_1Params.html#a50f136516b139f011939015c8c417ddd"> 86</a></span>  <a class="code" href="structcutlass_1_1TileLoadStream_1_1Params.html#a50f136516b139f011939015c8c417ddd">Params</a>(<span class="keyword">typename</span> Iterator::Params <span class="keyword">const</span> &_iterator) : <a class="code" href="structcutlass_1_1TileLoadStream_1_1Params.html#a0430f377595718291f84ef62eb6f4e57">iterator</a>(_iterator) {}</div><div class="line"><a name="l00087"></a><span class="lineno"> 87</span>  };</div><div class="line"><a name="l00088"></a><span class="lineno"> 88</span> </div><div class="line"><a name="l00089"></a><span class="lineno"> 89</span>  <span class="comment">//</span></div><div class="line"><a name="l00090"></a><span class="lineno"> 90</span>  <span class="comment">// Data members</span></div><div class="line"><a name="l00091"></a><span class="lineno"> 91</span>  <span class="comment">//</span></div><div class="line"><a name="l00092"></a><span class="lineno"> 92</span> </div><div class="line"><a name="l00094"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#ab6d8716c166d071615f4e78d9ac6efb8"> 94</a></span>  <a class="code" href="structcutlass_1_1TileLoadStream.html#a21234ea1d4e0ff5cd599c763035b967b">Iterator</a> <a class="code" href="structcutlass_1_1TileLoadStream.html#ab6d8716c166d071615f4e78d9ac6efb8">iterator</a>;</div><div class="line"><a name="l00095"></a><span class="lineno"> 95</span> </div><div class="line"><a name="l00097"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#a89b0f92764b5492a8d1de2c1ada60869"> 97</a></span>  <a class="code" href="structcutlass_1_1TileLoadStream.html#aea86cbd64781caabeee293cfa2070e81">Fragment</a> <a class="code" href="structcutlass_1_1TileLoadStream.html#a89b0f92764b5492a8d1de2c1ada60869">fetched_fragment</a>;</div><div class="line"><a name="l00098"></a><span class="lineno"> 98</span> </div><div class="line"><a name="l00100"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#a54399d7a42c1330ef0e756949483c552"> 100</a></span>  <a class="code" href="structcutlass_1_1TileLoadStream.html#ad531770d336b2541c303c19148ef5cd7">Transformer</a> <a class="code" href="structcutlass_1_1TileLoadStream.html#a54399d7a42c1330ef0e756949483c552">transformer</a>;</div><div class="line"><a name="l00101"></a><span class="lineno"> 101</span> </div><div class="line"><a name="l00103"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#ac61d45d91faf9d060509cf1e5c34fe01"> 103</a></span>  <a class="code" href="structcutlass_1_1TileLoadStream.html#a94cde8bcdcedc934cc14de19e43375d1">TransformedFragment</a> <a class="code" href="structcutlass_1_1TileLoadStream.html#ac61d45d91faf9d060509cf1e5c34fe01">transformed_fragment</a>;</div><div class="line"><a name="l00104"></a><span class="lineno"> 104</span> </div><div class="line"><a name="l00105"></a><span class="lineno"> 105</span>  <span class="comment">//</span></div><div class="line"><a name="l00106"></a><span class="lineno"> 106</span>  <span class="comment">// Methods</span></div><div class="line"><a name="l00107"></a><span class="lineno"> 107</span>  <span class="comment">//</span></div><div class="line"><a name="l00108"></a><span class="lineno"> 108</span> </div><div class="line"><a name="l00110"></a><span class="lineno"> 110</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00111"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#a40a9b1a87cda0f3eb6f4b3e73a4fade3"> 111</a></span>  <a class="code" href="structcutlass_1_1TileLoadStream.html#a40a9b1a87cda0f3eb6f4b3e73a4fade3">TileLoadStream</a>(<a class="code" href="structcutlass_1_1TileLoadStream_1_1Params.html">Params</a> <span class="keyword">const</span> &_params, <a class="code" href="structcutlass_1_1TileLoadStream.html#a8c9256c5cdd1fd129dbcc6536375aca7">TensorRef</a> <span class="keyword">const</span> &_ref)</div><div class="line"><a name="l00112"></a><span class="lineno"> 112</span>  : <a class="code" href="structcutlass_1_1TileLoadStream.html#ab6d8716c166d071615f4e78d9ac6efb8">iterator</a>(_params.<a class="code" href="structcutlass_1_1TileLoadStream.html#ab6d8716c166d071615f4e78d9ac6efb8">iterator</a>, _ref) {}</div><div class="line"><a name="l00113"></a><span class="lineno"> 113</span> </div><div class="line"><a name="l00115"></a><span class="lineno"> 115</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00116"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#a6b8b65772d95c30d29e7833348d06ba7"> 116</a></span>  <a class="code" href="structcutlass_1_1TileLoadStream.html#a6b8b65772d95c30d29e7833348d06ba7">TileLoadStream</a>(<a class="code" href="structcutlass_1_1TileLoadStream_1_1Params.html">Params</a> <span class="keyword">const</span> &_params,</div><div class="line"><a name="l00117"></a><span class="lineno"> 117</span>  <a class="code" href="structcutlass_1_1Coord.html">Coord<3></a> <span class="keyword">const</span> &threadblock_offset = <a class="code" href="namespacecutlass.html#a7419519fa453a121dfa5f26bf87318d9">make_Coord</a>(0, 0, 0)</div><div class="line"><a name="l00118"></a><span class="lineno"> 118</span>  ): <a class="code" href="structcutlass_1_1TileLoadStream.html#ab6d8716c166d071615f4e78d9ac6efb8">iterator</a>(_params.<a class="code" href="structcutlass_1_1TileLoadStream.html#ab6d8716c166d071615f4e78d9ac6efb8">iterator</a>, threadblock_offset) { }</div><div class="line"><a name="l00119"></a><span class="lineno"> 119</span> </div><div class="line"><a name="l00121"></a><span class="lineno"> 121</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00122"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#aed4e6a6f1bc125ea40ae04fb120d6a23"> 122</a></span>  <span class="keywordtype">void</span> <a class="code" href="structcutlass_1_1TileLoadStream.html#aed4e6a6f1bc125ea40ae04fb120d6a23">copy</a>() { <a class="code" href="structcutlass_1_1TileLoadStream.html#ab6d8716c166d071615f4e78d9ac6efb8">iterator</a>.load_post_increment(<a class="code" href="structcutlass_1_1TileLoadStream.html#a89b0f92764b5492a8d1de2c1ada60869">fetched_fragment</a>); }</div><div class="line"><a name="l00123"></a><span class="lineno"> 123</span> </div><div class="line"><a name="l00125"></a><span class="lineno"> 125</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00126"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#ac004fc2e078591ced5d4e5521dfd8627"> 126</a></span>  <span class="keywordtype">void</span> <a class="code" href="structcutlass_1_1TileLoadStream.html#ac004fc2e078591ced5d4e5521dfd8627">commit</a>() { <a class="code" href="structcutlass_1_1TileLoadStream.html#a54399d7a42c1330ef0e756949483c552">transformer</a>.transform(<a class="code" href="structcutlass_1_1TileLoadStream.html#a89b0f92764b5492a8d1de2c1ada60869">fetched_fragment</a>, <a class="code" href="structcutlass_1_1TileLoadStream.html#ac61d45d91faf9d060509cf1e5c34fe01">transformed_fragment</a>); }</div><div class="line"><a name="l00127"></a><span class="lineno"> 127</span> </div><div class="line"><a name="l00129"></a><span class="lineno"> 129</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00130"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#af2727fc0ddeffd1cdaef751140aa6093"> 130</a></span>  <a class="code" href="structcutlass_1_1TileLoadStream.html#aea86cbd64781caabeee293cfa2070e81">Fragment</a> &<a class="code" href="structcutlass_1_1TileLoadStream.html#af2727fc0ddeffd1cdaef751140aa6093">intermediate_fragment</a>() { <span class="keywordflow">return</span> <a class="code" href="structcutlass_1_1TileLoadStream.html#a89b0f92764b5492a8d1de2c1ada60869">fetched_fragment</a>; }</div><div class="line"><a name="l00131"></a><span class="lineno"> 131</span> </div><div class="line"><a name="l00133"></a><span class="lineno"> 133</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00134"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileLoadStream.html#a5b7161b2b97100c13c2c5009edd2a6be"> 134</a></span>  <a class="code" href="structcutlass_1_1TileLoadStream.html#a94cde8bcdcedc934cc14de19e43375d1">TransformedFragment</a> &<a class="code" href="structcutlass_1_1TileLoadStream.html#a5b7161b2b97100c13c2c5009edd2a6be">fragment</a>() { <span class="keywordflow">return</span> <a class="code" href="structcutlass_1_1TileLoadStream.html#ac61d45d91faf9d060509cf1e5c34fe01">transformed_fragment</a>; }</div><div class="line"><a name="l00135"></a><span class="lineno"> 135</span> };</div><div class="line"><a name="l00136"></a><span class="lineno"> 136</span> </div><div class="line"><a name="l00138"></a><span class="lineno"> 138</span> </div><div class="line"><a name="l00140"></a><span class="lineno"> 140</span> <span class="keyword">template</span> <<span class="keyword">typename</span> Iterator_, <span class="keyword">typename</span> Transformer_ = Copy<<span class="keyword">typename</span> Iterator_::Fragment> ></div><div class="line"><a name="l00141"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html"> 141</a></span> <span class="keyword">struct </span><a class="code" href="structcutlass_1_1TileStoreStream.html">TileStoreStream</a> {</div><div class="line"><a name="l00142"></a><span class="lineno"> 142</span>  <span class="comment">//</span></div><div class="line"><a name="l00143"></a><span class="lineno"> 143</span>  <span class="comment">// Type definitions</span></div><div class="line"><a name="l00144"></a><span class="lineno"> 144</span>  <span class="comment">//</span></div><div class="line"><a name="l00145"></a><span class="lineno"> 145</span> </div><div class="line"><a name="l00147"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#a35009c9a697f20fd5a7ee634de4d6c97"> 147</a></span>  <span class="keyword">typedef</span> Iterator_ <a class="code" href="structcutlass_1_1TileStoreStream.html#a35009c9a697f20fd5a7ee634de4d6c97">Iterator</a>;</div><div class="line"><a name="l00148"></a><span class="lineno"> 148</span> </div><div class="line"><a name="l00150"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#aa8c192da812ec83329350e5838838f5e"> 150</a></span>  <span class="keyword">typedef</span> Transformer_ <a class="code" href="structcutlass_1_1TileStoreStream.html#aa8c192da812ec83329350e5838838f5e">Transformer</a>;</div><div class="line"><a name="l00151"></a><span class="lineno"> 151</span> </div><div class="line"><a name="l00153"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#aea4357a67b8abef10f91a45e64840878"> 153</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> Transformer::InputFragment <a class="code" href="structcutlass_1_1TileStoreStream.html#aea4357a67b8abef10f91a45e64840878">Fragment</a>;</div><div class="line"><a name="l00154"></a><span class="lineno"> 154</span> </div><div class="line"><a name="l00156"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#ae14c71f6bb331030429d346f0140c993"> 156</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> Transformer::OutputFragment <a class="code" href="structcutlass_1_1TileStoreStream.html#ae14c71f6bb331030429d346f0140c993">TransformedFragment</a>;</div><div class="line"><a name="l00157"></a><span class="lineno"> 157</span> </div><div class="line"><a name="l00159"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#a2255d760e812cfe8e31f114cdb5793fe"> 159</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> Iterator::TensorRef <a class="code" href="structcutlass_1_1TileStoreStream.html#a2255d760e812cfe8e31f114cdb5793fe">TensorRef</a>;</div><div class="line"><a name="l00160"></a><span class="lineno"> 160</span> </div><div class="line"><a name="l00162"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream_1_1PredicateVector.html"> 162</a></span>  <span class="keyword">struct </span><a class="code" href="structcutlass_1_1TileStoreStream_1_1PredicateVector.html">PredicateVector</a> {};</div><div class="line"><a name="l00163"></a><span class="lineno"> 163</span> </div><div class="line"><a name="l00165"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#aa0e894a30d3a979ac56e5134360a08f4"> 165</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> Iterator::Index <a class="code" href="structcutlass_1_1TileStoreStream.html#aa0e894a30d3a979ac56e5134360a08f4">Index</a>;</div><div class="line"><a name="l00166"></a><span class="lineno"> 166</span> </div><div class="line"><a name="l00168"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream_1_1Params.html"> 168</a></span>  <span class="keyword">struct </span><a class="code" href="structcutlass_1_1TileStoreStream_1_1Params.html">Params</a> {</div><div class="line"><a name="l00170"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream_1_1Params.html#acd106661221997d7c5943daac8eb5088"> 170</a></span>  <span class="keyword">typename</span> Iterator::Params <a class="code" href="structcutlass_1_1TileStoreStream_1_1Params.html#acd106661221997d7c5943daac8eb5088">iterator</a>;</div><div class="line"><a name="l00171"></a><span class="lineno"> 171</span> </div><div class="line"><a name="l00172"></a><span class="lineno"> 172</span>  <span class="comment">//</span></div><div class="line"><a name="l00173"></a><span class="lineno"> 173</span>  <span class="comment">// Methods</span></div><div class="line"><a name="l00174"></a><span class="lineno"> 174</span>  <span class="comment">//</span></div><div class="line"><a name="l00175"></a><span class="lineno"> 175</span> </div><div class="line"><a name="l00177"></a><span class="lineno"> 177</span>  <a class="code" href="cutlass_8h.html#a28c2443a142676d3d71effdae1a986b1">CUTLASS_HOST_DEVICE</a></div><div class="line"><a name="l00178"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream_1_1Params.html#adfa2399bf13cdff16b7bfe1cb0dd2bd9"> 178</a></span>  <a class="code" href="structcutlass_1_1TileStoreStream_1_1Params.html#adfa2399bf13cdff16b7bfe1cb0dd2bd9">Params</a>() {}</div><div class="line"><a name="l00179"></a><span class="lineno"> 179</span> </div><div class="line"><a name="l00181"></a><span class="lineno"> 181</span>  <a class="code" href="cutlass_8h.html#a28c2443a142676d3d71effdae1a986b1">CUTLASS_HOST_DEVICE</a></div><div class="line"><a name="l00182"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream_1_1Params.html#acc400568f7694f818b5afbb109bd2e63"> 182</a></span>  <a class="code" href="structcutlass_1_1TileStoreStream_1_1Params.html#acc400568f7694f818b5afbb109bd2e63">Params</a>(<span class="keyword">typename</span> Iterator::Params <span class="keyword">const</span> &_iterator) : <a class="code" href="structcutlass_1_1TileStoreStream_1_1Params.html#acd106661221997d7c5943daac8eb5088">iterator</a>(_iterator) {}</div><div class="line"><a name="l00183"></a><span class="lineno"> 183</span>  };</div><div class="line"><a name="l00184"></a><span class="lineno"> 184</span> </div><div class="line"><a name="l00185"></a><span class="lineno"> 185</span>  <span class="comment">//</span></div><div class="line"><a name="l00186"></a><span class="lineno"> 186</span>  <span class="comment">// Data members</span></div><div class="line"><a name="l00187"></a><span class="lineno"> 187</span>  <span class="comment">//</span></div><div class="line"><a name="l00188"></a><span class="lineno"> 188</span> </div><div class="line"><a name="l00190"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#a601a296ec830e9b98aca9d5cf4b4010c"> 190</a></span>  <a class="code" href="structcutlass_1_1TileStoreStream.html#a35009c9a697f20fd5a7ee634de4d6c97">Iterator</a> <a class="code" href="structcutlass_1_1TileStoreStream.html#a601a296ec830e9b98aca9d5cf4b4010c">iterator</a>;</div><div class="line"><a name="l00191"></a><span class="lineno"> 191</span> </div><div class="line"><a name="l00193"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#a61d57147150bffda0c1662d6131a3934"> 193</a></span>  <a class="code" href="structcutlass_1_1TileStoreStream.html#aa8c192da812ec83329350e5838838f5e">Transformer</a> <a class="code" href="structcutlass_1_1TileStoreStream.html#a61d57147150bffda0c1662d6131a3934">transformer</a>;</div><div class="line"><a name="l00194"></a><span class="lineno"> 194</span> </div><div class="line"><a name="l00196"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#a0880c28b3ec82d38571ed332451c8d6a"> 196</a></span>  <a class="code" href="structcutlass_1_1TileStoreStream.html#aea4357a67b8abef10f91a45e64840878">Fragment</a> <a class="code" href="structcutlass_1_1TileStoreStream.html#a0880c28b3ec82d38571ed332451c8d6a">source_fragment</a>;</div><div class="line"><a name="l00197"></a><span class="lineno"> 197</span> </div><div class="line"><a name="l00199"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#aeb5be2edcc35c7876abe5234663f9c48"> 199</a></span>  <a class="code" href="structcutlass_1_1TileStoreStream.html#ae14c71f6bb331030429d346f0140c993">TransformedFragment</a> <a class="code" href="structcutlass_1_1TileStoreStream.html#aeb5be2edcc35c7876abe5234663f9c48">transformed_fragment</a>;</div><div class="line"><a name="l00200"></a><span class="lineno"> 200</span> </div><div class="line"><a name="l00201"></a><span class="lineno"> 201</span>  <span class="comment">//</span></div><div class="line"><a name="l00202"></a><span class="lineno"> 202</span>  <span class="comment">// Methods</span></div><div class="line"><a name="l00203"></a><span class="lineno"> 203</span>  <span class="comment">//</span></div><div class="line"><a name="l00204"></a><span class="lineno"> 204</span> </div><div class="line"><a name="l00206"></a><span class="lineno"> 206</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00207"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#af85b3acfc29e41ee605df64b09698a8b"> 207</a></span>  <a class="code" href="structcutlass_1_1TileStoreStream.html#af85b3acfc29e41ee605df64b09698a8b">TileStoreStream</a>(<a class="code" href="structcutlass_1_1TileStoreStream_1_1Params.html">Params</a> <span class="keyword">const</span> &_params, <a class="code" href="structcutlass_1_1TileStoreStream.html#a2255d760e812cfe8e31f114cdb5793fe">TensorRef</a> <span class="keyword">const</span> &_ref)</div><div class="line"><a name="l00208"></a><span class="lineno"> 208</span>  : <a class="code" href="structcutlass_1_1TileStoreStream.html#a601a296ec830e9b98aca9d5cf4b4010c">iterator</a>(_params.<a class="code" href="structcutlass_1_1TileStoreStream.html#a601a296ec830e9b98aca9d5cf4b4010c">iterator</a>, _ref) {}</div><div class="line"><a name="l00209"></a><span class="lineno"> 209</span> </div><div class="line"><a name="l00211"></a><span class="lineno"> 211</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00212"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#a08e7e7bf74e1e0d670dd6a4e65d14084"> 212</a></span>  <a class="code" href="structcutlass_1_1TileStoreStream.html#a08e7e7bf74e1e0d670dd6a4e65d14084">TileStoreStream</a>(<a class="code" href="structcutlass_1_1TileStoreStream_1_1Params.html">Params</a> <span class="keyword">const</span> &_params,</div><div class="line"><a name="l00213"></a><span class="lineno"> 213</span>  <a class="code" href="structcutlass_1_1Coord.html">Coord<3></a> <span class="keyword">const</span> &threadblock_offset = <a class="code" href="namespacecutlass.html#a7419519fa453a121dfa5f26bf87318d9">make_Coord</a>(0, 0, 0)</div><div class="line"><a name="l00214"></a><span class="lineno"> 214</span>  ): <a class="code" href="structcutlass_1_1TileStoreStream.html#a601a296ec830e9b98aca9d5cf4b4010c">iterator</a>(_params.<a class="code" href="structcutlass_1_1TileStoreStream.html#a601a296ec830e9b98aca9d5cf4b4010c">iterator</a>, threadblock_offset) { }</div><div class="line"><a name="l00215"></a><span class="lineno"> 215</span> </div><div class="line"><a name="l00217"></a><span class="lineno"> 217</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00218"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#a50b6b5bd08fd83baa36c3dc4461ca009"> 218</a></span>  <span class="keywordtype">void</span> <a class="code" href="structcutlass_1_1TileStoreStream.html#a50b6b5bd08fd83baa36c3dc4461ca009">copy</a>() {</div><div class="line"><a name="l00219"></a><span class="lineno"> 219</span> </div><div class="line"><a name="l00220"></a><span class="lineno"> 220</span>  <a class="code" href="structcutlass_1_1TileStoreStream.html#a61d57147150bffda0c1662d6131a3934">transformer</a>.transform(<a class="code" href="structcutlass_1_1TileStoreStream.html#a0880c28b3ec82d38571ed332451c8d6a">source_fragment</a>, <a class="code" href="structcutlass_1_1TileStoreStream.html#aeb5be2edcc35c7876abe5234663f9c48">transformed_fragment</a>);</div><div class="line"><a name="l00221"></a><span class="lineno"> 221</span>  <a class="code" href="structcutlass_1_1TileStoreStream.html#a601a296ec830e9b98aca9d5cf4b4010c">iterator</a>.store_post_increment(<a class="code" href="structcutlass_1_1TileStoreStream.html#aeb5be2edcc35c7876abe5234663f9c48">transformed_fragment</a>);</div><div class="line"><a name="l00222"></a><span class="lineno"> 222</span>  }</div><div class="line"><a name="l00223"></a><span class="lineno"> 223</span> </div><div class="line"><a name="l00225"></a><span class="lineno"> 225</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00226"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#aa0f3c75e59054d6229de159474c9c978"> 226</a></span>  <span class="keywordtype">void</span> <a class="code" href="structcutlass_1_1TileStoreStream.html#aa0f3c75e59054d6229de159474c9c978">copy</a>(<a class="code" href="structcutlass_1_1TileStoreStream.html#aea4357a67b8abef10f91a45e64840878">Fragment</a> <span class="keyword">const</span> &frag) {</div><div class="line"><a name="l00227"></a><span class="lineno"> 227</span>  <a class="code" href="structcutlass_1_1TileStoreStream.html#a0880c28b3ec82d38571ed332451c8d6a">source_fragment</a> = frag;</div><div class="line"><a name="l00228"></a><span class="lineno"> 228</span>  <a class="code" href="structcutlass_1_1TileStoreStream.html#a50b6b5bd08fd83baa36c3dc4461ca009">copy</a>();</div><div class="line"><a name="l00229"></a><span class="lineno"> 229</span>  }</div><div class="line"><a name="l00230"></a><span class="lineno"> 230</span> </div><div class="line"><a name="l00232"></a><span class="lineno"> 232</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00233"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#ab5176fc539364fdf63647dc33020f579"> 233</a></span>  <span class="keywordtype">void</span> <a class="code" href="structcutlass_1_1TileStoreStream.html#ab5176fc539364fdf63647dc33020f579">commit</a>() {}</div><div class="line"><a name="l00234"></a><span class="lineno"> 234</span> </div><div class="line"><a name="l00236"></a><span class="lineno"> 236</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00237"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#ad6ff1786f85d64053ece0ac8ae9a92b5"> 237</a></span>  <a class="code" href="structcutlass_1_1TileStoreStream.html#aea4357a67b8abef10f91a45e64840878">Fragment</a> &<a class="code" href="structcutlass_1_1TileStoreStream.html#ad6ff1786f85d64053ece0ac8ae9a92b5">fragment</a>() { <span class="keywordflow">return</span> <a class="code" href="structcutlass_1_1TileStoreStream.html#a0880c28b3ec82d38571ed332451c8d6a">source_fragment</a>; }</div><div class="line"><a name="l00238"></a><span class="lineno"> 238</span> </div><div class="line"><a name="l00240"></a><span class="lineno"> 240</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00241"></a><span class="lineno"><a class="line" href="structcutlass_1_1TileStoreStream.html#aff77aed0f1b1583b01a427fc935c5d71"> 241</a></span>  <a class="code" href="structcutlass_1_1TileStoreStream.html#ae14c71f6bb331030429d346f0140c993">TransformedFragment</a> &<a class="code" href="structcutlass_1_1TileStoreStream.html#aff77aed0f1b1583b01a427fc935c5d71">intermediate_fragment</a>() { <span class="keywordflow">return</span> <a class="code" href="structcutlass_1_1TileStoreStream.html#aeb5be2edcc35c7876abe5234663f9c48">transformed_fragment</a>; }</div><div class="line"><a name="l00242"></a><span class="lineno"> 242</span> };</div><div class="line"><a name="l00243"></a><span class="lineno"> 243</span> </div><div class="line"><a name="l00245"></a><span class="lineno"> 245</span> </div><div class="line"><a name="l00247"></a><span class="lineno"> 247</span> <span class="keyword">template</span> <<span class="keyword">typename</span> Iterator_,</div><div class="line"><a name="l00248"></a><span class="lineno"> 248</span>  <span class="keyword">typename</span> PredicateFunctor_ =</div><div class="line"><a name="l00249"></a><span class="lineno"> 249</span>  RegularTilePredicateFunctor<typename Iterator_::Traits::Delta>,</div><div class="line"><a name="l00250"></a><span class="lineno"> 250</span>  <span class="keyword">typename</span> Transformer_ = Copy<typename Iterator_::Fragment> ></div><div class="line"><a name="l00251"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileLoadStream.html"> 251</a></span> <span class="keyword">struct </span><a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html">PredicatedTileLoadStream</a> : <span class="keyword">public</span> <a class="code" href="structcutlass_1_1TileLoadStream.html">TileLoadStream</a><Iterator_, Transformer_> {</div><div class="line"><a name="l00252"></a><span class="lineno"> 252</span>  <span class="comment">//</span></div><div class="line"><a name="l00253"></a><span class="lineno"> 253</span>  <span class="comment">// Type definitions</span></div><div class="line"><a name="l00254"></a><span class="lineno"> 254</span>  <span class="comment">//</span></div><div class="line"><a name="l00255"></a><span class="lineno"> 255</span> </div><div class="line"><a name="l00256"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileLoadStream.html#ac7f57248d3e10c9309f042e5d41440c1"> 256</a></span>  <span class="keyword">typedef</span> <a class="code" href="structcutlass_1_1TileLoadStream.html">TileLoadStream<Iterator_, Transformer_></a> <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#ac7f57248d3e10c9309f042e5d41440c1">Base</a>;</div><div class="line"><a name="l00257"></a><span class="lineno"> 257</span> </div><div class="line"><a name="l00259"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileLoadStream.html#a1f2314aa062360b249b7c57c39af5430"> 259</a></span>  <span class="keyword">typedef</span> Iterator_ <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#a1f2314aa062360b249b7c57c39af5430">Iterator</a>;</div><div class="line"><a name="l00260"></a><span class="lineno"> 260</span> </div><div class="line"><a name="l00262"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileLoadStream.html#aedafb6329f8c484071e04ffd8949edc5"> 262</a></span>  <span class="keyword">typedef</span> PredicateFunctor_ <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#aedafb6329f8c484071e04ffd8949edc5">PredicateFunctor</a>;</div><div class="line"><a name="l00263"></a><span class="lineno"> 263</span> </div><div class="line"><a name="l00265"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileLoadStream.html#a9f79fd30231825b38694bf7c1d12ec2a"> 265</a></span>  <span class="keyword">typedef</span> Transformer_ <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#a9f79fd30231825b38694bf7c1d12ec2a">Transformer</a>;</div><div class="line"><a name="l00266"></a><span class="lineno"> 266</span> </div><div class="line"><a name="l00268"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileLoadStream.html#a7f802c4c733375d0a63f91c58196e6a0"> 268</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="structcutlass_1_1TileLoadStream.html#aea86cbd64781caabeee293cfa2070e81">Base::Fragment</a> <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#a7f802c4c733375d0a63f91c58196e6a0">Fragment</a>;</div><div class="line"><a name="l00269"></a><span class="lineno"> 269</span> </div><div class="line"><a name="l00271"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileLoadStream.html#adeb35451885c1c4fb930ae8c914ceb20"> 271</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="structcutlass_1_1TileLoadStream.html#a94cde8bcdcedc934cc14de19e43375d1">Base::TransformedFragment</a> <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#adeb35451885c1c4fb930ae8c914ceb20">TransformedFragment</a>;</div><div class="line"><a name="l00272"></a><span class="lineno"> 272</span> </div><div class="line"><a name="l00274"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileLoadStream.html#a3af1a02201f53d4d09adc483fdcc23a6"> 274</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="structcutlass_1_1TileLoadStream_1_1Params.html">Base::Params</a> <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#a3af1a02201f53d4d09adc483fdcc23a6">Params</a>;</div><div class="line"><a name="l00275"></a><span class="lineno"> 275</span> </div><div class="line"><a name="l00276"></a><span class="lineno"> 276</span>  <span class="comment">//</span></div><div class="line"><a name="l00277"></a><span class="lineno"> 277</span>  <span class="comment">// Data members</span></div><div class="line"><a name="l00278"></a><span class="lineno"> 278</span>  <span class="comment">//</span></div><div class="line"><a name="l00279"></a><span class="lineno"> 279</span> </div><div class="line"><a name="l00281"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileLoadStream.html#a8f8c7c54dba8a0c8cd0799b89130564f"> 281</a></span>  <span class="keyword">typename</span> Iterator::PredicateVector <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#a8f8c7c54dba8a0c8cd0799b89130564f">predicates</a>;</div><div class="line"><a name="l00282"></a><span class="lineno"> 282</span> </div><div class="line"><a name="l00283"></a><span class="lineno"> 283</span>  <span class="comment">//</span></div><div class="line"><a name="l00284"></a><span class="lineno"> 284</span>  <span class="comment">// Methods</span></div><div class="line"><a name="l00285"></a><span class="lineno"> 285</span>  <span class="comment">//</span></div><div class="line"><a name="l00286"></a><span class="lineno"> 286</span> </div><div class="line"><a name="l00288"></a><span class="lineno"> 288</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00289"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileLoadStream.html#a672a8883d16eff4ecc90dc79162084d3"> 289</a></span>  <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#a672a8883d16eff4ecc90dc79162084d3">PredicatedTileLoadStream</a>(<a class="code" href="structcutlass_1_1TileLoadStream_1_1Params.html">Params</a> <span class="keyword">const</span> &_params,</div><div class="line"><a name="l00290"></a><span class="lineno"> 290</span>  <a class="code" href="structcutlass_1_1Coord.html">Coord<3></a> <span class="keyword">const</span> &bounds,</div><div class="line"><a name="l00291"></a><span class="lineno"> 291</span>  <a class="code" href="structcutlass_1_1Coord.html">Coord<3></a> <span class="keyword">const</span> &threadblock_offset = <a class="code" href="namespacecutlass.html#a7419519fa453a121dfa5f26bf87318d9">make_Coord</a>(0, 0, 0))</div><div class="line"><a name="l00292"></a><span class="lineno"> 292</span>  : <a class="code" href="structcutlass_1_1TileLoadStream.html">Base</a>(_params, threadblock_offset) {</div><div class="line"><a name="l00293"></a><span class="lineno"> 293</span>  this->iterator.initialize_predicates(</div><div class="line"><a name="l00294"></a><span class="lineno"> 294</span>  <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#a8f8c7c54dba8a0c8cd0799b89130564f">predicates</a>.begin(), <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#aedafb6329f8c484071e04ffd8949edc5">PredicateFunctor</a>(bounds), threadblock_offset);</div><div class="line"><a name="l00295"></a><span class="lineno"> 295</span>  }</div><div class="line"><a name="l00296"></a><span class="lineno"> 296</span> </div><div class="line"><a name="l00298"></a><span class="lineno"> 298</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00299"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileLoadStream.html#a60a03c95452fe627477933d60815f7cb"> 299</a></span>  <span class="keywordtype">void</span> <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#a60a03c95452fe627477933d60815f7cb">copy</a>() { this->iterator.load_post_increment(this->fetched_fragment, <a class="code" href="structcutlass_1_1PredicatedTileLoadStream.html#a8f8c7c54dba8a0c8cd0799b89130564f">predicates</a>.begin()); }</div><div class="line"><a name="l00300"></a><span class="lineno"> 300</span> };</div><div class="line"><a name="l00301"></a><span class="lineno"> 301</span> </div><div class="line"><a name="l00303"></a><span class="lineno"> 303</span> </div><div class="line"><a name="l00305"></a><span class="lineno"> 305</span> <span class="keyword">template</span> <<span class="keyword">typename</span> Iterator_,</div><div class="line"><a name="l00306"></a><span class="lineno"> 306</span>  <span class="keyword">typename</span> PredicateFunctor_ =</div><div class="line"><a name="l00307"></a><span class="lineno"> 307</span>  RegularTilePredicateFunctor<typename Iterator_::Traits::Delta>,</div><div class="line"><a name="l00308"></a><span class="lineno"> 308</span>  <span class="keyword">typename</span> Transformer_ = Copy<typename Iterator_::Fragment> ></div><div class="line"><a name="l00309"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html"> 309</a></span> <span class="keyword">struct </span><a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html">PredicatedTileStoreStream</a> : <span class="keyword">public</span> <a class="code" href="structcutlass_1_1TileStoreStream.html">TileStoreStream</a><Iterator_, Transformer_> {</div><div class="line"><a name="l00310"></a><span class="lineno"> 310</span>  <span class="comment">//</span></div><div class="line"><a name="l00311"></a><span class="lineno"> 311</span>  <span class="comment">// Type definitions</span></div><div class="line"><a name="l00312"></a><span class="lineno"> 312</span>  <span class="comment">//</span></div><div class="line"><a name="l00313"></a><span class="lineno"> 313</span> </div><div class="line"><a name="l00314"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html#afc320f4d29f05102e9de0064ca31e49b"> 314</a></span>  <span class="keyword">typedef</span> <a class="code" href="structcutlass_1_1TileStoreStream.html">TileStoreStream<Iterator_, Transformer_></a> <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#afc320f4d29f05102e9de0064ca31e49b">Base</a>;</div><div class="line"><a name="l00315"></a><span class="lineno"> 315</span> </div><div class="line"><a name="l00317"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html#a0ba9097d54f3ba7b7dab12012631fa76"> 317</a></span>  <span class="keyword">typedef</span> Iterator_ <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#a0ba9097d54f3ba7b7dab12012631fa76">Iterator</a>;</div><div class="line"><a name="l00318"></a><span class="lineno"> 318</span> </div><div class="line"><a name="l00320"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html#aa6d4c263e057678b9f1b8ba6a9feb59f"> 320</a></span>  <span class="keyword">typedef</span> PredicateFunctor_ <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#aa6d4c263e057678b9f1b8ba6a9feb59f">PredicateFunctor</a>;</div><div class="line"><a name="l00321"></a><span class="lineno"> 321</span> </div><div class="line"><a name="l00323"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html#a0f91f328ed2b6bd65ef4eeafe18f9afd"> 323</a></span>  <span class="keyword">typedef</span> Transformer_ <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#a0f91f328ed2b6bd65ef4eeafe18f9afd">Transformer</a>;</div><div class="line"><a name="l00324"></a><span class="lineno"> 324</span> </div><div class="line"><a name="l00326"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html#a6c9737f5b09e7eb1aa7daabb00ae2e69"> 326</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="structcutlass_1_1TileStoreStream.html#aea4357a67b8abef10f91a45e64840878">Base::Fragment</a> <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#a6c9737f5b09e7eb1aa7daabb00ae2e69">Fragment</a>;</div><div class="line"><a name="l00327"></a><span class="lineno"> 327</span> </div><div class="line"><a name="l00329"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html#af349831b19bb91d414a83c67d14f6927"> 329</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="structcutlass_1_1TileStoreStream.html#ae14c71f6bb331030429d346f0140c993">Base::TransformedFragment</a> <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#af349831b19bb91d414a83c67d14f6927">TransformedFragment</a>;</div><div class="line"><a name="l00330"></a><span class="lineno"> 330</span> </div><div class="line"><a name="l00332"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html#ad0c7a51f1b98111ce332ed906601a4ba"> 332</a></span>  <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="structcutlass_1_1TileStoreStream_1_1Params.html">Base::Params</a> <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#ad0c7a51f1b98111ce332ed906601a4ba">Params</a>;</div><div class="line"><a name="l00333"></a><span class="lineno"> 333</span> </div><div class="line"><a name="l00334"></a><span class="lineno"> 334</span>  <span class="comment">//</span></div><div class="line"><a name="l00335"></a><span class="lineno"> 335</span>  <span class="comment">// Data members</span></div><div class="line"><a name="l00336"></a><span class="lineno"> 336</span>  <span class="comment">//</span></div><div class="line"><a name="l00337"></a><span class="lineno"> 337</span> </div><div class="line"><a name="l00339"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html#a2ecdfa152dcf7b3acaf8767f3e69cfbe"> 339</a></span>  <span class="keyword">typename</span> Iterator::PredicateVector <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#a2ecdfa152dcf7b3acaf8767f3e69cfbe">predicates</a>;</div><div class="line"><a name="l00340"></a><span class="lineno"> 340</span> </div><div class="line"><a name="l00341"></a><span class="lineno"> 341</span>  <span class="comment">//</span></div><div class="line"><a name="l00342"></a><span class="lineno"> 342</span>  <span class="comment">// Methods</span></div><div class="line"><a name="l00343"></a><span class="lineno"> 343</span>  <span class="comment">//</span></div><div class="line"><a name="l00344"></a><span class="lineno"> 344</span> </div><div class="line"><a name="l00346"></a><span class="lineno"> 346</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00347"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html#ac4aafc6bcc6cf3bff5b31b9cd60fd667"> 347</a></span>  <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#ac4aafc6bcc6cf3bff5b31b9cd60fd667">PredicatedTileStoreStream</a>(<a class="code" href="structcutlass_1_1TileStoreStream_1_1Params.html">Params</a> <span class="keyword">const</span> &_params,</div><div class="line"><a name="l00348"></a><span class="lineno"> 348</span>  <a class="code" href="structcutlass_1_1Coord.html">Coord<3></a> <span class="keyword">const</span> &bounds,</div><div class="line"><a name="l00349"></a><span class="lineno"> 349</span>  <a class="code" href="structcutlass_1_1Coord.html">Coord<3></a> <span class="keyword">const</span> &threadblock_offset = <a class="code" href="namespacecutlass.html#a7419519fa453a121dfa5f26bf87318d9">make_Coord</a>(0, 0, 0))</div><div class="line"><a name="l00350"></a><span class="lineno"> 350</span>  : <a class="code" href="structcutlass_1_1TileStoreStream.html">Base</a>(_params, threadblock_offset) {</div><div class="line"><a name="l00351"></a><span class="lineno"> 351</span>  this->iterator.initialize_predicates(</div><div class="line"><a name="l00352"></a><span class="lineno"> 352</span>  <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#a2ecdfa152dcf7b3acaf8767f3e69cfbe">predicates</a>.begin(), <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#aa6d4c263e057678b9f1b8ba6a9feb59f">PredicateFunctor</a>(bounds), threadblock_offset);</div><div class="line"><a name="l00353"></a><span class="lineno"> 353</span>  }</div><div class="line"><a name="l00354"></a><span class="lineno"> 354</span> </div><div class="line"><a name="l00356"></a><span class="lineno"> 356</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00357"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html#ae84437a66097189406c2090d88a79350"> 357</a></span>  <span class="keywordtype">void</span> <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#ae84437a66097189406c2090d88a79350">copy</a>() {</div><div class="line"><a name="l00358"></a><span class="lineno"> 358</span>  this->transformer.transform(this->source_fragment, this->transformed_fragment);</div><div class="line"><a name="l00359"></a><span class="lineno"> 359</span>  this->iterator.store_post_increment(this->transformed_fragment, <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#a2ecdfa152dcf7b3acaf8767f3e69cfbe">predicates</a>.begin());</div><div class="line"><a name="l00360"></a><span class="lineno"> 360</span>  }</div><div class="line"><a name="l00361"></a><span class="lineno"> 361</span> </div><div class="line"><a name="l00363"></a><span class="lineno"> 363</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00364"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html#a1d33da4593ae68e6301df54b310a70a0"> 364</a></span>  <span class="keywordtype">void</span> <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#a1d33da4593ae68e6301df54b310a70a0">copy</a>(<a class="code" href="structcutlass_1_1TileStoreStream.html#aea4357a67b8abef10f91a45e64840878">Fragment</a> <span class="keyword">const</span> &frag) {</div><div class="line"><a name="l00365"></a><span class="lineno"> 365</span>  this->source_fragment = frag;</div><div class="line"><a name="l00366"></a><span class="lineno"> 366</span>  <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#ae84437a66097189406c2090d88a79350">copy</a>();</div><div class="line"><a name="l00367"></a><span class="lineno"> 367</span>  }</div><div class="line"><a name="l00368"></a><span class="lineno"> 368</span> </div><div class="line"><a name="l00370"></a><span class="lineno"> 370</span>  CUTLASS_DEVICE</div><div class="line"><a name="l00371"></a><span class="lineno"><a class="line" href="structcutlass_1_1PredicatedTileStoreStream.html#a165a0d486f53fb2315d4e555c9f59891"> 371</a></span>  <span class="keywordtype">void</span> <a class="code" href="structcutlass_1_1PredicatedTileStoreStream.html#a165a0d486f53fb2315d4e555c9f59891">commit</a>() {}</div><div class="line"><a name="l00372"></a><span class="lineno"> 372</span> };</div><div class="line"><a name="l00373"></a><span class="lineno"> 373</span> </div><div class="line"><a name="l00375"></a><span class="lineno"> 375</span> </div><div class="line"><a name="l00376"></a><span class="lineno"> 376</span> } <span class="comment">// namespace cutlass</span></div><div class="line"><a name="l00377"></a><span class="lineno"> 377</span> </div><div class="line"><a name="l00378"></a><span class="lineno"> 378</span> <span class="comment">// clang-format on</span></div><div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html_af349831b19bb91d414a83c67d14f6927"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html#af349831b19bb91d414a83c67d14f6927">cutlass::PredicatedTileStoreStream::TransformedFragment</a></div><div class="ttdeci">Base::TransformedFragment TransformedFragment</div><div class="ttdoc">Output fragment from transformer. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:329</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_a5b7161b2b97100c13c2c5009edd2a6be"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#a5b7161b2b97100c13c2c5009edd2a6be">cutlass::TileLoadStream::fragment</a></div><div class="ttdeci">CUTLASS_DEVICE TransformedFragment & fragment()</div><div class="ttdoc">Accesses the loaded, transformed fragment. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:134</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html_a1d33da4593ae68e6301df54b310a70a0"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html#a1d33da4593ae68e6301df54b310a70a0">cutlass::PredicatedTileStoreStream::copy</a></div><div class="ttdeci">CUTLASS_DEVICE void copy(Fragment const &frag)</div><div class="ttdoc">Stores the fragment and increments the iterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:364</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_ad6ff1786f85d64053ece0ac8ae9a92b5"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#ad6ff1786f85d64053ece0ac8ae9a92b5">cutlass::TileStoreStream::fragment</a></div><div class="ttdeci">CUTLASS_DEVICE Fragment & fragment()</div><div class="ttdoc">Accesses the transformed fragment. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:237</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_aed4e6a6f1bc125ea40ae04fb120d6a23"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#aed4e6a6f1bc125ea40ae04fb120d6a23">cutlass::TileLoadStream::copy</a></div><div class="ttdeci">CUTLASS_DEVICE void copy()</div><div class="ttdoc">Loads a tile and increments the iterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:122</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html_ae84437a66097189406c2090d88a79350"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html#ae84437a66097189406c2090d88a79350">cutlass::PredicatedTileStoreStream::copy</a></div><div class="ttdeci">CUTLASS_DEVICE void copy()</div><div class="ttdoc">Stores the fragment and increments the iterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:357</div></div>
|
|
<div class="ttc" id="namespacecutlass_html"><div class="ttname"><a href="namespacecutlass.html">cutlass</a></div><div class="ttdef"><b>Definition:</b> convert.h:33</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_aea4357a67b8abef10f91a45e64840878"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#aea4357a67b8abef10f91a45e64840878">cutlass::TileStoreStream::Fragment</a></div><div class="ttdeci">Transformer::InputFragment Fragment</div><div class="ttdoc">Source fragment. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:153</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileLoadStream_html_a8f8c7c54dba8a0c8cd0799b89130564f"><div class="ttname"><a href="structcutlass_1_1PredicatedTileLoadStream.html#a8f8c7c54dba8a0c8cd0799b89130564f">cutlass::PredicatedTileLoadStream::predicates</a></div><div class="ttdeci">Iterator::PredicateVector predicates</div><div class="ttdoc">Predicates. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:281</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_aa0f3c75e59054d6229de159474c9c978"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#aa0f3c75e59054d6229de159474c9c978">cutlass::TileStoreStream::copy</a></div><div class="ttdeci">CUTLASS_DEVICE void copy(Fragment const &frag)</div><div class="ttdoc">Stores a fragment and increments the iterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:226</div></div>
|
|
<div class="ttc" id="tile__iterator_8h_html"><div class="ttname"><a href="tile__iterator_8h.html">tile_iterator.h</a></div><div class="ttdoc">Defines the Tile Traits concept and iterators for loading and storing to tiles efficiently. </div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html_a0ba9097d54f3ba7b7dab12012631fa76"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html#a0ba9097d54f3ba7b7dab12012631fa76">cutlass::PredicatedTileStoreStream::Iterator</a></div><div class="ttdeci">Iterator_ Iterator</div><div class="ttdoc">TileLoadIterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:317</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_a2255d760e812cfe8e31f114cdb5793fe"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#a2255d760e812cfe8e31f114cdb5793fe">cutlass::TileStoreStream::TensorRef</a></div><div class="ttdeci">Iterator::TensorRef TensorRef</div><div class="ttdoc">Tensor reference expected by the underlying iterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:159</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_a21234ea1d4e0ff5cd599c763035b967b"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#a21234ea1d4e0ff5cd599c763035b967b">cutlass::TileLoadStream::Iterator</a></div><div class="ttdeci">Iterator_ Iterator</div><div class="ttdoc">TileLoadIterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:51</div></div>
|
|
<div class="ttc" id="namespacecutlass_html_a7419519fa453a121dfa5f26bf87318d9"><div class="ttname"><a href="namespacecutlass.html#a7419519fa453a121dfa5f26bf87318d9">cutlass::make_Coord</a></div><div class="ttdeci">CUTLASS_HOST_DEVICE Coord< 1 > make_Coord(int _0)</div><div class="ttdoc">Helper to make a 2-element coordinate. </div><div class="ttdef"><b>Definition:</b> coord.h:368</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html">cutlass::TileStoreStream</a></div><div class="ttdoc">Generic stream for transforming and storing fragments. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:141</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileLoadStream_html_aedafb6329f8c484071e04ffd8949edc5"><div class="ttname"><a href="structcutlass_1_1PredicatedTileLoadStream.html#aedafb6329f8c484071e04ffd8949edc5">cutlass::PredicatedTileLoadStream::PredicateFunctor</a></div><div class="ttdeci">PredicateFunctor_ PredicateFunctor</div><div class="ttdoc">Predicate functor. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:262</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileLoadStream_html"><div class="ttname"><a href="structcutlass_1_1PredicatedTileLoadStream.html">cutlass::PredicatedTileLoadStream</a></div><div class="ttdoc">Generic stream for loading and transforming fragments. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:251</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileLoadStream_html_adeb35451885c1c4fb930ae8c914ceb20"><div class="ttname"><a href="structcutlass_1_1PredicatedTileLoadStream.html#adeb35451885c1c4fb930ae8c914ceb20">cutlass::PredicatedTileLoadStream::TransformedFragment</a></div><div class="ttdeci">Base::TransformedFragment TransformedFragment</div><div class="ttdoc">Output fragment from transformer. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:271</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html_a6c9737f5b09e7eb1aa7daabb00ae2e69"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html#a6c9737f5b09e7eb1aa7daabb00ae2e69">cutlass::PredicatedTileStoreStream::Fragment</a></div><div class="ttdeci">Base::Fragment Fragment</div><div class="ttdoc">Fragment fetched from source memory. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:326</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_1_1PredicateVector_html"><div class="ttname"><a href="structcutlass_1_1TileStoreStream_1_1PredicateVector.html">cutlass::TileStoreStream::PredicateVector</a></div><div class="ttdoc">Empty predicate vector struct. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:162</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html_ad0c7a51f1b98111ce332ed906601a4ba"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html#ad0c7a51f1b98111ce332ed906601a4ba">cutlass::PredicatedTileStoreStream::Params</a></div><div class="ttdeci">Base::Params Params</div><div class="ttdoc">Parameters object used to construct generic load stream. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:332</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_1_1Params_html"><div class="ttname"><a href="structcutlass_1_1TileStoreStream_1_1Params.html">cutlass::TileStoreStream::Params</a></div><div class="ttdoc">Parameters used to construct the stream. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:168</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileLoadStream_html_a60a03c95452fe627477933d60815f7cb"><div class="ttname"><a href="structcutlass_1_1PredicatedTileLoadStream.html#a60a03c95452fe627477933d60815f7cb">cutlass::PredicatedTileLoadStream::copy</a></div><div class="ttdeci">CUTLASS_DEVICE void copy()</div><div class="ttdoc">Loads a tile and increments the iterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:299</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_ac61d45d91faf9d060509cf1e5c34fe01"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#ac61d45d91faf9d060509cf1e5c34fe01">cutlass::TileLoadStream::transformed_fragment</a></div><div class="ttdeci">TransformedFragment transformed_fragment</div><div class="ttdoc">Transformed fragment from transformer. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:103</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_ac004fc2e078591ced5d4e5521dfd8627"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#ac004fc2e078591ced5d4e5521dfd8627">cutlass::TileLoadStream::commit</a></div><div class="ttdeci">CUTLASS_DEVICE void commit()</div><div class="ttdoc">Commits the fetched fragment and applies a transformation. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:126</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html_a0f91f328ed2b6bd65ef4eeafe18f9afd"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html#a0f91f328ed2b6bd65ef4eeafe18f9afd">cutlass::PredicatedTileStoreStream::Transformer</a></div><div class="ttdeci">Transformer_ Transformer</div><div class="ttdoc">Transformer. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:323</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_ab6d8716c166d071615f4e78d9ac6efb8"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#ab6d8716c166d071615f4e78d9ac6efb8">cutlass::TileLoadStream::iterator</a></div><div class="ttdeci">Iterator iterator</div><div class="ttdoc">Iterator to load tiles. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:94</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_1_1Params_html_acc400568f7694f818b5afbb109bd2e63"><div class="ttname"><a href="structcutlass_1_1TileStoreStream_1_1Params.html#acc400568f7694f818b5afbb109bd2e63">cutlass::TileStoreStream::Params::Params</a></div><div class="ttdeci">CUTLASS_HOST_DEVICE Params(typename Iterator::Params const &_iterator)</div><div class="ttdoc">Constructor with iterator params. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:182</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_af2727fc0ddeffd1cdaef751140aa6093"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#af2727fc0ddeffd1cdaef751140aa6093">cutlass::TileLoadStream::intermediate_fragment</a></div><div class="ttdeci">CUTLASS_DEVICE Fragment & intermediate_fragment()</div><div class="ttdoc">Accesses the loaded, transformed fragment. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:130</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileLoadStream_html_a9f79fd30231825b38694bf7c1d12ec2a"><div class="ttname"><a href="structcutlass_1_1PredicatedTileLoadStream.html#a9f79fd30231825b38694bf7c1d12ec2a">cutlass::PredicatedTileLoadStream::Transformer</a></div><div class="ttdeci">Transformer_ Transformer</div><div class="ttdoc">Transformer. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:265</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileLoadStream_html_a3af1a02201f53d4d09adc483fdcc23a6"><div class="ttname"><a href="structcutlass_1_1PredicatedTileLoadStream.html#a3af1a02201f53d4d09adc483fdcc23a6">cutlass::PredicatedTileLoadStream::Params</a></div><div class="ttdeci">Base::Params Params</div><div class="ttdoc">Parameters object used to construct generic load stream. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:274</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_aa8c192da812ec83329350e5838838f5e"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#aa8c192da812ec83329350e5838838f5e">cutlass::TileStoreStream::Transformer</a></div><div class="ttdeci">Transformer_ Transformer</div><div class="ttdoc">Transformer. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:150</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_a90ca6bbd882e39b5624ee0cd17e0d652"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#a90ca6bbd882e39b5624ee0cd17e0d652">cutlass::TileLoadStream::Index</a></div><div class="ttdeci">Iterator::Index Index</div><div class="ttdoc">Index type. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:69</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_1_1Params_html_acd106661221997d7c5943daac8eb5088"><div class="ttname"><a href="structcutlass_1_1TileStoreStream_1_1Params.html#acd106661221997d7c5943daac8eb5088">cutlass::TileStoreStream::Params::iterator</a></div><div class="ttdeci">Iterator::Params iterator</div><div class="ttdoc">Parameters to the iterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:170</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html_a2ecdfa152dcf7b3acaf8767f3e69cfbe"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html#a2ecdfa152dcf7b3acaf8767f3e69cfbe">cutlass::PredicatedTileStoreStream::predicates</a></div><div class="ttdeci">Iterator::PredicateVector predicates</div><div class="ttdoc">Predicates. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:339</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_a54399d7a42c1330ef0e756949483c552"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#a54399d7a42c1330ef0e756949483c552">cutlass::TileLoadStream::transformer</a></div><div class="ttdeci">Transformer transformer</div><div class="ttdoc">Transformation applied to fragments. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:100</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html_ac4aafc6bcc6cf3bff5b31b9cd60fd667"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html#ac4aafc6bcc6cf3bff5b31b9cd60fd667">cutlass::PredicatedTileStoreStream::PredicatedTileStoreStream</a></div><div class="ttdeci">CUTLASS_DEVICE PredicatedTileStoreStream(Params const &_params, Coord< 3 > const &bounds, Coord< 3 > const &threadblock_offset=make_Coord(0, 0, 0))</div><div class="ttdoc">Ctor. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:347</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_a89b0f92764b5492a8d1de2c1ada60869"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#a89b0f92764b5492a8d1de2c1ada60869">cutlass::TileLoadStream::fetched_fragment</a></div><div class="ttdeci">Fragment fetched_fragment</div><div class="ttdoc">Fragment loaded via iterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:97</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_ad531770d336b2541c303c19148ef5cd7"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#ad531770d336b2541c303c19148ef5cd7">cutlass::TileLoadStream::Transformer</a></div><div class="ttdeci">Transformer_ Transformer</div><div class="ttdoc">Transformer. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:54</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_af85b3acfc29e41ee605df64b09698a8b"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#af85b3acfc29e41ee605df64b09698a8b">cutlass::TileStoreStream::TileStoreStream</a></div><div class="ttdeci">CUTLASS_DEVICE TileStoreStream(Params const &_params, TensorRef const &_ref)</div><div class="ttdoc">Ctor. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:207</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_1_1Params_html_a90772ac34f8c49f049eb62fada0a2165"><div class="ttname"><a href="structcutlass_1_1TileLoadStream_1_1Params.html#a90772ac34f8c49f049eb62fada0a2165">cutlass::TileLoadStream::Params::Params</a></div><div class="ttdeci">CUTLASS_HOST_DEVICE Params()</div><div class="ttdoc">Default constructor. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:82</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_a08e7e7bf74e1e0d670dd6a4e65d14084"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#a08e7e7bf74e1e0d670dd6a4e65d14084">cutlass::TileStoreStream::TileStoreStream</a></div><div class="ttdeci">CUTLASS_DEVICE TileStoreStream(Params const &_params, Coord< 3 > const &threadblock_offset=make_Coord(0, 0, 0))</div><div class="ttdoc">Ctor. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:212</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_a40a9b1a87cda0f3eb6f4b3e73a4fade3"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#a40a9b1a87cda0f3eb6f4b3e73a4fade3">cutlass::TileLoadStream::TileLoadStream</a></div><div class="ttdeci">CUTLASS_DEVICE TileLoadStream(Params const &_params, TensorRef const &_ref)</div><div class="ttdoc">Ctor. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:111</div></div>
|
|
<div class="ttc" id="cutlass_8h_html_a28c2443a142676d3d71effdae1a986b1"><div class="ttname"><a href="cutlass_8h.html#a28c2443a142676d3d71effdae1a986b1">CUTLASS_HOST_DEVICE</a></div><div class="ttdeci">#define CUTLASS_HOST_DEVICE</div><div class="ttdef"><b>Definition:</b> cutlass.h:46</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_a8c9256c5cdd1fd129dbcc6536375aca7"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#a8c9256c5cdd1fd129dbcc6536375aca7">cutlass::TileLoadStream::TensorRef</a></div><div class="ttdeci">Iterator::TensorRef TensorRef</div><div class="ttdoc">Tensor reference expected by the stream. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:63</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_1_1Params_html_adfa2399bf13cdff16b7bfe1cb0dd2bd9"><div class="ttname"><a href="structcutlass_1_1TileStoreStream_1_1Params.html#adfa2399bf13cdff16b7bfe1cb0dd2bd9">cutlass::TileStoreStream::Params::Params</a></div><div class="ttdeci">CUTLASS_HOST_DEVICE Params()</div><div class="ttdoc">Default constructor. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:178</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_a61d57147150bffda0c1662d6131a3934"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#a61d57147150bffda0c1662d6131a3934">cutlass::TileStoreStream::transformer</a></div><div class="ttdeci">Transformer transformer</div><div class="ttdoc">Transformation applied to inputs. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:193</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_a94cde8bcdcedc934cc14de19e43375d1"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#a94cde8bcdcedc934cc14de19e43375d1">cutlass::TileLoadStream::TransformedFragment</a></div><div class="ttdeci">Transformer::OutputFragment TransformedFragment</div><div class="ttdoc">Output fragment from transformer. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:60</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileLoadStream_html_a672a8883d16eff4ecc90dc79162084d3"><div class="ttname"><a href="structcutlass_1_1PredicatedTileLoadStream.html#a672a8883d16eff4ecc90dc79162084d3">cutlass::PredicatedTileLoadStream::PredicatedTileLoadStream</a></div><div class="ttdeci">CUTLASS_DEVICE PredicatedTileLoadStream(Params const &_params, Coord< 3 > const &bounds, Coord< 3 > const &threadblock_offset=make_Coord(0, 0, 0))</div><div class="ttdoc">Ctor. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:289</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html_aa6d4c263e057678b9f1b8ba6a9feb59f"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html#aa6d4c263e057678b9f1b8ba6a9feb59f">cutlass::PredicatedTileStoreStream::PredicateFunctor</a></div><div class="ttdeci">PredicateFunctor_ PredicateFunctor</div><div class="ttdoc">Predicate functor. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:320</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html">cutlass::TileLoadStream</a></div><div class="ttdoc">Generic stream for loading and transforming fragments. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:45</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_1_1PredicateVector_html"><div class="ttname"><a href="structcutlass_1_1TileLoadStream_1_1PredicateVector.html">cutlass::TileLoadStream::PredicateVector</a></div><div class="ttdoc">Empty predicate vector struct. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:66</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_ab5176fc539364fdf63647dc33020f579"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#ab5176fc539364fdf63647dc33020f579">cutlass::TileStoreStream::commit</a></div><div class="ttdeci">CUTLASS_DEVICE void commit()</div><div class="ttdoc">Commits the store operation. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:233</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_aea86cbd64781caabeee293cfa2070e81"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#aea86cbd64781caabeee293cfa2070e81">cutlass::TileLoadStream::Fragment</a></div><div class="ttdeci">Iterator::Fragment Fragment</div><div class="ttdoc">Fragment fetched from source memory. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:57</div></div>
|
|
<div class="ttc" id="structcutlass_1_1Coord_html"><div class="ttname"><a href="structcutlass_1_1Coord.html">cutlass::Coord< 3 ></a></div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_1_1Params_html"><div class="ttname"><a href="structcutlass_1_1TileLoadStream_1_1Params.html">cutlass::TileLoadStream::Params</a></div><div class="ttdoc">Parameters object used to construct generic load stream. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:72</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_aa0e894a30d3a979ac56e5134360a08f4"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#aa0e894a30d3a979ac56e5134360a08f4">cutlass::TileStoreStream::Index</a></div><div class="ttdeci">Iterator::Index Index</div><div class="ttdoc">Index type. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:165</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileLoadStream_html_a7f802c4c733375d0a63f91c58196e6a0"><div class="ttname"><a href="structcutlass_1_1PredicatedTileLoadStream.html#a7f802c4c733375d0a63f91c58196e6a0">cutlass::PredicatedTileLoadStream::Fragment</a></div><div class="ttdeci">Base::Fragment Fragment</div><div class="ttdoc">Fragment fetched from source memory. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:268</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_1_1Params_html_a50f136516b139f011939015c8c417ddd"><div class="ttname"><a href="structcutlass_1_1TileLoadStream_1_1Params.html#a50f136516b139f011939015c8c417ddd">cutlass::TileLoadStream::Params::Params</a></div><div class="ttdeci">CUTLASS_HOST_DEVICE Params(typename Iterator::Params const &_iterator)</div><div class="ttdoc">Constructor with iterator params. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:86</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_ae14c71f6bb331030429d346f0140c993"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#ae14c71f6bb331030429d346f0140c993">cutlass::TileStoreStream::TransformedFragment</a></div><div class="ttdeci">Transformer::OutputFragment TransformedFragment</div><div class="ttdoc">Transformed fragment, compatible with Iterator::Fragment. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:156</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_a0880c28b3ec82d38571ed332451c8d6a"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#a0880c28b3ec82d38571ed332451c8d6a">cutlass::TileStoreStream::source_fragment</a></div><div class="ttdeci">Fragment source_fragment</div><div class="ttdoc">Source fragment. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:196</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_aff77aed0f1b1583b01a427fc935c5d71"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#aff77aed0f1b1583b01a427fc935c5d71">cutlass::TileStoreStream::intermediate_fragment</a></div><div class="ttdeci">CUTLASS_DEVICE TransformedFragment & intermediate_fragment()</div><div class="ttdoc">Accesses the fragment after trasnforming. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:241</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html_afc320f4d29f05102e9de0064ca31e49b"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html#afc320f4d29f05102e9de0064ca31e49b">cutlass::PredicatedTileStoreStream::Base</a></div><div class="ttdeci">TileStoreStream< Iterator_, Transformer_ > Base</div><div class="ttdef"><b>Definition:</b> tile_stream.h:314</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_html_a6b8b65772d95c30d29e7833348d06ba7"><div class="ttname"><a href="structcutlass_1_1TileLoadStream.html#a6b8b65772d95c30d29e7833348d06ba7">cutlass::TileLoadStream::TileLoadStream</a></div><div class="ttdeci">CUTLASS_DEVICE TileLoadStream(Params const &_params, Coord< 3 > const &threadblock_offset=make_Coord(0, 0, 0))</div><div class="ttdoc">Ctor. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:116</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_a35009c9a697f20fd5a7ee634de4d6c97"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#a35009c9a697f20fd5a7ee634de4d6c97">cutlass::TileStoreStream::Iterator</a></div><div class="ttdeci">Iterator_ Iterator</div><div class="ttdoc">TileLoadIterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:147</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html_a165a0d486f53fb2315d4e555c9f59891"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html#a165a0d486f53fb2315d4e555c9f59891">cutlass::PredicatedTileStoreStream::commit</a></div><div class="ttdeci">CUTLASS_DEVICE void commit()</div><div class="ttdoc">Commits the store operation. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:371</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileStoreStream_html"><div class="ttname"><a href="structcutlass_1_1PredicatedTileStoreStream.html">cutlass::PredicatedTileStoreStream</a></div><div class="ttdoc">Generic stream for transforming and storing fragments. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:309</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_aeb5be2edcc35c7876abe5234663f9c48"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#aeb5be2edcc35c7876abe5234663f9c48">cutlass::TileStoreStream::transformed_fragment</a></div><div class="ttdeci">TransformedFragment transformed_fragment</div><div class="ttdoc">Transformed fragment from transformer. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:199</div></div>
|
|
<div class="ttc" id="convert_8h_html"><div class="ttname"><a href="convert_8h.html">convert.h</a></div><div class="ttdoc">Defines conversion operations among Fragments of different base type. </div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileLoadStream_html_a1f2314aa062360b249b7c57c39af5430"><div class="ttname"><a href="structcutlass_1_1PredicatedTileLoadStream.html#a1f2314aa062360b249b7c57c39af5430">cutlass::PredicatedTileLoadStream::Iterator</a></div><div class="ttdeci">Iterator_ Iterator</div><div class="ttdoc">TileLoadIterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:259</div></div>
|
|
<div class="ttc" id="structcutlass_1_1PredicatedTileLoadStream_html_ac7f57248d3e10c9309f042e5d41440c1"><div class="ttname"><a href="structcutlass_1_1PredicatedTileLoadStream.html#ac7f57248d3e10c9309f042e5d41440c1">cutlass::PredicatedTileLoadStream::Base</a></div><div class="ttdeci">TileLoadStream< Iterator_, Transformer_ > Base</div><div class="ttdef"><b>Definition:</b> tile_stream.h:256</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_a50b6b5bd08fd83baa36c3dc4461ca009"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#a50b6b5bd08fd83baa36c3dc4461ca009">cutlass::TileStoreStream::copy</a></div><div class="ttdeci">CUTLASS_DEVICE void copy()</div><div class="ttdoc">Stores a fragment and increments the iterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:218</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileLoadStream_1_1Params_html_a0430f377595718291f84ef62eb6f4e57"><div class="ttname"><a href="structcutlass_1_1TileLoadStream_1_1Params.html#a0430f377595718291f84ef62eb6f4e57">cutlass::TileLoadStream::Params::iterator</a></div><div class="ttdeci">Iterator::Params iterator</div><div class="ttdoc">Parameters to the iterator. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:74</div></div>
|
|
<div class="ttc" id="structcutlass_1_1TileStoreStream_html_a601a296ec830e9b98aca9d5cf4b4010c"><div class="ttname"><a href="structcutlass_1_1TileStoreStream.html#a601a296ec830e9b98aca9d5cf4b4010c">cutlass::TileStoreStream::iterator</a></div><div class="ttdeci">Iterator iterator</div><div class="ttdoc">Iterator to store tiles. </div><div class="ttdef"><b>Definition:</b> tile_stream.h:190</div></div>
|
|
</div><!-- fragment --></div><!-- contents -->
|
|
<!-- start footer part -->
|
|
<hr class="footer"/><address class="footer"><small>
|
|
Generated on Fri Oct 26 2018 14:53:33 for Cutlass by  <a href="http://www.doxygen.org/index.html">
|
|
<img class="footer" src="doxygen.png" alt="doxygen"/>
|
|
</a> 1.8.14
|
|
</small></address>
|
|
</body>
|
|
</html>
|