blob: f35f9c58bfbb15b44a2471c74b369d4f59aaa42c [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.11"/>
<title>mxnet: /work/mxnet/3rdparty/tvm/nnvm/include/nnvm/compiler/op_attr_types.h File Reference</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/javascript">
$(document).ready(function() { init_search(); });
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td id="projectalign" style="padding-left: 0.5em;">
<div id="projectname">mxnet
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.11 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
<div id="navrow1" class="tabs">
<ul class="tablist">
<li><a href="index.html"><span>Main&#160;Page</span></a></li>
<li><a href="modules.html"><span>Modules</span></a></li>
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
<li><a href="annotated.html"><span>Classes</span></a></li>
<li class="current"><a href="files.html"><span>Files</span></a></li>
<li>
<div id="MSearchBox" class="MSearchBoxInactive">
<span class="left">
<img id="MSearchSelect" src="search/mag_sel.png"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
alt=""/>
<input type="text" id="MSearchField" value="Search" accesskey="S"
onfocus="searchBox.OnSearchFieldFocus(true)"
onblur="searchBox.OnSearchFieldFocus(false)"
onkeyup="searchBox.OnSearchFieldChange(event)"/>
</span><span class="right">
<a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
</span>
</div>
</li>
</ul>
</div>
<div id="navrow2" class="tabs2">
<ul class="tablist">
<li><a href="files.html"><span>File&#160;List</span></a></li>
<li><a href="globals.html"><span>File&#160;Members</span></a></li>
</ul>
</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_d40daf7ef9783ad6669561b9a39523a5.html">tvm</a></li><li class="navelem"><a class="el" href="dir_59ab2d7405f48271a817356d16f4868c.html">nnvm</a></li><li class="navelem"><a class="el" href="dir_564b1b3930cee8f0cd6786ede046ff35.html">include</a></li><li class="navelem"><a class="el" href="dir_aadb892b7c99db7e2c3fc68a6c967545.html">nnvm</a></li><li class="navelem"><a class="el" href="dir_379f8467e47314db6ca7e79336bbdaec.html">compiler</a></li> </ul>
</div>
</div><!-- top -->
<div class="header">
<div class="summary">
<a href="#namespaces">Namespaces</a> &#124;
<a href="#typedef-members">Typedefs</a> &#124;
<a href="#enum-members">Enumerations</a> </div>
<div class="headertitle">
<div class="title">op_attr_types.h File Reference</div> </div>
</div><!--header-->
<div class="contents">
<p>The Expr and related elements in DataFlow construction.
<a href="#details">More...</a></p>
<div class="textblock"><code>#include &lt;tvm/expr.h&gt;</code><br />
<code>#include &lt;tvm/tensor.h&gt;</code><br />
<code>#include &lt;tvm/schedule.h&gt;</code><br />
<code>#include &lt;tvm/packed_func_ext.h&gt;</code><br />
<code>#include &lt;tvm/runtime/registry.h&gt;</code><br />
<code>#include &lt;<a class="el" href="3rdparty_2tvm_2nnvm_2include_2nnvm_2op__attr__types_8h_source.html">nnvm/op_attr_types.h</a>&gt;</code><br />
<code>#include &lt;<a class="el" href="3rdparty_2tvm_2nnvm_2include_2nnvm_2graph__attr__types_8h_source.html">nnvm/graph_attr_types.h</a>&gt;</code><br />
<code>#include &lt;<a class="el" href="graph_8h_source.html">nnvm/graph.h</a>&gt;</code><br />
<code>#include &lt;vector&gt;</code><br />
<code>#include &lt;string&gt;</code><br />
<code>#include &quot;<a class="el" href="packed__func__ext_8h_source.html">packed_func_ext.h</a>&quot;</code><br />
</div><div class="textblock"><div class="dynheader">
Include dependency graph for op_attr_types.h:</div>
<div class="dyncontent">
<div class="center"><img src="3rdparty_2tvm_2nnvm_2include_2nnvm_2compiler_2op__attr__types_8h__incl.png" border="0" usemap="#_2work_2mxnet_23rdparty_2tvm_2nnvm_2include_2nnvm_2compiler_2op__attr__types_8h" alt=""/></div>
<map name="_2work_2mxnet_23rdparty_2tvm_2nnvm_2include_2nnvm_2compiler_2op__attr__types_8h" id="_2work_2mxnet_23rdparty_2tvm_2nnvm_2include_2nnvm_2compiler_2op__attr__types_8h">
<area shape="rect" id="node7" href="3rdparty_2tvm_2nnvm_2include_2nnvm_2op__attr__types_8h.html" title="Data structures that can appear in operator attributes. " alt="" coords="1949,273,2112,300"/>
<area shape="rect" id="node44" href="3rdparty_2tvm_2nnvm_2include_2nnvm_2graph__attr__types_8h.html" title="Data structures that can appear in graph attributes. " alt="" coords="1281,348,1463,375"/>
<area shape="rect" id="node45" href="graph_8h.html" title="Configuation of nnvm as well as basic data structure. " alt="" coords="2417,191,2527,218"/>
<area shape="rect" id="node49" href="packed__func__ext_8h.html" title="Extension to enable packed functionn for nnvm types. " alt="" coords="2452,109,2593,136"/>
<area shape="rect" id="node13" href="3rdparty_2tvm_2nnvm_2include_2nnvm_2base_8h.html" title="Configuration of nnvm as well as basic data structure. " alt="" coords="1887,497,1953,524"/>
<area shape="rect" id="node39" href="node_8h.html" title="Graph node data structure. " alt="" coords="2500,348,2567,375"/>
<area shape="rect" id="node42" href="3rdparty_2tvm_2nnvm_2include_2nnvm_2tuple_8h.html" title="Data structure Tuple and TShape to store dynamic sized shapes. " alt="" coords="1209,423,1276,449"/>
<area shape="rect" id="node43" href="layout_8h.html" title="Layout expression. The layout is composed of upper cases, lower cases and numbers, where upper case indicates a (super&#45;)dimension and the corresponding lower case with factor size indicates the split (sub&#45;)dimension. For example, NCHW16c can describe a 5&#45;D tensor of [batch_size, channel, height, width, channel_block]. Here sub&#45;dimension channel_block=16 is the split of super&#45;dimension C (channel). " alt="" coords="1414,572,1487,599"/>
<area shape="rect" id="node14" href="3rdparty_2dmlc-core_2include_2dmlc_2base_8h.html" title="dmlc/base.h" alt="" coords="1657,796,1757,823"/>
<area shape="rect" id="node18" href="common_8h.html" title="defines some common utility function. " alt="" coords="2043,647,2170,673"/>
<area shape="rect" id="node22" href="any_8h.html" title="Container to hold any data type. " alt="" coords="1776,647,1867,673"/>
<area shape="rect" id="node27" href="memory_8h.html" title="Additional memory hanlding utilities. " alt="" coords="2630,647,2751,673"/>
<area shape="rect" id="node31" href="registry_8h.html" title="Registry utility that helps to build registry singletons. " alt="" coords="1512,572,1627,599"/>
<area shape="rect" id="node37" href="array__view_8h.html" title="Read only data structure to reference array. " alt="" coords="2499,572,2634,599"/>
<area shape="rect" id="node17" href="build__config__default_8h.html" title="Default detection logic for fopen64 and other symbols. May be overriden by CMake. ..." alt="" coords="1773,871,1968,897"/>
<area shape="rect" id="node29" href="thread__local_8h.html" title="Portable thread local storage. " alt="" coords="2480,721,2600,748"/>
<area shape="rect" id="node33" href="parameter_8h.html" title="Provide lightweight util to do parameter setup and checking. " alt="" coords="1420,647,1529,673"/>
<area shape="rect" id="node36" href="type__traits_8h.html" title="type traits information header " alt="" coords="1153,721,1263,748"/>
<area shape="rect" id="node40" href="op_8h.html" title="Operator information structor. " alt="" coords="2221,423,2272,449"/>
<area shape="rect" id="node41" href="3rdparty_2tvm_2nnvm_2include_2nnvm_2c__api_8h.html" title="C API of NNVM symbolic construction and pass. Enables construction and transformation of Graph in any..." alt="" coords="2448,497,2515,524"/>
<area shape="rect" id="node47" href="symbolic_8h.html" title="Symbolic graph construction API. " alt="" coords="2729,273,2820,300"/>
</map>
</div>
</div>
<p><a href="3rdparty_2tvm_2nnvm_2include_2nnvm_2compiler_2op__attr__types_8h_source.html">Go to the source code of this file.</a></p>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="namespaces"></a>
Namespaces</h2></td></tr>
<tr class="memitem:namespacennvm"><td class="memItemLeft" align="right" valign="top"> &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacennvm.html">nnvm</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:namespacennvm_1_1compiler"><td class="memItemLeft" align="right" valign="top"> &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacennvm_1_1compiler.html">nnvm::compiler</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="typedef-members"></a>
Typedefs</h2></td></tr>
<tr class="memitem:ac7390f867756c18b847aaaaf549bf9e1"><td class="memItemLeft" align="right" valign="top">using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacennvm_1_1compiler.html#ac7390f867756c18b847aaaaf549bf9e1">nnvm::compiler::TOpPattern</a> = int</td></tr>
<tr class="memdesc:ac7390f867756c18b847aaaaf549bf9e1"><td class="mdescLeft">&#160;</td><td class="mdescRight">the operator pattern <a href="namespacennvm_1_1compiler.html#ac7390f867756c18b847aaaaf549bf9e1">More...</a><br /></td></tr>
<tr class="separator:ac7390f867756c18b847aaaaf549bf9e1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad95ea95f1a7bd97f7a8d13f936318f42"><td class="memItemLeft" align="right" valign="top">using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacennvm_1_1compiler.html#ad95ea95f1a7bd97f7a8d13f936318f42">nnvm::compiler::FTVMCompute</a> = std::function&lt; Array&lt; Tensor &gt;(const NodeAttrs &amp;attrs, const Array&lt; Tensor &gt; &amp;inputs, const Array&lt; Tensor &gt; &amp;out_info)&gt;</td></tr>
<tr class="memdesc:ad95ea95f1a7bd97f7a8d13f936318f42"><td class="mdescLeft">&#160;</td><td class="mdescRight">Computation description interface. <a href="namespacennvm_1_1compiler.html#ad95ea95f1a7bd97f7a8d13f936318f42">More...</a><br /></td></tr>
<tr class="separator:ad95ea95f1a7bd97f7a8d13f936318f42"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3092e35c1709e8bbce0b44822ecf690a"><td class="memItemLeft" align="right" valign="top">using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacennvm_1_1compiler.html#a3092e35c1709e8bbce0b44822ecf690a">nnvm::compiler::FTVMSchedule</a> = std::function&lt; Schedule(const NodeAttrs &amp;attrs, const Array&lt; Tensor &gt; &amp;outs, const std::string &amp;target)&gt;</td></tr>
<tr class="memdesc:a3092e35c1709e8bbce0b44822ecf690a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Build the computation schedule for op whose root is at current op. <a href="namespacennvm_1_1compiler.html#a3092e35c1709e8bbce0b44822ecf690a">More...</a><br /></td></tr>
<tr class="separator:a3092e35c1709e8bbce0b44822ecf690a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5928b293fb1d2a15fdb1440ce21aa72a"><td class="memItemLeft" align="right" valign="top">using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacennvm_1_1compiler.html#a5928b293fb1d2a15fdb1440ce21aa72a">nnvm::compiler::FTVMAlterOpLayout</a> = std::function&lt; bool(const NodeAttrs &amp;attrs, const Symbol &amp;inputs, const Array&lt; Tensor &gt; &amp;tinfos, Symbol *ret)&gt;</td></tr>
<tr class="memdesc:a5928b293fb1d2a15fdb1440ce21aa72a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Modify the op node to alter its input layout. it is invoked in AlterOpLayout pass. <a href="namespacennvm_1_1compiler.html#a5928b293fb1d2a15fdb1440ce21aa72a">More...</a><br /></td></tr>
<tr class="separator:a5928b293fb1d2a15fdb1440ce21aa72a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a795b559e153b961dcadfb44a9d7c46c6"><td class="memItemLeft" align="right" valign="top">using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacennvm_1_1compiler.html#a795b559e153b961dcadfb44a9d7c46c6">nnvm::compiler::FTVMVectorizedOp</a> = std::function&lt; <a class="el" href="namespacennvm.html#a4259d4f89d9f0feb94111a1c8cb5a1ae">nnvm::NodePtr</a>(const <a class="el" href="classnnvm_1_1Node.html">nnvm::Node</a> *node)&gt;</td></tr>
<tr class="memdesc:a795b559e153b961dcadfb44a9d7c46c6"><td class="mdescLeft">&#160;</td><td class="mdescRight">Transform from normal operator to vectorized operator. <a href="namespacennvm_1_1compiler.html#a795b559e153b961dcadfb44a9d7c46c6">More...</a><br /></td></tr>
<tr class="separator:a795b559e153b961dcadfb44a9d7c46c6"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="enum-members"></a>
Enumerations</h2></td></tr>
<tr class="memitem:aafc152b15e768d3ff58a2ae792c5c65d"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacennvm_1_1compiler.html#aafc152b15e768d3ff58a2ae792c5c65d">nnvm::compiler::OpPatternKind</a> { <br />
&#160;&#160;<a class="el" href="namespacennvm_1_1compiler.html#aafc152b15e768d3ff58a2ae792c5c65daa8f912ede584a436f0c3be789c325746">nnvm::compiler::kElemWise</a> = 0,
<a class="el" href="namespacennvm_1_1compiler.html#aafc152b15e768d3ff58a2ae792c5c65dae7bf0b2a21008ef1b5cf4c0067a374a6">nnvm::compiler::kBroadcast</a> = 1,
<a class="el" href="namespacennvm_1_1compiler.html#aafc152b15e768d3ff58a2ae792c5c65da3b417eaee3f4cea30631b6fb418c626a">nnvm::compiler::kInjective</a> = 2,
<a class="el" href="namespacennvm_1_1compiler.html#aafc152b15e768d3ff58a2ae792c5c65dabc03c0a03151f482156f3a54db1a1a2e">nnvm::compiler::kCommReduce</a> = 3,
<br />
&#160;&#160;<a class="el" href="namespacennvm_1_1compiler.html#aafc152b15e768d3ff58a2ae792c5c65da23e581ba98062335862357f533cd58bc">nnvm::compiler::kOutEWiseFusable</a> = 4,
<a class="el" href="namespacennvm_1_1compiler.html#aafc152b15e768d3ff58a2ae792c5c65da1727f380a91bc76c6b3405bc3511d74d">nnvm::compiler::kOpaque</a> = 8
<br />
}<tr class="memdesc:aafc152b15e768d3ff58a2ae792c5c65d"><td class="mdescLeft">&#160;</td><td class="mdescRight">operator pattern used in graph fusion <a href="namespacennvm_1_1compiler.html#aafc152b15e768d3ff58a2ae792c5c65d">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:aafc152b15e768d3ff58a2ae792c5c65d"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
<div class="textblock"><p>The Expr and related elements in DataFlow construction. </p>
<p>Copyright (c) 2017 by Contributors </p>
</div></div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated on Sat Mar 28 2020 00:52:30 for mxnet by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.11
</small></address>
</body>
</html>