<!-- HTML header for doxygen 1.8.14-->
<!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"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>Caffe2 - Python API: caffe2/python/dataio.py Source File</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<link rel="icon" href="/static/favicon.png" type="image/x-icon">
<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="stylesheet.css" rel="stylesheet" type="text/css" />
<link href="main.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="projectlogo" width="56"><a href="/"><img alt="Logo" src="Caffe2-with-name-55-tall.png"/></a></td>
  <td id="projectalign" style="padding-left: 0.5em;">
   <div id="projectname">Caffe2 - Python API
   </div>
   <div id="projectbrief">A deep learning, cross platform ML framework</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="namespaces.html"><span>Packages</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><a href="/doxygen-c/html/classes.html"><span>C++&#160;API</span></a></li>
      <li><a href="/doxygen-python/html/annotated.html"><span>Python&#160;API</span></a></li>
      <li><a href="https://github.com/caffe2/caffe2"><span>GitHub</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>
    </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_20697b8f204bdfcab31e6b1a416f3ab8.html">caffe2</a></li><li class="navelem"><a class="el" href="dir_f4fda25fc5253eea1ed54677ae5fa2de.html">python</a></li>  </ul>
</div>
</div><!-- top -->
<div class="header">
  <div class="headertitle">
<div class="title">dataio.py</div>  </div>
</div><!--header-->
<div class="contents">
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;<span class="comment">## @package dataio</span></div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;<span class="comment"># Module caffe2.python.dataio</span></div><div class="line"><a name="l00003"></a><span class="lineno">    3</span>&#160;<span class="stringliteral">&quot;&quot;&quot;</span></div><div class="line"><a name="l00004"></a><span class="lineno">    4</span>&#160;<span class="stringliteral">Defines the base interface for reading and writing operations.</span></div><div class="line"><a name="l00005"></a><span class="lineno">    5</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00006"></a><span class="lineno">    6</span>&#160;<span class="stringliteral">Readers/Writers are objects that produce operations that read/write sequences</span></div><div class="line"><a name="l00007"></a><span class="lineno">    7</span>&#160;<span class="stringliteral">of data. Each operation reads or writes a list of BlobReferences.</span></div><div class="line"><a name="l00008"></a><span class="lineno">    8</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00009"></a><span class="lineno">    9</span>&#160;<span class="stringliteral">Readers and Writers must be implemented such that read and write operations</span></div><div class="line"><a name="l00010"></a><span class="lineno">   10</span>&#160;<span class="stringliteral">are atomic and thread safe.</span></div><div class="line"><a name="l00011"></a><span class="lineno">   11</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00012"></a><span class="lineno">   12</span>&#160;<span class="stringliteral">Examples of possible Readers and Writers:</span></div><div class="line"><a name="l00013"></a><span class="lineno">   13</span>&#160;<span class="stringliteral">    QueueReader, QueueWriter,</span></div><div class="line"><a name="l00014"></a><span class="lineno">   14</span>&#160;<span class="stringliteral">    DatasetReader, DatasetWriter,</span></div><div class="line"><a name="l00015"></a><span class="lineno">   15</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00016"></a><span class="lineno">   16</span>&#160;<span class="stringliteral">See `dataset.py` for an example of implementation.</span></div><div class="line"><a name="l00017"></a><span class="lineno">   17</span>&#160;<span class="stringliteral">&quot;&quot;&quot;</span></div><div class="line"><a name="l00018"></a><span class="lineno">   18</span>&#160;<span class="keyword">from</span> __future__ <span class="keyword">import</span> absolute_import</div><div class="line"><a name="l00019"></a><span class="lineno">   19</span>&#160;<span class="keyword">from</span> __future__ <span class="keyword">import</span> division</div><div class="line"><a name="l00020"></a><span class="lineno">   20</span>&#160;<span class="keyword">from</span> __future__ <span class="keyword">import</span> print_function</div><div class="line"><a name="l00021"></a><span class="lineno">   21</span>&#160;<span class="keyword">from</span> __future__ <span class="keyword">import</span> unicode_literals</div><div class="line"><a name="l00022"></a><span class="lineno">   22</span>&#160;</div><div class="line"><a name="l00023"></a><span class="lineno">   23</span>&#160;<span class="keyword">from</span> <a class="code" href="namespacecaffe2_1_1python.html">caffe2.python</a> <span class="keyword">import</span> core</div><div class="line"><a name="l00024"></a><span class="lineno">   24</span>&#160;<span class="keyword">from</span> <a class="code" href="namespacecaffe2_1_1python_1_1schema.html">caffe2.python.schema</a> <span class="keyword">import</span> Field, Struct, from_blob_list</div><div class="line"><a name="l00025"></a><span class="lineno">   25</span>&#160;<span class="keyword">import</span> numpy <span class="keyword">as</span> np</div><div class="line"><a name="l00026"></a><span class="lineno">   26</span>&#160;</div><div class="line"><a name="l00027"></a><span class="lineno">   27</span>&#160;</div><div class="line"><a name="l00028"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html">   28</a></span>&#160;<span class="keyword">class </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html">Reader</a>(object):</div><div class="line"><a name="l00029"></a><span class="lineno">   29</span>&#160;    <span class="stringliteral">&quot;&quot;&quot;</span></div><div class="line"><a name="l00030"></a><span class="lineno">   30</span>&#160;<span class="stringliteral">    Reader is an abstract class to be implemented in order to provide</span></div><div class="line"><a name="l00031"></a><span class="lineno">   31</span>&#160;<span class="stringliteral">    operations capable of iterating through a dataset or stream of data.</span></div><div class="line"><a name="l00032"></a><span class="lineno">   32</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00033"></a><span class="lineno">   33</span>&#160;<span class="stringliteral">    A Reader must implement at least one operation, `read`, which</span></div><div class="line"><a name="l00034"></a><span class="lineno">   34</span>&#160;<span class="stringliteral">    adds operations to a net that read the next batch of data. Readers can</span></div><div class="line"><a name="l00035"></a><span class="lineno">   35</span>&#160;<span class="stringliteral">    optionally support the `reset` operation, which is useful when multiple</span></div><div class="line"><a name="l00036"></a><span class="lineno">   36</span>&#160;<span class="stringliteral">    passes over the data are required.</span></div><div class="line"><a name="l00037"></a><span class="lineno">   37</span>&#160;<span class="stringliteral">    &quot;&quot;&quot;</span></div><div class="line"><a name="l00038"></a><span class="lineno">   38</span>&#160;    <span class="keyword">def </span>__init__(self, schema=None):</div><div class="line"><a name="l00039"></a><span class="lineno">   39</span>&#160;        <span class="keywordflow">if</span> schema <span class="keywordflow">is</span> <span class="keywordflow">not</span> <span class="keywordtype">None</span>:</div><div class="line"><a name="l00040"></a><span class="lineno">   40</span>&#160;            <span class="keyword">assert</span> isinstance(schema, Field)</div><div class="line"><a name="l00041"></a><span class="lineno">   41</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a67e4d228c8017789e3331bff2b5d2537">_schema</a> = schema</div><div class="line"><a name="l00042"></a><span class="lineno">   42</span>&#160;</div><div class="line"><a name="l00043"></a><span class="lineno">   43</span>&#160;    <span class="keyword">def </span><a class="code" href="namespaceschema.html">schema</a>(self):</div><div class="line"><a name="l00044"></a><span class="lineno">   44</span>&#160;        <span class="keyword">assert</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a67e4d228c8017789e3331bff2b5d2537">_schema</a> <span class="keywordflow">is</span> <span class="keywordflow">not</span> <span class="keywordtype">None</span>, <span class="stringliteral">&#39;Schema not provided for this reader.&#39;</span></div><div class="line"><a name="l00045"></a><span class="lineno">   45</span>&#160;        <span class="keywordflow">return</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a67e4d228c8017789e3331bff2b5d2537">_schema</a></div><div class="line"><a name="l00046"></a><span class="lineno">   46</span>&#160;</div><div class="line"><a name="l00047"></a><span class="lineno">   47</span>&#160;    <span class="keyword">def </span>_set_schema(self, schema):</div><div class="line"><a name="l00048"></a><span class="lineno">   48</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a67e4d228c8017789e3331bff2b5d2537">_schema</a> = schema</div><div class="line"><a name="l00049"></a><span class="lineno">   49</span>&#160;</div><div class="line"><a name="l00050"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a8d8909ca962957a5eb60f9d4007ef745">   50</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a8d8909ca962957a5eb60f9d4007ef745">setup_ex</a>(self, init_net, finish_net):</div><div class="line"><a name="l00051"></a><span class="lineno">   51</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Setup nets to run at task initialization and cleanup time.</span></div><div class="line"><a name="l00052"></a><span class="lineno">   52</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00053"></a><span class="lineno">   53</span>&#160;<span class="stringliteral">        Args:</span></div><div class="line"><a name="l00054"></a><span class="lineno">   54</span>&#160;<span class="stringliteral">            global_init_net: A net invoked at task init time.</span></div><div class="line"><a name="l00055"></a><span class="lineno">   55</span>&#160;<span class="stringliteral">            global_finish_net: A net invoked at task cleanup time.</span></div><div class="line"><a name="l00056"></a><span class="lineno">   56</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00057"></a><span class="lineno">   57</span>&#160;        <span class="keywordflow">pass</span></div><div class="line"><a name="l00058"></a><span class="lineno">   58</span>&#160;</div><div class="line"><a name="l00059"></a><span class="lineno">   59</span>&#160;    <span class="keyword">def </span>read_ex(self, local_init_net, local_finish_net):</div><div class="line"><a name="l00060"></a><span class="lineno">   60</span>&#160;        read_net = core.Net(<span class="stringliteral">&#39;reader_body&#39;</span>)</div><div class="line"><a name="l00061"></a><span class="lineno">   61</span>&#160;        <span class="keywordflow">return</span> ([read_net], ) + self.read(read_net)</div><div class="line"><a name="l00062"></a><span class="lineno">   62</span>&#160;</div><div class="line"><a name="l00063"></a><span class="lineno">   63</span>&#160;    <span class="keyword">def </span>read_record_ex(self, local_init_net, local_finish_net):</div><div class="line"><a name="l00064"></a><span class="lineno">   64</span>&#160;        nets, should_stop, fields = self.read_ex(</div><div class="line"><a name="l00065"></a><span class="lineno">   65</span>&#160;            local_init_net, local_finish_net)</div><div class="line"><a name="l00066"></a><span class="lineno">   66</span>&#160;        <span class="keywordflow">if</span> self._schema:</div><div class="line"><a name="l00067"></a><span class="lineno">   67</span>&#160;            fields = from_blob_list(self._schema, fields)</div><div class="line"><a name="l00068"></a><span class="lineno">   68</span>&#160;        <span class="keywordflow">return</span> nets, should_stop, fields</div><div class="line"><a name="l00069"></a><span class="lineno">   69</span>&#160;</div><div class="line"><a name="l00070"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a024602c0217e1c49b436d5d592a9ff70">   70</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a024602c0217e1c49b436d5d592a9ff70">read</a>(self, read_net):</div><div class="line"><a name="l00071"></a><span class="lineno">   71</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Append operations to read_net that will read a batch from the</span></div><div class="line"><a name="l00072"></a><span class="lineno">   72</span>&#160;<span class="stringliteral">        underlying data soruce.</span></div><div class="line"><a name="l00073"></a><span class="lineno">   73</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00074"></a><span class="lineno">   74</span>&#160;<span class="stringliteral">        Operations added to `read_net` must be thread safe and atomic, that is,</span></div><div class="line"><a name="l00075"></a><span class="lineno">   75</span>&#160;<span class="stringliteral">        it should be possible to clone `read_net` and run multiple instances of</span></div><div class="line"><a name="l00076"></a><span class="lineno">   76</span>&#160;<span class="stringliteral">        it in parallel.</span></div><div class="line"><a name="l00077"></a><span class="lineno">   77</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00078"></a><span class="lineno">   78</span>&#160;<span class="stringliteral">        Args:</span></div><div class="line"><a name="l00079"></a><span class="lineno">   79</span>&#160;<span class="stringliteral">            read_net: the net that will be appended with read operations</span></div><div class="line"><a name="l00080"></a><span class="lineno">   80</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00081"></a><span class="lineno">   81</span>&#160;<span class="stringliteral">        Returns:</span></div><div class="line"><a name="l00082"></a><span class="lineno">   82</span>&#160;<span class="stringliteral">            A tuple (should_stop, fields), with:</span></div><div class="line"><a name="l00083"></a><span class="lineno">   83</span>&#160;<span class="stringliteral">                should_stop: BlobReference pointing to a boolean scalar</span></div><div class="line"><a name="l00084"></a><span class="lineno">   84</span>&#160;<span class="stringliteral">                    blob that indicates whether the read operation</span></div><div class="line"><a name="l00085"></a><span class="lineno">   85</span>&#160;<span class="stringliteral">                    was succesfull or whether the end of data has</span></div><div class="line"><a name="l00086"></a><span class="lineno">   86</span>&#160;<span class="stringliteral">                    been reached.</span></div><div class="line"><a name="l00087"></a><span class="lineno">   87</span>&#160;<span class="stringliteral">                fields: A tuple of BlobReference containing the latest batch</span></div><div class="line"><a name="l00088"></a><span class="lineno">   88</span>&#160;<span class="stringliteral">                    of data that was read.</span></div><div class="line"><a name="l00089"></a><span class="lineno">   89</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00090"></a><span class="lineno">   90</span>&#160;        <span class="keywordflow">raise</span> NotImplementedError(<span class="stringliteral">&#39;Readers must implement `read`.&#39;</span>)</div><div class="line"><a name="l00091"></a><span class="lineno">   91</span>&#160;</div><div class="line"><a name="l00092"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a3e24214ecea0850be812df3296b3796b">   92</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a3e24214ecea0850be812df3296b3796b">reset</a>(self, net):</div><div class="line"><a name="l00093"></a><span class="lineno">   93</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Append operations to `net` that will reset the reader.</span></div><div class="line"><a name="l00094"></a><span class="lineno">   94</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00095"></a><span class="lineno">   95</span>&#160;<span class="stringliteral">        This can be used to read the data multiple times.</span></div><div class="line"><a name="l00096"></a><span class="lineno">   96</span>&#160;<span class="stringliteral">        Not all readers support this operation.</span></div><div class="line"><a name="l00097"></a><span class="lineno">   97</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00098"></a><span class="lineno">   98</span>&#160;        <span class="keywordflow">raise</span> NotImplementedError(<span class="stringliteral">&#39;This reader cannot be resetted.&#39;</span>)</div><div class="line"><a name="l00099"></a><span class="lineno">   99</span>&#160;</div><div class="line"><a name="l00100"></a><span class="lineno">  100</span>&#160;    <span class="keyword">def </span>read_record(self, read_net):</div><div class="line"><a name="l00101"></a><span class="lineno">  101</span>&#160;        should_stop, fields = self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a024602c0217e1c49b436d5d592a9ff70">read</a>(read_net)</div><div class="line"><a name="l00102"></a><span class="lineno">  102</span>&#160;        <span class="keywordflow">if</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a67e4d228c8017789e3331bff2b5d2537">_schema</a>:</div><div class="line"><a name="l00103"></a><span class="lineno">  103</span>&#160;            fields = from_blob_list(self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a67e4d228c8017789e3331bff2b5d2537">_schema</a>, fields)</div><div class="line"><a name="l00104"></a><span class="lineno">  104</span>&#160;        <span class="keywordflow">return</span> should_stop, fields</div><div class="line"><a name="l00105"></a><span class="lineno">  105</span>&#160;</div><div class="line"><a name="l00106"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#ad6c5e15f2482793bebac92089d050bbc">  106</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#ad6c5e15f2482793bebac92089d050bbc">execution_step</a>(self, reader_net_name=None, external_should_stop=None):</div><div class="line"><a name="l00107"></a><span class="lineno">  107</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Create an execution step with a net containing read operators.</span></div><div class="line"><a name="l00108"></a><span class="lineno">  108</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00109"></a><span class="lineno">  109</span>&#160;<span class="stringliteral">        The execution step will contain a `stop_blob` that knows how to stop</span></div><div class="line"><a name="l00110"></a><span class="lineno">  110</span>&#160;<span class="stringliteral">        the execution loop when end of data was reached.</span></div><div class="line"><a name="l00111"></a><span class="lineno">  111</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00112"></a><span class="lineno">  112</span>&#160;<span class="stringliteral">        E.g.:</span></div><div class="line"><a name="l00113"></a><span class="lineno">  113</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00114"></a><span class="lineno">  114</span>&#160;<span class="stringliteral">            read_step, fields = reader.execution_step()</span></div><div class="line"><a name="l00115"></a><span class="lineno">  115</span>&#160;<span class="stringliteral">            consume_net = core.Net(&#39;consume&#39;)</span></div><div class="line"><a name="l00116"></a><span class="lineno">  116</span>&#160;<span class="stringliteral">            consume_net.Print(fields[0], [])</span></div><div class="line"><a name="l00117"></a><span class="lineno">  117</span>&#160;<span class="stringliteral">            p = core.Plan(&#39;reader&#39;)</span></div><div class="line"><a name="l00118"></a><span class="lineno">  118</span>&#160;<span class="stringliteral">            p.AddStep(read_step.AddNet(consume_net))</span></div><div class="line"><a name="l00119"></a><span class="lineno">  119</span>&#160;<span class="stringliteral">            core.RunPlan(p)</span></div><div class="line"><a name="l00120"></a><span class="lineno">  120</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00121"></a><span class="lineno">  121</span>&#160;<span class="stringliteral">        Args:</span></div><div class="line"><a name="l00122"></a><span class="lineno">  122</span>&#160;<span class="stringliteral">            reader_net_name: (optional) the name of the reader_net to be</span></div><div class="line"><a name="l00123"></a><span class="lineno">  123</span>&#160;<span class="stringliteral">                             created. The execution step will</span></div><div class="line"><a name="l00124"></a><span class="lineno">  124</span>&#160;<span class="stringliteral">                             be named accordingly.</span></div><div class="line"><a name="l00125"></a><span class="lineno">  125</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00126"></a><span class="lineno">  126</span>&#160;<span class="stringliteral">        Returns:</span></div><div class="line"><a name="l00127"></a><span class="lineno">  127</span>&#160;<span class="stringliteral">            A tuple (read_step, fields), with:</span></div><div class="line"><a name="l00128"></a><span class="lineno">  128</span>&#160;<span class="stringliteral">                read_step: A newly created execution step containing a net with</span></div><div class="line"><a name="l00129"></a><span class="lineno">  129</span>&#160;<span class="stringliteral">                           read operations. The step will have `stop_blob` set,</span></div><div class="line"><a name="l00130"></a><span class="lineno">  130</span>&#160;<span class="stringliteral">                           in order to stop the loop on end of data.</span></div><div class="line"><a name="l00131"></a><span class="lineno">  131</span>&#160;<span class="stringliteral">                fields: A tuple of BlobReference containing the latest batch</span></div><div class="line"><a name="l00132"></a><span class="lineno">  132</span>&#160;<span class="stringliteral">                        of data that was read.</span></div><div class="line"><a name="l00133"></a><span class="lineno">  133</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00134"></a><span class="lineno">  134</span>&#160;        reader_net = <a class="code" href="classcaffe2_1_1python_1_1core_1_1_net.html">core.Net</a>(reader_net_name <span class="keywordflow">or</span> <span class="stringliteral">&#39;reader&#39;</span>)</div><div class="line"><a name="l00135"></a><span class="lineno">  135</span>&#160;        should_stop, fields = self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a272213d199828188fff4e1f006285372">read_record</a>(reader_net)</div><div class="line"><a name="l00136"></a><span class="lineno">  136</span>&#160;        <span class="keywordflow">if</span> external_should_stop <span class="keywordflow">is</span> <span class="keywordflow">not</span> <span class="keywordtype">None</span>:</div><div class="line"><a name="l00137"></a><span class="lineno">  137</span>&#160;            should_stop = reader_net.Or([external_should_stop, should_stop])</div><div class="line"><a name="l00138"></a><span class="lineno">  138</span>&#160;        read_step = core.execution_step(</div><div class="line"><a name="l00139"></a><span class="lineno">  139</span>&#160;            <span class="stringliteral">&#39;{}_step&#39;</span>.format(reader_net_name),</div><div class="line"><a name="l00140"></a><span class="lineno">  140</span>&#160;            reader_net,</div><div class="line"><a name="l00141"></a><span class="lineno">  141</span>&#160;            should_stop_blob=should_stop)</div><div class="line"><a name="l00142"></a><span class="lineno">  142</span>&#160;        <span class="keywordflow">return</span> (read_step, fields)</div><div class="line"><a name="l00143"></a><span class="lineno">  143</span>&#160;</div><div class="line"><a name="l00144"></a><span class="lineno">  144</span>&#160;</div><div class="line"><a name="l00145"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html">  145</a></span>&#160;<span class="keyword">class </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html">Writer</a>(object):</div><div class="line"><a name="l00146"></a><span class="lineno">  146</span>&#160;    <span class="stringliteral">&quot;&quot;&quot;</span></div><div class="line"><a name="l00147"></a><span class="lineno">  147</span>&#160;<span class="stringliteral">    Writer is an abstract class to be implemented in order to provide</span></div><div class="line"><a name="l00148"></a><span class="lineno">  148</span>&#160;<span class="stringliteral">    operations capable of feeding a data stream or a dataset.</span></div><div class="line"><a name="l00149"></a><span class="lineno">  149</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00150"></a><span class="lineno">  150</span>&#160;<span class="stringliteral">    A Writer must implement 2 operations:</span></div><div class="line"><a name="l00151"></a><span class="lineno">  151</span>&#160;<span class="stringliteral">    `write`, which adds operations to a net that write the write batch of</span></div><div class="line"><a name="l00152"></a><span class="lineno">  152</span>&#160;<span class="stringliteral">    data, and `commit`, which adds operations to a net in order to indicate</span></div><div class="line"><a name="l00153"></a><span class="lineno">  153</span>&#160;<span class="stringliteral">    that no more data will be written.</span></div><div class="line"><a name="l00154"></a><span class="lineno">  154</span>&#160;<span class="stringliteral">    &quot;&quot;&quot;</span></div><div class="line"><a name="l00155"></a><span class="lineno">  155</span>&#160;    _schema = <span class="keywordtype">None</span></div><div class="line"><a name="l00156"></a><span class="lineno">  156</span>&#160;</div><div class="line"><a name="l00157"></a><span class="lineno">  157</span>&#160;    <span class="keyword">def </span><a class="code" href="namespaceschema.html">schema</a>(self):</div><div class="line"><a name="l00158"></a><span class="lineno">  158</span>&#160;        <span class="keywordflow">return</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a9d70c665219c46da12b0cfafdae8060a">_schema</a></div><div class="line"><a name="l00159"></a><span class="lineno">  159</span>&#160;</div><div class="line"><a name="l00160"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a77a746b74ca09dd9aee005330cc6916d">  160</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a77a746b74ca09dd9aee005330cc6916d">write</a>(self, writer_net, fields):</div><div class="line"><a name="l00161"></a><span class="lineno">  161</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Add operations to `writer_net` that write the next batch of data.</span></div><div class="line"><a name="l00162"></a><span class="lineno">  162</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00163"></a><span class="lineno">  163</span>&#160;<span class="stringliteral">        Operations added to the net must be thread-safe and unique, that is:</span></div><div class="line"><a name="l00164"></a><span class="lineno">  164</span>&#160;<span class="stringliteral">        multiple writers must be able to write to the dataset in parallel.</span></div><div class="line"><a name="l00165"></a><span class="lineno">  165</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00166"></a><span class="lineno">  166</span>&#160;<span class="stringliteral">        Args:</span></div><div class="line"><a name="l00167"></a><span class="lineno">  167</span>&#160;<span class="stringliteral">            fields: a tuple of BlobReference containing the batch of data to</span></div><div class="line"><a name="l00168"></a><span class="lineno">  168</span>&#160;<span class="stringliteral">                    write.</span></div><div class="line"><a name="l00169"></a><span class="lineno">  169</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00170"></a><span class="lineno">  170</span>&#160;        <span class="keywordflow">raise</span> NotImplementedError(<span class="stringliteral">&#39;Writers must implement write.&#39;</span>)</div><div class="line"><a name="l00171"></a><span class="lineno">  171</span>&#160;</div><div class="line"><a name="l00172"></a><span class="lineno">  172</span>&#160;    <span class="keyword">def </span>write_record(self, writer_net, fields):</div><div class="line"><a name="l00173"></a><span class="lineno">  173</span>&#160;        <span class="keywordflow">if</span> isinstance(fields, Field):</div><div class="line"><a name="l00174"></a><span class="lineno">  174</span>&#160;            self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a9d70c665219c46da12b0cfafdae8060a">_schema</a> = fields</div><div class="line"><a name="l00175"></a><span class="lineno">  175</span>&#160;            fields = fields.field_blobs()</div><div class="line"><a name="l00176"></a><span class="lineno">  176</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a77a746b74ca09dd9aee005330cc6916d">write</a>(writer_net, fields)</div><div class="line"><a name="l00177"></a><span class="lineno">  177</span>&#160;</div><div class="line"><a name="l00178"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a3e270a50d9e2d65db196cddc56132c00">  178</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a3e270a50d9e2d65db196cddc56132c00">setup_ex</a>(self, init_net, finish_net):</div><div class="line"><a name="l00179"></a><span class="lineno">  179</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Experimental, don&#39;t use yet&quot;&quot;&quot;</span></div><div class="line"><a name="l00180"></a><span class="lineno">  180</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a7fb018f843ba304edbd23f0e82328ece">commit</a>(finish_net)</div><div class="line"><a name="l00181"></a><span class="lineno">  181</span>&#160;</div><div class="line"><a name="l00182"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a8c0252988fae6e79ed51fa5407e244f6">  182</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a8c0252988fae6e79ed51fa5407e244f6">write_ex</a>(self, fields, local_init_net, local_finish_net, stop_blob):</div><div class="line"><a name="l00183"></a><span class="lineno">  183</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Experimental extension to the interface. Don&#39;t use yet&quot;&quot;&quot;</span></div><div class="line"><a name="l00184"></a><span class="lineno">  184</span>&#160;        write_net = <a class="code" href="classcaffe2_1_1python_1_1core_1_1_net.html">core.Net</a>(<span class="stringliteral">&#39;write_net&#39;</span>)</div><div class="line"><a name="l00185"></a><span class="lineno">  185</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a77a746b74ca09dd9aee005330cc6916d">write</a>(write_net, fields)</div><div class="line"><a name="l00186"></a><span class="lineno">  186</span>&#160;        <span class="keywordflow">return</span> [write_net]</div><div class="line"><a name="l00187"></a><span class="lineno">  187</span>&#160;</div><div class="line"><a name="l00188"></a><span class="lineno">  188</span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a55b403eba95e44ab19e68dd164a9aaf1">write_record_ex</a>(</div><div class="line"><a name="l00189"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a55b403eba95e44ab19e68dd164a9aaf1">  189</a></span>&#160;            self, fields, local_init_net, local_finish_net, stop_blob=<span class="keywordtype">None</span>):</div><div class="line"><a name="l00190"></a><span class="lineno">  190</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Experimental extension to the interface. Don&#39;t use yet.&quot;&quot;&quot;</span></div><div class="line"><a name="l00191"></a><span class="lineno">  191</span>&#160;        <span class="keywordflow">if</span> isinstance(fields, Field):</div><div class="line"><a name="l00192"></a><span class="lineno">  192</span>&#160;            self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a9d70c665219c46da12b0cfafdae8060a">_schema</a> = fields</div><div class="line"><a name="l00193"></a><span class="lineno">  193</span>&#160;            fields = fields.field_blobs()</div><div class="line"><a name="l00194"></a><span class="lineno">  194</span>&#160;        <span class="keywordflow">if</span> stop_blob <span class="keywordflow">is</span> <span class="keywordtype">None</span>:</div><div class="line"><a name="l00195"></a><span class="lineno">  195</span>&#160;            stop_blob = local_init_net.NextName(<span class="stringliteral">&quot;dequeue_status&quot;</span>)</div><div class="line"><a name="l00196"></a><span class="lineno">  196</span>&#160;        write_nets = self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a8c0252988fae6e79ed51fa5407e244f6">write_ex</a>(</div><div class="line"><a name="l00197"></a><span class="lineno">  197</span>&#160;            fields, local_init_net, local_finish_net, stop_blob)</div><div class="line"><a name="l00198"></a><span class="lineno">  198</span>&#160;        <span class="keywordflow">return</span> (write_nets, stop_blob)</div><div class="line"><a name="l00199"></a><span class="lineno">  199</span>&#160;</div><div class="line"><a name="l00200"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a7fb018f843ba304edbd23f0e82328ece">  200</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a7fb018f843ba304edbd23f0e82328ece">commit</a>(self, finish_net):</div><div class="line"><a name="l00201"></a><span class="lineno">  201</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Add operations to `finish_net` that signal end of data.</span></div><div class="line"><a name="l00202"></a><span class="lineno">  202</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00203"></a><span class="lineno">  203</span>&#160;<span class="stringliteral">        This must be implemented by all Writers, but may be no-op for some</span></div><div class="line"><a name="l00204"></a><span class="lineno">  204</span>&#160;<span class="stringliteral">        of them.</span></div><div class="line"><a name="l00205"></a><span class="lineno">  205</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00206"></a><span class="lineno">  206</span>&#160;        <span class="keywordflow">pass</span></div><div class="line"><a name="l00207"></a><span class="lineno">  207</span>&#160;</div><div class="line"><a name="l00208"></a><span class="lineno">  208</span>&#160;</div><div class="line"><a name="l00209"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader_builder.html">  209</a></span>&#160;<span class="keyword">class </span>ReaderBuilder(object):</div><div class="line"><a name="l00210"></a><span class="lineno">  210</span>&#160;    <span class="stringliteral">&quot;&quot;&quot; Allow usage of a reader in distributed fashion. &quot;&quot;&quot;</span></div><div class="line"><a name="l00211"></a><span class="lineno">  211</span>&#160;    <span class="keyword">def </span><a class="code" href="namespaceschema.html">schema</a>(self):</div><div class="line"><a name="l00212"></a><span class="lineno">  212</span>&#160;        <span class="keywordflow">raise</span> NotImplementedError()</div><div class="line"><a name="l00213"></a><span class="lineno">  213</span>&#160;</div><div class="line"><a name="l00214"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader_builder.html#a45191bc578de11a88715b49faec44d03">  214</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_builder.html#a45191bc578de11a88715b49faec44d03">setup</a>(self, **kwargs):</div><div class="line"><a name="l00215"></a><span class="lineno">  215</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;</span></div><div class="line"><a name="l00216"></a><span class="lineno">  216</span>&#160;<span class="stringliteral">        Optionally, perform one-time setup before calling new_reader().</span></div><div class="line"><a name="l00217"></a><span class="lineno">  217</span>&#160;<span class="stringliteral">        Subclass should make sure this function is only called once.</span></div><div class="line"><a name="l00218"></a><span class="lineno">  218</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00219"></a><span class="lineno">  219</span>&#160;        <span class="keywordflow">raise</span> NotImplementedError()</div><div class="line"><a name="l00220"></a><span class="lineno">  220</span>&#160;</div><div class="line"><a name="l00221"></a><span class="lineno">  221</span>&#160;    <span class="keyword">def </span>new_reader(self, **kwargs):</div><div class="line"><a name="l00222"></a><span class="lineno">  222</span>&#160;        <span class="keywordflow">raise</span> NotImplementedError()</div><div class="line"><a name="l00223"></a><span class="lineno">  223</span>&#160;</div><div class="line"><a name="l00224"></a><span class="lineno">  224</span>&#160;</div><div class="line"><a name="l00225"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_piped_reader_builder.html">  225</a></span>&#160;<span class="keyword">class </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_piped_reader_builder.html">PipedReaderBuilder</a>(<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_builder.html">ReaderBuilder</a>):</div><div class="line"><a name="l00226"></a><span class="lineno">  226</span>&#160;    <span class="stringliteral">&quot;&quot;&quot;ReaderBuilder that modifies underlying builder by calling `piper`</span></div><div class="line"><a name="l00227"></a><span class="lineno">  227</span>&#160;<span class="stringliteral">    function on each new reader produced, and return the result of</span></div><div class="line"><a name="l00228"></a><span class="lineno">  228</span>&#160;<span class="stringliteral">    the function. This way, it is possible to append data processing</span></div><div class="line"><a name="l00229"></a><span class="lineno">  229</span>&#160;<span class="stringliteral">    pipelines that will be replicated for each reader that gets created.</span></div><div class="line"><a name="l00230"></a><span class="lineno">  230</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00231"></a><span class="lineno">  231</span>&#160;<span class="stringliteral">    E.g.:</span></div><div class="line"><a name="l00232"></a><span class="lineno">  232</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00233"></a><span class="lineno">  233</span>&#160;<span class="stringliteral">    PipedReaderBuilder(</span></div><div class="line"><a name="l00234"></a><span class="lineno">  234</span>&#160;<span class="stringliteral">        ReaderBuilder(...),</span></div><div class="line"><a name="l00235"></a><span class="lineno">  235</span>&#160;<span class="stringliteral">        lambda reader: pipe(reader, processor=my_proc))</span></div><div class="line"><a name="l00236"></a><span class="lineno">  236</span>&#160;<span class="stringliteral">    &quot;&quot;&quot;</span></div><div class="line"><a name="l00237"></a><span class="lineno">  237</span>&#160;</div><div class="line"><a name="l00238"></a><span class="lineno">  238</span>&#160;    <span class="keyword">def </span>__init__(self, builder, piper):</div><div class="line"><a name="l00239"></a><span class="lineno">  239</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_piped_reader_builder.html#a5b880dde8089504e6a1d59d961211510">_builder</a> = builder</div><div class="line"><a name="l00240"></a><span class="lineno">  240</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_piped_reader_builder.html#afa8acb4ffa740a238fcb64d307d245a2">_piper</a> = piper</div><div class="line"><a name="l00241"></a><span class="lineno">  241</span>&#160;</div><div class="line"><a name="l00242"></a><span class="lineno">  242</span>&#160;    <span class="keyword">def </span><a class="code" href="namespaceschema.html">schema</a>(self):</div><div class="line"><a name="l00243"></a><span class="lineno">  243</span>&#160;        <span class="keywordflow">return</span> self._builder.schema()</div><div class="line"><a name="l00244"></a><span class="lineno">  244</span>&#160;</div><div class="line"><a name="l00245"></a><span class="lineno">  245</span>&#160;    <span class="keyword">def </span>setup(self, **kwargs):</div><div class="line"><a name="l00246"></a><span class="lineno">  246</span>&#160;        self._builder.setup(**kwargs)</div><div class="line"><a name="l00247"></a><span class="lineno">  247</span>&#160;</div><div class="line"><a name="l00248"></a><span class="lineno">  248</span>&#160;    <span class="keyword">def </span>new_reader(self, **kwargs):</div><div class="line"><a name="l00249"></a><span class="lineno">  249</span>&#160;        <span class="comment"># Passing everything down since you could wrap a PipedReaderBuilder in</span></div><div class="line"><a name="l00250"></a><span class="lineno">  250</span>&#160;        <span class="comment"># another PipedReaderBuilder</span></div><div class="line"><a name="l00251"></a><span class="lineno">  251</span>&#160;        output = self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_piped_reader_builder.html#afa8acb4ffa740a238fcb64d307d245a2">_piper</a>(</div><div class="line"><a name="l00252"></a><span class="lineno">  252</span>&#160;            reader=self._builder.new_reader(**kwargs),</div><div class="line"><a name="l00253"></a><span class="lineno">  253</span>&#160;            **kwargs</div><div class="line"><a name="l00254"></a><span class="lineno">  254</span>&#160;        )</div><div class="line"><a name="l00255"></a><span class="lineno">  255</span>&#160;        <span class="keywordflow">return</span> output <span class="keywordflow">if</span> isinstance(output, Reader) <span class="keywordflow">else</span> output.reader()</div><div class="line"><a name="l00256"></a><span class="lineno">  256</span>&#160;</div><div class="line"><a name="l00257"></a><span class="lineno">  257</span>&#160;</div><div class="line"><a name="l00258"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_pipe.html">  258</a></span>&#160;<span class="keyword">class </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_pipe.html">Pipe</a>(object):</div><div class="line"><a name="l00259"></a><span class="lineno">  259</span>&#160;    <span class="keyword">def </span>__init__(self, schema=None, obj_key=None):</div><div class="line"><a name="l00260"></a><span class="lineno">  260</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_pipe.html#a67fa37befe204abe20469aefcc435b5d">_num_writers</a> = 0</div><div class="line"><a name="l00261"></a><span class="lineno">  261</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_pipe.html#aeb582e1dc5b200f59799a85c7162aed9">_num_readers</a> = 0</div><div class="line"><a name="l00262"></a><span class="lineno">  262</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_pipe.html#a1583d0c5bad66affcfe3def7ccf48bf0">_schema</a> = schema</div><div class="line"><a name="l00263"></a><span class="lineno">  263</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_pipe.html#a978c380d579e6ec821fe71e1be9d574d">_obj_key</a> = obj_key</div><div class="line"><a name="l00264"></a><span class="lineno">  264</span>&#160;</div><div class="line"><a name="l00265"></a><span class="lineno">  265</span>&#160;    <span class="keyword">def </span><a class="code" href="namespaceschema.html">schema</a>(self):</div><div class="line"><a name="l00266"></a><span class="lineno">  266</span>&#160;        <span class="keywordflow">return</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_pipe.html#a1583d0c5bad66affcfe3def7ccf48bf0">_schema</a></div><div class="line"><a name="l00267"></a><span class="lineno">  267</span>&#160;</div><div class="line"><a name="l00268"></a><span class="lineno">  268</span>&#160;    <span class="keyword">def </span>setup(self, global_init_net):</div><div class="line"><a name="l00269"></a><span class="lineno">  269</span>&#160;        <span class="keywordflow">pass</span></div><div class="line"><a name="l00270"></a><span class="lineno">  270</span>&#160;</div><div class="line"><a name="l00271"></a><span class="lineno">  271</span>&#160;    <span class="keyword">def </span>reader(self):</div><div class="line"><a name="l00272"></a><span class="lineno">  272</span>&#160;        <span class="keywordflow">raise</span> NotImplementedError()</div><div class="line"><a name="l00273"></a><span class="lineno">  273</span>&#160;</div><div class="line"><a name="l00274"></a><span class="lineno">  274</span>&#160;    <span class="keyword">def </span>writer(self):</div><div class="line"><a name="l00275"></a><span class="lineno">  275</span>&#160;        <span class="keywordflow">raise</span> NotImplementedError()</div><div class="line"><a name="l00276"></a><span class="lineno">  276</span>&#160;</div><div class="line"><a name="l00277"></a><span class="lineno">  277</span>&#160;    <span class="keyword">def </span>num_readers(self):</div><div class="line"><a name="l00278"></a><span class="lineno">  278</span>&#160;        <span class="keywordflow">return</span> self._num_readers</div><div class="line"><a name="l00279"></a><span class="lineno">  279</span>&#160;</div><div class="line"><a name="l00280"></a><span class="lineno">  280</span>&#160;    <span class="keyword">def </span>num_writers(self):</div><div class="line"><a name="l00281"></a><span class="lineno">  281</span>&#160;        <span class="keywordflow">return</span> self._num_writers</div><div class="line"><a name="l00282"></a><span class="lineno">  282</span>&#160;</div><div class="line"><a name="l00283"></a><span class="lineno">  283</span>&#160;    <span class="keyword">def </span>_new_writer(self, writer_schema, writer_init_net):</div><div class="line"><a name="l00284"></a><span class="lineno">  284</span>&#160;        <span class="keywordflow">if</span> writer_schema <span class="keywordflow">is</span> <span class="keywordflow">not</span> <span class="keywordtype">None</span> <span class="keywordflow">and</span> self._schema <span class="keywordflow">is</span> <span class="keywordtype">None</span>:</div><div class="line"><a name="l00285"></a><span class="lineno">  285</span>&#160;            self._schema = writer_schema</div><div class="line"><a name="l00286"></a><span class="lineno">  286</span>&#160;        self._num_writers += 1</div><div class="line"><a name="l00287"></a><span class="lineno">  287</span>&#160;        <span class="keywordflow">if</span> self._obj_key <span class="keywordflow">is</span> <span class="keywordflow">not</span> <span class="keywordtype">None</span>:</div><div class="line"><a name="l00288"></a><span class="lineno">  288</span>&#160;            writer_init_net.add_attribute(self._obj_key, self)</div><div class="line"><a name="l00289"></a><span class="lineno">  289</span>&#160;</div><div class="line"><a name="l00290"></a><span class="lineno">  290</span>&#160;    <span class="keyword">def </span>_new_reader(self, reader_init_net):</div><div class="line"><a name="l00291"></a><span class="lineno">  291</span>&#160;        self._num_readers += 1</div><div class="line"><a name="l00292"></a><span class="lineno">  292</span>&#160;        <span class="keywordflow">if</span> self._obj_key <span class="keywordflow">is</span> <span class="keywordflow">not</span> <span class="keywordtype">None</span>:</div><div class="line"><a name="l00293"></a><span class="lineno">  293</span>&#160;            reader_init_net.add_attribute(self._obj_key, self)</div><div class="line"><a name="l00294"></a><span class="lineno">  294</span>&#160;</div><div class="line"><a name="l00295"></a><span class="lineno">  295</span>&#160;</div><div class="line"><a name="l00296"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html">  296</a></span>&#160;<span class="keyword">class </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html">CounterReader</a>(<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html">Reader</a>):</div><div class="line"><a name="l00297"></a><span class="lineno">  297</span>&#160;    <span class="stringliteral">&quot;&quot;&quot; Reader that produces increasing integers. &quot;&quot;&quot;</span></div><div class="line"><a name="l00298"></a><span class="lineno">  298</span>&#160;    <span class="keyword">def </span>__init__(self):</div><div class="line"><a name="l00299"></a><span class="lineno">  299</span>&#160;        Reader.__init__(self, schema=<a class="code" href="classcaffe2_1_1python_1_1schema_1_1_struct.html">Struct</a>((<span class="stringliteral">&#39;iter&#39;</span>, np.int64)))</div><div class="line"><a name="l00300"></a><span class="lineno">  300</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html#aef4fa9db5d30aa1f08f744490ce8021f">counter</a> = <span class="keywordtype">None</span></div><div class="line"><a name="l00301"></a><span class="lineno">  301</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html#a3b43f6f116b22f46e62dac1541b335c1">should_stop</a> = <span class="keywordtype">None</span></div><div class="line"><a name="l00302"></a><span class="lineno">  302</span>&#160;</div><div class="line"><a name="l00303"></a><span class="lineno">  303</span>&#160;    <span class="keyword">def </span>setup_ex(self, global_init_net, global_finish_net):</div><div class="line"><a name="l00304"></a><span class="lineno">  304</span>&#160;        <span class="keywordflow">if</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html#aef4fa9db5d30aa1f08f744490ce8021f">counter</a> <span class="keywordflow">is</span> <span class="keywordtype">None</span>:</div><div class="line"><a name="l00305"></a><span class="lineno">  305</span>&#160;            self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html#aef4fa9db5d30aa1f08f744490ce8021f">counter</a> = global_init_net.CreateCounter([], init_count=0)</div><div class="line"><a name="l00306"></a><span class="lineno">  306</span>&#160;            self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html#a3b43f6f116b22f46e62dac1541b335c1">should_stop</a> = global_init_net.ConstantFill(</div><div class="line"><a name="l00307"></a><span class="lineno">  307</span>&#160;                [], shape=[], dtype=core.DataType.BOOL, value=<span class="keyword">False</span>)</div><div class="line"><a name="l00308"></a><span class="lineno">  308</span>&#160;</div><div class="line"><a name="l00309"></a><span class="lineno">  309</span>&#160;    <span class="keyword">def </span>read_ex(self, local_init_net, local_finish_net):</div><div class="line"><a name="l00310"></a><span class="lineno">  310</span>&#160;        count_net = <a class="code" href="classcaffe2_1_1python_1_1core_1_1_net.html">core.Net</a>(<span class="stringliteral">&#39;limited_reader_counter&#39;</span>)</div><div class="line"><a name="l00311"></a><span class="lineno">  311</span>&#160;        value = count_net.CountUp([self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html#aef4fa9db5d30aa1f08f744490ce8021f">counter</a>], 1)</div><div class="line"><a name="l00312"></a><span class="lineno">  312</span>&#160;        <span class="keywordflow">return</span> [count_net], self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html#a3b43f6f116b22f46e62dac1541b335c1">should_stop</a>, [value]</div><div class="line"><a name="l00313"></a><span class="lineno">  313</span>&#160;</div><div class="line"><a name="l00314"></a><span class="lineno">  314</span>&#160;</div><div class="line"><a name="l00315"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html">  315</a></span>&#160;<span class="keyword">class </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html">ReaderWithLimitBase</a>(<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html">Reader</a>):</div><div class="line"><a name="l00316"></a><span class="lineno">  316</span>&#160;    <span class="stringliteral">&quot;&quot;&quot;Abstract Reader constrained by certain conditions.</span></div><div class="line"><a name="l00317"></a><span class="lineno">  317</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00318"></a><span class="lineno">  318</span>&#160;<span class="stringliteral">    Base class for Reader classes which check for certain conditions to stop</span></div><div class="line"><a name="l00319"></a><span class="lineno">  319</span>&#160;<span class="stringliteral">    further processing (e.g. max number of iterations or time limit).</span></div><div class="line"><a name="l00320"></a><span class="lineno">  320</span>&#160;<span class="stringliteral">    Also produces a boolean blob (data_finished) that can be used to see if</span></div><div class="line"><a name="l00321"></a><span class="lineno">  321</span>&#160;<span class="stringliteral">    the reader exausted all input data (true) or stopped for another reason</span></div><div class="line"><a name="l00322"></a><span class="lineno">  322</span>&#160;<span class="stringliteral">    (false).</span></div><div class="line"><a name="l00323"></a><span class="lineno">  323</span>&#160;<span class="stringliteral">    &quot;&quot;&quot;</span></div><div class="line"><a name="l00324"></a><span class="lineno">  324</span>&#160;</div><div class="line"><a name="l00325"></a><span class="lineno">  325</span>&#160;    <span class="keyword">def </span>__init__(self, reader):</div><div class="line"><a name="l00326"></a><span class="lineno">  326</span>&#160;        Reader.__init__(self, schema=reader._schema)</div><div class="line"><a name="l00327"></a><span class="lineno">  327</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a4280bdbee45637532cc46f379ceebe36">reader</a> = reader</div><div class="line"><a name="l00328"></a><span class="lineno">  328</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a2695eb809e444deca3fa9c1d1e6a45a0">net</a> = <a class="code" href="classcaffe2_1_1python_1_1core_1_1_net.html">core.Net</a>(<span class="stringliteral">&#39;reader_with_limit&#39;</span>)</div><div class="line"><a name="l00329"></a><span class="lineno">  329</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a40e3b66209543cb9501574bc529c55a2">_data_finished</a> = self.net.AddExternalInput(</div><div class="line"><a name="l00330"></a><span class="lineno">  330</span>&#160;            self.net.NextName(<span class="stringliteral">&#39;data_finished&#39;</span>))</div><div class="line"><a name="l00331"></a><span class="lineno">  331</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#afe0a7c91ce61267f4966715d97897f86">should_stop</a> = <span class="keywordtype">None</span></div><div class="line"><a name="l00332"></a><span class="lineno">  332</span>&#160;</div><div class="line"><a name="l00333"></a><span class="lineno">  333</span>&#160;    <span class="keyword">def </span>setup_ex(self, global_init_net, global_finish_net):</div><div class="line"><a name="l00334"></a><span class="lineno">  334</span>&#160;        global_init_net.ConstantFill(</div><div class="line"><a name="l00335"></a><span class="lineno">  335</span>&#160;            [], [self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a40e3b66209543cb9501574bc529c55a2">_data_finished</a>],</div><div class="line"><a name="l00336"></a><span class="lineno">  336</span>&#160;            shape=[], value=<span class="keyword">False</span>, dtype=core.DataType.BOOL)</div><div class="line"><a name="l00337"></a><span class="lineno">  337</span>&#160;        self.reader.setup_ex(global_init_net, global_finish_net)</div><div class="line"><a name="l00338"></a><span class="lineno">  338</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a969c829309710eced9c46c7372267f43">setup_limiter</a>(global_init_net, global_finish_net)</div><div class="line"><a name="l00339"></a><span class="lineno">  339</span>&#160;</div><div class="line"><a name="l00340"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a947fb82fe17fd625685cad6f63874c50">  340</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a947fb82fe17fd625685cad6f63874c50">read_ex</a>(self, local_init_net, local_finish_net):</div><div class="line"><a name="l00341"></a><span class="lineno">  341</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Reads from an underlying Reader class, but may stop due to additional</span></div><div class="line"><a name="l00342"></a><span class="lineno">  342</span>&#160;<span class="stringliteral">        constraints.</span></div><div class="line"><a name="l00343"></a><span class="lineno">  343</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00344"></a><span class="lineno">  344</span>&#160;<span class="stringliteral">        Build and return network(s) to read data from a Reader with</span></div><div class="line"><a name="l00345"></a><span class="lineno">  345</span>&#160;<span class="stringliteral">        additional constraints, depending on which derived class is used.</span></div><div class="line"><a name="l00346"></a><span class="lineno">  346</span>&#160;<span class="stringliteral">        Derived classes implement setup_limited and check_limiter_condition</span></div><div class="line"><a name="l00347"></a><span class="lineno">  347</span>&#160;<span class="stringliteral">        which determine the nature of the constraint imposed on the reader,</span></div><div class="line"><a name="l00348"></a><span class="lineno">  348</span>&#160;<span class="stringliteral">        e.g. iteration limits or time limit.</span></div><div class="line"><a name="l00349"></a><span class="lineno">  349</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00350"></a><span class="lineno">  350</span>&#160;<span class="stringliteral">        Args:</span></div><div class="line"><a name="l00351"></a><span class="lineno">  351</span>&#160;<span class="stringliteral">            local_init_net: A net invoked at task instance init time (Once per</span></div><div class="line"><a name="l00352"></a><span class="lineno">  352</span>&#160;<span class="stringliteral">                parallel thread).</span></div><div class="line"><a name="l00353"></a><span class="lineno">  353</span>&#160;<span class="stringliteral">            local_finish_net: A net invoked at task instance cleanup time (Once</span></div><div class="line"><a name="l00354"></a><span class="lineno">  354</span>&#160;<span class="stringliteral">                per parallel thread).</span></div><div class="line"><a name="l00355"></a><span class="lineno">  355</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00356"></a><span class="lineno">  356</span>&#160;</div><div class="line"><a name="l00357"></a><span class="lineno">  357</span>&#160;        <span class="comment"># Check if limiting constraint is met.</span></div><div class="line"><a name="l00358"></a><span class="lineno">  358</span>&#160;        stop_condition_net = <a class="code" href="classcaffe2_1_1python_1_1core_1_1_net.html">core.Net</a>(<span class="stringliteral">&#39;limited_reader_condition&#39;</span>)</div><div class="line"><a name="l00359"></a><span class="lineno">  359</span>&#160;        should_stop = self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a77b30909960c74b18df486f3e727da23">check_limiter_condition</a>(stop_condition_net)</div><div class="line"><a name="l00360"></a><span class="lineno">  360</span>&#160;</div><div class="line"><a name="l00361"></a><span class="lineno">  361</span>&#160;        <span class="comment"># Call original reader.</span></div><div class="line"><a name="l00362"></a><span class="lineno">  362</span>&#160;        nets, local_data_finished, fields = self.reader.read_ex(</div><div class="line"><a name="l00363"></a><span class="lineno">  363</span>&#160;            local_init_net, local_finish_net)</div><div class="line"><a name="l00364"></a><span class="lineno">  364</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#aab1108a3c40f87d3a28a8e195a68f76e">_set_schema</a>(self.reader._schema)</div><div class="line"><a name="l00365"></a><span class="lineno">  365</span>&#160;</div><div class="line"><a name="l00366"></a><span class="lineno">  366</span>&#160;        <span class="comment"># Check if original reader is done.</span></div><div class="line"><a name="l00367"></a><span class="lineno">  367</span>&#160;        check_done_net = <a class="code" href="classcaffe2_1_1python_1_1core_1_1_net.html">core.Net</a>(<span class="stringliteral">&#39;limited_reader_post&#39;</span>)</div><div class="line"><a name="l00368"></a><span class="lineno">  368</span>&#160;        <span class="comment"># Copy to the same blob as the counter output to trigger reader</span></div><div class="line"><a name="l00369"></a><span class="lineno">  369</span>&#160;        <span class="comment"># stopping - this is ok because execution will check should_stop_blob</span></div><div class="line"><a name="l00370"></a><span class="lineno">  370</span>&#160;        <span class="comment"># after every single operation, so it has already been checked on this</span></div><div class="line"><a name="l00371"></a><span class="lineno">  371</span>&#160;        <span class="comment"># iteration by this point.</span></div><div class="line"><a name="l00372"></a><span class="lineno">  372</span>&#160;        check_done_net.Copy(local_data_finished, should_stop)</div><div class="line"><a name="l00373"></a><span class="lineno">  373</span>&#160;        <span class="comment"># Update externally-accessible flag indicating if reader is done</span></div><div class="line"><a name="l00374"></a><span class="lineno">  374</span>&#160;        check_done_net.Or([self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a40e3b66209543cb9501574bc529c55a2">_data_finished</a>, local_data_finished],</div><div class="line"><a name="l00375"></a><span class="lineno">  375</span>&#160;                          [self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a40e3b66209543cb9501574bc529c55a2">_data_finished</a>])</div><div class="line"><a name="l00376"></a><span class="lineno">  376</span>&#160;</div><div class="line"><a name="l00377"></a><span class="lineno">  377</span>&#160;        <span class="keywordflow">return</span> [stop_condition_net] + nets + [check_done_net], should_stop, fields</div><div class="line"><a name="l00378"></a><span class="lineno">  378</span>&#160;</div><div class="line"><a name="l00379"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a969c829309710eced9c46c7372267f43">  379</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a969c829309710eced9c46c7372267f43">setup_limiter</a>(self, global_init_net, global_finish_net):</div><div class="line"><a name="l00380"></a><span class="lineno">  380</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Configure task level init/cleanup nets required to implement limit</span></div><div class="line"><a name="l00381"></a><span class="lineno">  381</span>&#160;<span class="stringliteral">        condition. Must be implemented by subclass.</span></div><div class="line"><a name="l00382"></a><span class="lineno">  382</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00383"></a><span class="lineno">  383</span>&#160;<span class="stringliteral">        Args:</span></div><div class="line"><a name="l00384"></a><span class="lineno">  384</span>&#160;<span class="stringliteral">            global_init_net: A net invoked at task init time.</span></div><div class="line"><a name="l00385"></a><span class="lineno">  385</span>&#160;<span class="stringliteral">            global_finish_net: A net invoked at task cleanup time.</span></div><div class="line"><a name="l00386"></a><span class="lineno">  386</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00387"></a><span class="lineno">  387</span>&#160;        <span class="keywordflow">raise</span> NotImplementedError(<span class="stringliteral">&quot;Subclass must implement `setup_limiter`&quot;</span>)</div><div class="line"><a name="l00388"></a><span class="lineno">  388</span>&#160;</div><div class="line"><a name="l00389"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a77b30909960c74b18df486f3e727da23">  389</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a77b30909960c74b18df486f3e727da23">check_limiter_condition</a>(self, stop_condition_net):</div><div class="line"><a name="l00390"></a><span class="lineno">  390</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Configure a net that is invoked between reading batches to see if</span></div><div class="line"><a name="l00391"></a><span class="lineno">  391</span>&#160;<span class="stringliteral">        limit condition is met. Must be implemented by subclass.</span></div><div class="line"><a name="l00392"></a><span class="lineno">  392</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00393"></a><span class="lineno">  393</span>&#160;<span class="stringliteral">        Args:</span></div><div class="line"><a name="l00394"></a><span class="lineno">  394</span>&#160;<span class="stringliteral">            stop_condition_net: A net invoked to evaluate an early termination</span></div><div class="line"><a name="l00395"></a><span class="lineno">  395</span>&#160;<span class="stringliteral">                condition.</span></div><div class="line"><a name="l00396"></a><span class="lineno">  396</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00397"></a><span class="lineno">  397</span>&#160;        <span class="keywordflow">raise</span> NotImplementedError(<span class="stringliteral">&quot;Subclass must implement `check_limiter_condition&quot;</span>)</div><div class="line"><a name="l00398"></a><span class="lineno">  398</span>&#160;</div><div class="line"><a name="l00399"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#aac12472533f0d43e0cb4b8a5df6489d1">  399</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#aac12472533f0d43e0cb4b8a5df6489d1">data_finished</a>(self):</div><div class="line"><a name="l00400"></a><span class="lineno">  400</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;</span></div><div class="line"><a name="l00401"></a><span class="lineno">  401</span>&#160;<span class="stringliteral">        Return a blob that can be checked after the end of the reading task,</span></div><div class="line"><a name="l00402"></a><span class="lineno">  402</span>&#160;<span class="stringliteral">        which will contain a scalar float indicating whether the underlying</span></div><div class="line"><a name="l00403"></a><span class="lineno">  403</span>&#160;<span class="stringliteral">        reader has been exhausted (True) or whether we stopped because reached</span></div><div class="line"><a name="l00404"></a><span class="lineno">  404</span>&#160;<span class="stringliteral">        the limit of iterations (False).</span></div><div class="line"><a name="l00405"></a><span class="lineno">  405</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00406"></a><span class="lineno">  406</span>&#160;        <span class="keywordflow">return</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a40e3b66209543cb9501574bc529c55a2">_data_finished</a></div><div class="line"><a name="l00407"></a><span class="lineno">  407</span>&#160;</div><div class="line"><a name="l00408"></a><span class="lineno">  408</span>&#160;</div><div class="line"><a name="l00409"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html">  409</a></span>&#160;<span class="keyword">class </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html">ReaderWithLimit</a>(<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html">ReaderWithLimitBase</a>):</div><div class="line"><a name="l00410"></a><span class="lineno">  410</span>&#160;    <span class="stringliteral">&quot;&quot;&quot;Reader that stops after `num_iter` batches.</span></div><div class="line"><a name="l00411"></a><span class="lineno">  411</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00412"></a><span class="lineno">  412</span>&#160;<span class="stringliteral">    If `num_iter` &lt;= 0 or is None, reverts to an unconstrained reader that</span></div><div class="line"><a name="l00413"></a><span class="lineno">  413</span>&#160;<span class="stringliteral">    exports a boolean blob indicating that the reader has exhausted</span></div><div class="line"><a name="l00414"></a><span class="lineno">  414</span>&#160;<span class="stringliteral">    the data steam.</span></div><div class="line"><a name="l00415"></a><span class="lineno">  415</span>&#160;<span class="stringliteral">    &quot;&quot;&quot;</span></div><div class="line"><a name="l00416"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#a70002bd48f0f4d114520015b12bfdfbd">  416</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#a70002bd48f0f4d114520015b12bfdfbd">__init__</a>(self, reader, num_iter=1):</div><div class="line"><a name="l00417"></a><span class="lineno">  417</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Class initializer.</span></div><div class="line"><a name="l00418"></a><span class="lineno">  418</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00419"></a><span class="lineno">  419</span>&#160;<span class="stringliteral">        Args:</span></div><div class="line"><a name="l00420"></a><span class="lineno">  420</span>&#160;<span class="stringliteral">            reader: The underlying reader object doing the actual read.</span></div><div class="line"><a name="l00421"></a><span class="lineno">  421</span>&#160;<span class="stringliteral">            num_iter: Number of batches to read. If `None`,</span></div><div class="line"><a name="l00422"></a><span class="lineno">  422</span>&#160;<span class="stringliteral">                the class reverts to a normal reader except that it also</span></div><div class="line"><a name="l00423"></a><span class="lineno">  423</span>&#160;<span class="stringliteral">                produces a data_finished blob as a side effect to indicate</span></div><div class="line"><a name="l00424"></a><span class="lineno">  424</span>&#160;<span class="stringliteral">                whether the input stream is exhausted.</span></div><div class="line"><a name="l00425"></a><span class="lineno">  425</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00426"></a><span class="lineno">  426</span>&#160;        super(ReaderWithLimit, self).<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#a70002bd48f0f4d114520015b12bfdfbd">__init__</a>(reader)</div><div class="line"><a name="l00427"></a><span class="lineno">  427</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#af3e6f05bed28a9630dc7a148cbb95098">counter</a> = <span class="keywordtype">None</span></div><div class="line"><a name="l00428"></a><span class="lineno">  428</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#affce11133c16f0bb732989888c221f67">num_iter</a> = num_iter</div><div class="line"><a name="l00429"></a><span class="lineno">  429</span>&#160;        <span class="keywordflow">if</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#affce11133c16f0bb732989888c221f67">num_iter</a> <span class="keywordflow">is</span> <span class="keywordflow">not</span> <span class="keywordtype">None</span>:</div><div class="line"><a name="l00430"></a><span class="lineno">  430</span>&#160;            self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#af3e6f05bed28a9630dc7a148cbb95098">counter</a> = self.net.AddExternalInput(</div><div class="line"><a name="l00431"></a><span class="lineno">  431</span>&#160;                self.net.NextName(<span class="stringliteral">&#39;counter&#39;</span>))</div><div class="line"><a name="l00432"></a><span class="lineno">  432</span>&#160;</div><div class="line"><a name="l00433"></a><span class="lineno">  433</span>&#160;    <span class="keyword">def </span>setup_limiter(self, global_init_net, global_finish_net):</div><div class="line"><a name="l00434"></a><span class="lineno">  434</span>&#160;        <span class="keywordflow">if</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#af3e6f05bed28a9630dc7a148cbb95098">counter</a>:</div><div class="line"><a name="l00435"></a><span class="lineno">  435</span>&#160;            global_init_net.CreateCounter(</div><div class="line"><a name="l00436"></a><span class="lineno">  436</span>&#160;                [], [self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#af3e6f05bed28a9630dc7a148cbb95098">counter</a>], init_count=int(self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#affce11133c16f0bb732989888c221f67">num_iter</a>))</div><div class="line"><a name="l00437"></a><span class="lineno">  437</span>&#160;</div><div class="line"><a name="l00438"></a><span class="lineno">  438</span>&#160;    <span class="keyword">def </span>check_limiter_condition(self, stop_condition_net):</div><div class="line"><a name="l00439"></a><span class="lineno">  439</span>&#160;        <span class="keywordflow">if</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#af3e6f05bed28a9630dc7a148cbb95098">counter</a>:</div><div class="line"><a name="l00440"></a><span class="lineno">  440</span>&#160;            <span class="keywordflow">return</span> stop_condition_net.CountDown([self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#af3e6f05bed28a9630dc7a148cbb95098">counter</a>], 1)</div><div class="line"><a name="l00441"></a><span class="lineno">  441</span>&#160;        <span class="keywordflow">else</span>:</div><div class="line"><a name="l00442"></a><span class="lineno">  442</span>&#160;            <span class="keywordflow">return</span> stop_condition_net.ConstantFill(</div><div class="line"><a name="l00443"></a><span class="lineno">  443</span>&#160;                [], 1,</div><div class="line"><a name="l00444"></a><span class="lineno">  444</span>&#160;                shape=[], value=<span class="keyword">False</span>, dtype=core.DataType.BOOL)</div><div class="line"><a name="l00445"></a><span class="lineno">  445</span>&#160;</div><div class="line"><a name="l00446"></a><span class="lineno">  446</span>&#160;</div><div class="line"><a name="l00447"></a><span class="lineno">  447</span>&#160;<span class="keyword">def </span>CountUntil(num_iter):</div><div class="line"><a name="l00448"></a><span class="lineno">  448</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html">ReaderWithLimit</a>(<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html">CounterReader</a>(), num_iter)</div><div class="line"><a name="l00449"></a><span class="lineno">  449</span>&#160;</div><div class="line"><a name="l00450"></a><span class="lineno">  450</span>&#160;</div><div class="line"><a name="l00451"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html">  451</a></span>&#160;<span class="keyword">class </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html">ReaderWithTimeLimit</a>(<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html">ReaderWithLimitBase</a>):</div><div class="line"><a name="l00452"></a><span class="lineno">  452</span>&#160;    <span class="stringliteral">&quot;&quot;&quot;Reader that stops after `duration` seconds.</span></div><div class="line"><a name="l00453"></a><span class="lineno">  453</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00454"></a><span class="lineno">  454</span>&#160;<span class="stringliteral">    If `duration` &lt;= 0 or is None, reverts to an unconstrained reader that</span></div><div class="line"><a name="l00455"></a><span class="lineno">  455</span>&#160;<span class="stringliteral">    exports a boolean blob indicating that the reader has exhausted</span></div><div class="line"><a name="l00456"></a><span class="lineno">  456</span>&#160;<span class="stringliteral">    the data steam.</span></div><div class="line"><a name="l00457"></a><span class="lineno">  457</span>&#160;<span class="stringliteral">    &quot;&quot;&quot;</span></div><div class="line"><a name="l00458"></a><span class="lineno"><a class="line" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a71add0ae34dd8e3caf4acae256eca151">  458</a></span>&#160;    <span class="keyword">def </span><a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a71add0ae34dd8e3caf4acae256eca151">__init__</a>(self, reader, duration=0):</div><div class="line"><a name="l00459"></a><span class="lineno">  459</span>&#160;        <span class="stringliteral">&quot;&quot;&quot;Class initializer.</span></div><div class="line"><a name="l00460"></a><span class="lineno">  460</span>&#160;<span class="stringliteral"></span></div><div class="line"><a name="l00461"></a><span class="lineno">  461</span>&#160;<span class="stringliteral">        Args:</span></div><div class="line"><a name="l00462"></a><span class="lineno">  462</span>&#160;<span class="stringliteral">            reader: The underlying reader object doing the actual read.</span></div><div class="line"><a name="l00463"></a><span class="lineno">  463</span>&#160;<span class="stringliteral">            duration: Number of seconds to read. If un-specified, None, or &lt;= 0,</span></div><div class="line"><a name="l00464"></a><span class="lineno">  464</span>&#160;<span class="stringliteral">                the class reverts to a normal reader except that it also</span></div><div class="line"><a name="l00465"></a><span class="lineno">  465</span>&#160;<span class="stringliteral">                produces a data_finished blob as a side effect to indicate</span></div><div class="line"><a name="l00466"></a><span class="lineno">  466</span>&#160;<span class="stringliteral">                whether the input stream is exhausted.</span></div><div class="line"><a name="l00467"></a><span class="lineno">  467</span>&#160;<span class="stringliteral">        &quot;&quot;&quot;</span></div><div class="line"><a name="l00468"></a><span class="lineno">  468</span>&#160;        super(ReaderWithTimeLimit, self).<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a71add0ae34dd8e3caf4acae256eca151">__init__</a>(reader)</div><div class="line"><a name="l00469"></a><span class="lineno">  469</span>&#160;</div><div class="line"><a name="l00470"></a><span class="lineno">  470</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#abee021655958ec4fba6c3a611eb43ec4">timer</a> = <span class="keywordtype">None</span></div><div class="line"><a name="l00471"></a><span class="lineno">  471</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a0ff62afd3c822f5bd0cfd7ba5c1b859a">duration</a> = duration</div><div class="line"><a name="l00472"></a><span class="lineno">  472</span>&#160;        self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a224e4dc2dbf1d25e2a4fc4c7c3a26095">duration_ns_blob</a> = <span class="keywordtype">None</span></div><div class="line"><a name="l00473"></a><span class="lineno">  473</span>&#160;</div><div class="line"><a name="l00474"></a><span class="lineno">  474</span>&#160;    <span class="keyword">def </span>setup_limiter(self, global_init_net, global_finish_net):</div><div class="line"><a name="l00475"></a><span class="lineno">  475</span>&#160;        <span class="keywordflow">if</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a0ff62afd3c822f5bd0cfd7ba5c1b859a">duration</a> <span class="keywordflow">is</span> <span class="keywordflow">not</span> <span class="keywordtype">None</span> <span class="keywordflow">and</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a0ff62afd3c822f5bd0cfd7ba5c1b859a">duration</a> &gt; 0:</div><div class="line"><a name="l00476"></a><span class="lineno">  476</span>&#160;            duration_ns = int(self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a0ff62afd3c822f5bd0cfd7ba5c1b859a">duration</a> * (10**9))</div><div class="line"><a name="l00477"></a><span class="lineno">  477</span>&#160;</div><div class="line"><a name="l00478"></a><span class="lineno">  478</span>&#160;            self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#abee021655958ec4fba6c3a611eb43ec4">timer</a> = global_init_net.TimerBegin(</div><div class="line"><a name="l00479"></a><span class="lineno">  479</span>&#160;                [], counter_name=<span class="stringliteral">&#39;epoch_timer&#39;</span>)</div><div class="line"><a name="l00480"></a><span class="lineno">  480</span>&#160;            start_time = global_init_net.TimerGet(self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#abee021655958ec4fba6c3a611eb43ec4">timer</a>)</div><div class="line"><a name="l00481"></a><span class="lineno">  481</span>&#160;            self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a224e4dc2dbf1d25e2a4fc4c7c3a26095">duration_ns_blob</a> = global_init_net.ConstantFill(</div><div class="line"><a name="l00482"></a><span class="lineno">  482</span>&#160;                [start_time], value=duration_ns)</div><div class="line"><a name="l00483"></a><span class="lineno">  483</span>&#160;</div><div class="line"><a name="l00484"></a><span class="lineno">  484</span>&#160;            global_finish_net.TimerEnd([self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#abee021655958ec4fba6c3a611eb43ec4">timer</a>], [])</div><div class="line"><a name="l00485"></a><span class="lineno">  485</span>&#160;</div><div class="line"><a name="l00486"></a><span class="lineno">  486</span>&#160;    <span class="keyword">def </span>check_limiter_condition(self, stop_condition_net):</div><div class="line"><a name="l00487"></a><span class="lineno">  487</span>&#160;        <span class="keywordflow">if</span> self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a0ff62afd3c822f5bd0cfd7ba5c1b859a">duration</a>:</div><div class="line"><a name="l00488"></a><span class="lineno">  488</span>&#160;            time_elapsed = stop_condition_net.TimerGet(self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#abee021655958ec4fba6c3a611eb43ec4">timer</a>)</div><div class="line"><a name="l00489"></a><span class="lineno">  489</span>&#160;            <span class="keywordflow">return</span> stop_condition_net.GE(</div><div class="line"><a name="l00490"></a><span class="lineno">  490</span>&#160;                [time_elapsed, self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a224e4dc2dbf1d25e2a4fc4c7c3a26095">duration_ns_blob</a>], str(self.<a class="code" href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#afe0a7c91ce61267f4966715d97897f86">should_stop</a>))</div><div class="line"><a name="l00491"></a><span class="lineno">  491</span>&#160;        <span class="keywordflow">else</span>:</div><div class="line"><a name="l00492"></a><span class="lineno">  492</span>&#160;            <span class="keywordflow">return</span> stop_condition_net.ConstantFill(</div><div class="line"><a name="l00493"></a><span class="lineno">  493</span>&#160;                [], 1, shape=[], value=<span class="keyword">False</span>, dtype=core.DataType.BOOL</div><div class="line"><a name="l00494"></a><span class="lineno">  494</span>&#160;            )</div><div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base_html_a40e3b66209543cb9501574bc529c55a2"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a40e3b66209543cb9501574bc529c55a2">caffe2.python.dataio.ReaderWithLimitBase._data_finished</a></div><div class="ttdeci">_data_finished</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00329">dataio.py:329</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_html_affce11133c16f0bb732989888c221f67"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#affce11133c16f0bb732989888c221f67">caffe2.python.dataio.ReaderWithLimit.num_iter</a></div><div class="ttdeci">num_iter</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00428">dataio.py:428</a></div></div>
<div class="ttc" id="namespaceschema_html"><div class="ttname"><a href="namespaceschema.html">schema</a></div><div class="ttdoc">Module caffe2.python.schema. </div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_builder_html_a45191bc578de11a88715b49faec44d03"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_builder.html#a45191bc578de11a88715b49faec44d03">caffe2.python.dataio.ReaderBuilder.setup</a></div><div class="ttdeci">def setup(self, kwargs)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00214">dataio.py:214</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base_html_afe0a7c91ce61267f4966715d97897f86"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#afe0a7c91ce61267f4966715d97897f86">caffe2.python.dataio.ReaderWithLimitBase.should_stop</a></div><div class="ttdeci">should_stop</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00331">dataio.py:331</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_builder_html"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_builder.html">caffe2.python.dataio.ReaderBuilder</a></div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00209">dataio.py:209</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_pipe_html_a1583d0c5bad66affcfe3def7ccf48bf0"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_pipe.html#a1583d0c5bad66affcfe3def7ccf48bf0">caffe2.python.dataio.Pipe._schema</a></div><div class="ttdeci">_schema</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00262">dataio.py:262</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base_html_a4280bdbee45637532cc46f379ceebe36"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a4280bdbee45637532cc46f379ceebe36">caffe2.python.dataio.ReaderWithLimitBase.reader</a></div><div class="ttdeci">reader</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00327">dataio.py:327</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_counter_reader_html_a3b43f6f116b22f46e62dac1541b335c1"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html#a3b43f6f116b22f46e62dac1541b335c1">caffe2.python.dataio.CounterReader.should_stop</a></div><div class="ttdeci">should_stop</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00301">dataio.py:301</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_html_a024602c0217e1c49b436d5d592a9ff70"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a024602c0217e1c49b436d5d592a9ff70">caffe2.python.dataio.Reader.read</a></div><div class="ttdeci">def read(self, read_net)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00070">dataio.py:70</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_html_aab1108a3c40f87d3a28a8e195a68f76e"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#aab1108a3c40f87d3a28a8e195a68f76e">caffe2.python.dataio.Reader._set_schema</a></div><div class="ttdeci">def _set_schema(self, schema)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00047">dataio.py:47</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base_html_aac12472533f0d43e0cb4b8a5df6489d1"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#aac12472533f0d43e0cb4b8a5df6489d1">caffe2.python.dataio.ReaderWithLimitBase.data_finished</a></div><div class="ttdeci">def data_finished(self)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00399">dataio.py:399</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_piped_reader_builder_html_afa8acb4ffa740a238fcb64d307d245a2"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_piped_reader_builder.html#afa8acb4ffa740a238fcb64d307d245a2">caffe2.python.dataio.PipedReaderBuilder._piper</a></div><div class="ttdeci">_piper</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00240">dataio.py:240</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit_html_a224e4dc2dbf1d25e2a4fc4c7c3a26095"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a224e4dc2dbf1d25e2a4fc4c7c3a26095">caffe2.python.dataio.ReaderWithTimeLimit.duration_ns_blob</a></div><div class="ttdeci">duration_ns_blob</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00472">dataio.py:472</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_html"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader.html">caffe2.python.dataio.Reader</a></div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00028">dataio.py:28</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_html"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html">caffe2.python.dataio.ReaderWithLimit</a></div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00409">dataio.py:409</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_html_a67e4d228c8017789e3331bff2b5d2537"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a67e4d228c8017789e3331bff2b5d2537">caffe2.python.dataio.Reader._schema</a></div><div class="ttdeci">_schema</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00041">dataio.py:41</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base_html_a2695eb809e444deca3fa9c1d1e6a45a0"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a2695eb809e444deca3fa9c1d1e6a45a0">caffe2.python.dataio.ReaderWithLimitBase.net</a></div><div class="ttdeci">net</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00328">dataio.py:328</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_pipe_html"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_pipe.html">caffe2.python.dataio.Pipe</a></div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00258">dataio.py:258</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_writer_html_a55b403eba95e44ab19e68dd164a9aaf1"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a55b403eba95e44ab19e68dd164a9aaf1">caffe2.python.dataio.Writer.write_record_ex</a></div><div class="ttdeci">def write_record_ex(self, fields, local_init_net, local_finish_net, stop_blob=None)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00189">dataio.py:189</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit_html_a71add0ae34dd8e3caf4acae256eca151"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a71add0ae34dd8e3caf4acae256eca151">caffe2.python.dataio.ReaderWithTimeLimit.__init__</a></div><div class="ttdeci">def __init__(self, reader, duration=0)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00458">dataio.py:458</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_writer_html_a3e270a50d9e2d65db196cddc56132c00"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a3e270a50d9e2d65db196cddc56132c00">caffe2.python.dataio.Writer.setup_ex</a></div><div class="ttdeci">def setup_ex(self, init_net, finish_net)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00178">dataio.py:178</a></div></div>
<div class="ttc" id="namespacecaffe2_1_1python_html"><div class="ttname"><a href="namespacecaffe2_1_1python.html">caffe2.python</a></div><div class="ttdef"><b>Definition:</b> <a href="python_2____init_____8py_source.html#l00001">__init__.py:1</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_pipe_html_a67fa37befe204abe20469aefcc435b5d"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_pipe.html#a67fa37befe204abe20469aefcc435b5d">caffe2.python.dataio.Pipe._num_writers</a></div><div class="ttdeci">_num_writers</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00260">dataio.py:260</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_pipe_html_a978c380d579e6ec821fe71e1be9d574d"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_pipe.html#a978c380d579e6ec821fe71e1be9d574d">caffe2.python.dataio.Pipe._obj_key</a></div><div class="ttdeci">_obj_key</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00263">dataio.py:263</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_piped_reader_builder_html_a5b880dde8089504e6a1d59d961211510"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_piped_reader_builder.html#a5b880dde8089504e6a1d59d961211510">caffe2.python.dataio.PipedReaderBuilder._builder</a></div><div class="ttdeci">_builder</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00239">dataio.py:239</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_piped_reader_builder_html"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_piped_reader_builder.html">caffe2.python.dataio.PipedReaderBuilder</a></div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00225">dataio.py:225</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit_html_abee021655958ec4fba6c3a611eb43ec4"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#abee021655958ec4fba6c3a611eb43ec4">caffe2.python.dataio.ReaderWithTimeLimit.timer</a></div><div class="ttdeci">timer</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00470">dataio.py:470</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_writer_html_a7fb018f843ba304edbd23f0e82328ece"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a7fb018f843ba304edbd23f0e82328ece">caffe2.python.dataio.Writer.commit</a></div><div class="ttdeci">def commit(self, finish_net)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00200">dataio.py:200</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_writer_html"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_writer.html">caffe2.python.dataio.Writer</a></div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00145">dataio.py:145</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_pipe_html_aeb582e1dc5b200f59799a85c7162aed9"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_pipe.html#aeb582e1dc5b200f59799a85c7162aed9">caffe2.python.dataio.Pipe._num_readers</a></div><div class="ttdeci">_num_readers</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00261">dataio.py:261</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_writer_html_a9d70c665219c46da12b0cfafdae8060a"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a9d70c665219c46da12b0cfafdae8060a">caffe2.python.dataio.Writer._schema</a></div><div class="ttdeci">_schema</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00155">dataio.py:155</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_counter_reader_html"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html">caffe2.python.dataio.CounterReader</a></div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00296">dataio.py:296</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_html_af3e6f05bed28a9630dc7a148cbb95098"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#af3e6f05bed28a9630dc7a148cbb95098">caffe2.python.dataio.ReaderWithLimit.counter</a></div><div class="ttdeci">counter</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00427">dataio.py:427</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1core_1_1_net_html"><div class="ttname"><a href="classcaffe2_1_1python_1_1core_1_1_net.html">caffe2.python.core.Net</a></div><div class="ttdef"><b>Definition:</b> <a href="core_8py_source.html#l01352">core.py:1352</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_html_ad6c5e15f2482793bebac92089d050bbc"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#ad6c5e15f2482793bebac92089d050bbc">caffe2.python.dataio.Reader.execution_step</a></div><div class="ttdeci">def execution_step(self, reader_net_name=None, external_should_stop=None)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00106">dataio.py:106</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base_html_a77b30909960c74b18df486f3e727da23"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a77b30909960c74b18df486f3e727da23">caffe2.python.dataio.ReaderWithLimitBase.check_limiter_condition</a></div><div class="ttdeci">def check_limiter_condition(self, stop_condition_net)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00389">dataio.py:389</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_html_a3e24214ecea0850be812df3296b3796b"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a3e24214ecea0850be812df3296b3796b">caffe2.python.dataio.Reader.reset</a></div><div class="ttdeci">def reset(self, net)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00092">dataio.py:92</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_html_a272213d199828188fff4e1f006285372"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a272213d199828188fff4e1f006285372">caffe2.python.dataio.Reader.read_record</a></div><div class="ttdeci">def read_record(self, read_net)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00100">dataio.py:100</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base_html_a969c829309710eced9c46c7372267f43"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a969c829309710eced9c46c7372267f43">caffe2.python.dataio.ReaderWithLimitBase.setup_limiter</a></div><div class="ttdeci">def setup_limiter(self, global_init_net, global_finish_net)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00379">dataio.py:379</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1schema_1_1_struct_html"><div class="ttname"><a href="classcaffe2_1_1python_1_1schema_1_1_struct.html">caffe2.python.schema.Struct</a></div><div class="ttdef"><b>Definition:</b> <a href="schema_8py_source.html#l00278">schema.py:278</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit_html"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html">caffe2.python.dataio.ReaderWithTimeLimit</a></div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00451">dataio.py:451</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base_html_a947fb82fe17fd625685cad6f63874c50"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html#a947fb82fe17fd625685cad6f63874c50">caffe2.python.dataio.ReaderWithLimitBase.read_ex</a></div><div class="ttdeci">def read_ex(self, local_init_net, local_finish_net)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00340">dataio.py:340</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base_html"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_base.html">caffe2.python.dataio.ReaderWithLimitBase</a></div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00315">dataio.py:315</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_writer_html_a77a746b74ca09dd9aee005330cc6916d"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a77a746b74ca09dd9aee005330cc6916d">caffe2.python.dataio.Writer.write</a></div><div class="ttdeci">def write(self, writer_net, fields)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00160">dataio.py:160</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit_html_a70002bd48f0f4d114520015b12bfdfbd"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_limit.html#a70002bd48f0f4d114520015b12bfdfbd">caffe2.python.dataio.ReaderWithLimit.__init__</a></div><div class="ttdeci">def __init__(self, reader, num_iter=1)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00416">dataio.py:416</a></div></div>
<div class="ttc" id="namespacecaffe2_1_1python_1_1schema_html"><div class="ttname"><a href="namespacecaffe2_1_1python_1_1schema.html">caffe2.python.schema</a></div><div class="ttdef"><b>Definition:</b> <a href="schema_8py_source.html#l00001">schema.py:1</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_writer_html_a8c0252988fae6e79ed51fa5407e244f6"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_writer.html#a8c0252988fae6e79ed51fa5407e244f6">caffe2.python.dataio.Writer.write_ex</a></div><div class="ttdeci">def write_ex(self, fields, local_init_net, local_finish_net, stop_blob)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00182">dataio.py:182</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit_html_a0ff62afd3c822f5bd0cfd7ba5c1b859a"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader_with_time_limit.html#a0ff62afd3c822f5bd0cfd7ba5c1b859a">caffe2.python.dataio.ReaderWithTimeLimit.duration</a></div><div class="ttdeci">duration</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00471">dataio.py:471</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_reader_html_a8d8909ca962957a5eb60f9d4007ef745"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_reader.html#a8d8909ca962957a5eb60f9d4007ef745">caffe2.python.dataio.Reader.setup_ex</a></div><div class="ttdeci">def setup_ex(self, init_net, finish_net)</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00050">dataio.py:50</a></div></div>
<div class="ttc" id="classcaffe2_1_1python_1_1dataio_1_1_counter_reader_html_aef4fa9db5d30aa1f08f744490ce8021f"><div class="ttname"><a href="classcaffe2_1_1python_1_1dataio_1_1_counter_reader.html#aef4fa9db5d30aa1f08f744490ce8021f">caffe2.python.dataio.CounterReader.counter</a></div><div class="ttdeci">counter</div><div class="ttdef"><b>Definition:</b> <a href="dataio_8py_source.html#l00300">dataio.py:300</a></div></div>
</div><!-- fragment --></div><!-- contents -->
<!-- HTML footer for doxygen 1.8.14-->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated on Thu Apr 19 2018 13:04:04 for Caffe2 - Python API by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.11
</small></address>
<div class="footerContainer">
  <div id="footer_wrap" class="wrapper footerWrapper">
    <div class="footerBlocks">
      <div id="fb_oss" class="footerSection fbOpenSourceFooter">
          <svg class="facebookOSSLogoSvg" viewBox="0 0 1133.9 1133.9" x="0px" y="0px" height=50 width=50>
            <g>
              <path class="logoRing outerRing" d="M 498.3 3.7 c 153.6 88.9 307.3 177.7 461.1 266.2 c 7.6 4.4 10.3 9.1 10.3 17.8 c -0.3 179.1 -0.2 358.3 0 537.4 c 0 8.1 -2.4 12.8 -9.7 17.1 c -154.5 88.9 -308.8 178.1 -462.9 267.5 c -9 5.2 -15.5 5.3 -24.6 0.1 c -153.9 -89.2 -307.9 -178 -462.1 -266.8 C 3 838.8 0 833.9 0 825.1 c 0.3 -179.1 0.2 -358.3 0 -537.4 c 0 -8.6 2.6 -13.6 10.2 -18 C 164.4 180.9 318.4 92 472.4 3 C 477 -1.5 494.3 -0.7 498.3 3.7 Z M 48.8 555.3 c 0 79.9 0.2 159.9 -0.2 239.8 c -0.1 10 3 15.6 11.7 20.6 c 137.2 78.8 274.2 157.8 411 237.3 c 9.9 5.7 17 5.7 26.8 0.1 c 137.5 -79.8 275.2 -159.2 412.9 -238.5 c 7.4 -4.3 10.5 -8.9 10.5 -17.8 c -0.3 -160.2 -0.3 -320.5 0 -480.7 c 0 -8.8 -2.8 -13.6 -10.3 -18 C 772.1 218 633.1 137.8 494.2 57.4 c -6.5 -3.8 -11.5 -4.5 -18.5 -0.5 C 336.8 137.4 197.9 217.7 58.8 297.7 c -7.7 4.4 -10.2 9.2 -10.2 17.9 C 48.9 395.5 48.8 475.4 48.8 555.3 Z" />
              <path class="logoRing middleRing" d="M 184.4 555.9 c 0 -33.3 -1 -66.7 0.3 -100 c 1.9 -48 24.1 -86 64.7 -110.9 c 54.8 -33.6 110.7 -65.5 167 -96.6 c 45.7 -25.2 92.9 -24.7 138.6 1 c 54.4 30.6 108.7 61.5 162.2 93.7 c 44 26.5 67.3 66.8 68 118.4 c 0.9 63.2 0.9 126.5 0 189.7 c -0.7 50.6 -23.4 90.7 -66.6 116.9 c -55 33.4 -110.8 65.4 -167.1 96.5 c -43.4 24 -89 24.2 -132.3 0.5 c -57.5 -31.3 -114.2 -64 -170 -98.3 c -41 -25.1 -62.9 -63.7 -64.5 -112.2 C 183.5 621.9 184.3 588.9 184.4 555.9 Z M 232.9 556.3 c 0 29.5 0.5 59.1 -0.1 88.6 c -0.8 39.2 16.9 67.1 50.2 86.2 c 51.2 29.4 102.2 59.2 153.4 88.4 c 31.4 17.9 63.6 18.3 95 0.6 c 53.7 -30.3 107.1 -61.2 160.3 -92.5 c 29.7 -17.5 45 -44.5 45.3 -78.8 c 0.6 -61.7 0.5 -123.5 0 -185.2 c -0.3 -34.4 -15.3 -61.5 -44.9 -79 C 637.7 352.6 583 320.8 527.9 290 c -27.5 -15.4 -57.2 -16.1 -84.7 -0.7 c -56.9 31.6 -113.4 64 -169.1 97.6 c -26.4 15.9 -40.7 41.3 -41.1 72.9 C 232.6 491.9 232.9 524.1 232.9 556.3 Z" />
              <path class="logoRing innerRing" d="M 484.9 424.4 c 69.8 -2.8 133.2 57.8 132.6 132 C 617 630 558.5 688.7 484.9 689.1 c -75.1 0.4 -132.6 -63.6 -132.7 -132.7 C 352.1 485 413.4 421.5 484.9 424.4 Z M 401.3 556.7 c -3.4 37.2 30.5 83.6 83 84.1 c 46.6 0.4 84.8 -37.6 84.9 -84 c 0.1 -46.6 -37.2 -84.4 -84.2 -84.6 C 432.2 472.1 397.9 518.3 401.3 556.7 Z" />
            </g>
          </svg>
        <h2>Facebook Open Source</h2>
      </div>
      <div class="footerSection">
        <a class="footerLink" href="https://code.facebook.com/projects/" target="_blank">Open Source Projects</a>
        <a class="footerLink" href="https://github.com/facebook/" target="_blank">GitHub</a>
        <a class="footerLink" href="https://twitter.com/fbOpenSource" target="_blank">Twitter</a>
      </div>
      <div class="footerSection rightAlign">
        <a class="footerLink" href="https://github.com/caffe2/caffe2" target="_blank">Contribute to this project on GitHub</a>
      </div>
    </div>
  </div>
</div>
<script type="text/javascript" src="/js/jekyll-link-anchors.js"></script>
<script>
  (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
  (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
  m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
  })(window,document,'script','//www.google-analytics.com/analytics.js','ga');
  ga('create', '{{ site.gacode }}', 'auto');
  ga('send', 'pageview');
</script>
</body>
</html>