Something went wrong on our end
-
abhishek-0802 authoredabhishek-0802 authored
navipy_processing_pcode_py.html 76.46 KiB
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=emulateIE7" />
<title>Coverage for navipy/processing/pcode.py: 68%</title>
<link rel="stylesheet" href="style.css" type="text/css">
<script type="text/javascript" src="jquery.min.js"></script>
<script type="text/javascript" src="jquery.hotkeys.js"></script>
<script type="text/javascript" src="jquery.isonscreen.js"></script>
<script type="text/javascript" src="coverage_html.js"></script>
<script type="text/javascript">
jQuery(document).ready(coverage.pyfile_ready);
</script>
</head>
<body class="pyfile">
<div id="header">
<div class="content">
<h1>Coverage for <b>navipy/processing/pcode.py</b> :
<span class="pc_cov">68%</span>
</h1>
<img id="keyboard_icon" src="keybd_closed.png" alt="Show keyboard shortcuts" />
<h2 class="stats">
140 statements
<span class="run hide_run shortkey_r button_toggle_run">95 run</span>
<span class="mis shortkey_m button_toggle_mis">45 missing</span>
<span class="exc shortkey_x button_toggle_exc">0 excluded</span>
</h2>
</div>
</div>
<div class="help_panel">
<img id="panel_icon" src="keybd_open.png" alt="Hide keyboard shortcuts" />
<p class="legend">Hot-keys on this page</p>
<div>
<p class="keyhelp">
<span class="key">r</span>
<span class="key">m</span>
<span class="key">x</span>
<span class="key">p</span> toggle line displays
</p>
<p class="keyhelp">
<span class="key">j</span>
<span class="key">k</span> next/prev highlighted chunk
</p>
<p class="keyhelp">
<span class="key">0</span> (zero) top of page
</p>
<p class="keyhelp">
<span class="key">1</span> (one) first highlighted chunk
</p>
</div>
</div>
<div id="source">
<table>
<tr>
<td class="linenos">
<p id="n1" class="pln"><a href="#n1">1</a></p>
<p id="n2" class="pln"><a href="#n2">2</a></p>
<p id="n3" class="pln"><a href="#n3">3</a></p>
<p id="n4" class="stm run hide_run"><a href="#n4">4</a></p>
<p id="n5" class="stm run hide_run"><a href="#n5">5</a></p>
<p id="n6" class="stm run hide_run"><a href="#n6">6</a></p>
<p id="n7" class="stm run hide_run"><a href="#n7">7</a></p>
<p id="n8" class="stm run hide_run"><a href="#n8">8</a></p>
<p id="n9" class="stm run hide_run"><a href="#n9">9</a></p>
<p id="n10" class="stm run hide_run"><a href="#n10">10</a></p>
<p id="n11" class="stm run hide_run"><a href="#n11">11</a></p>
<p id="n12" class="stm run hide_run"><a href="#n12">12</a></p>
<p id="n13" class="stm run hide_run"><a href="#n13">13</a></p>
<p id="n14" class="stm run hide_run"><a href="#n14">14</a></p>
<p id="n15" class="stm run hide_run"><a href="#n15">15</a></p>
<p id="n16" class="pln"><a href="#n16">16</a></p>
<p id="n17" class="pln"><a href="#n17">17</a></p>
<p id="n18" class="stm run hide_run"><a href="#n18">18</a></p>
<p id="n19" class="pln"><a href="#n19">19</a></p>
<p id="n20" class="pln"><a href="#n20">20</a></p>
<p id="n21" class="pln"><a href="#n21">21</a></p>
<p id="n22" class="pln"><a href="#n22">22</a></p>
<p id="n23" class="pln"><a href="#n23">23</a></p>
<p id="n24" class="pln"><a href="#n24">24</a></p>
<p id="n25" class="pln"><a href="#n25">25</a></p>
<p id="n26" class="stm run hide_run"><a href="#n26">26</a></p>
<p id="n27" class="stm run hide_run"><a href="#n27">27</a></p>
<p id="n28" class="stm run hide_run"><a href="#n28">28</a></p>
<p id="n29" class="stm run hide_run"><a href="#n29">29</a></p>
<p id="n30" class="stm run hide_run"><a href="#n30">30</a></p>
<p id="n31" class="pln"><a href="#n31">31</a></p>
<p id="n32" class="pln"><a href="#n32">32</a></p>
<p id="n33" class="stm run hide_run"><a href="#n33">33</a></p>
<p id="n34" class="pln"><a href="#n34">34</a></p>
<p id="n35" class="pln"><a href="#n35">35</a></p>
<p id="n36" class="pln"><a href="#n36">36</a></p>
<p id="n37" class="pln"><a href="#n37">37</a></p>
<p id="n38" class="pln"><a href="#n38">38</a></p>
<p id="n39" class="pln"><a href="#n39">39</a></p>
<p id="n40" class="pln"><a href="#n40">40</a></p>
<p id="n41" class="pln"><a href="#n41">41</a></p>
<p id="n42" class="pln"><a href="#n42">42</a></p>
<p id="n43" class="pln"><a href="#n43">43</a></p>
<p id="n44" class="pln"><a href="#n44">44</a></p>
<p id="n45" class="pln"><a href="#n45">45</a></p>
<p id="n46" class="pln"><a href="#n46">46</a></p>
<p id="n47" class="pln"><a href="#n47">47</a></p>
<p id="n48" class="pln"><a href="#n48">48</a></p>
<p id="n49" class="pln"><a href="#n49">49</a></p>
<p id="n50" class="stm run hide_run"><a href="#n50">50</a></p>
<p id="n51" class="stm run hide_run"><a href="#n51">51</a></p>
<p id="n52" class="stm mis"><a href="#n52">52</a></p>
<p id="n53" class="pln"><a href="#n53">53</a></p>
<p id="n54" class="stm run hide_run"><a href="#n54">54</a></p>
<p id="n55" class="stm run hide_run"><a href="#n55">55</a></p>
<p id="n56" class="stm run hide_run"><a href="#n56">56</a></p>
<p id="n57" class="stm run hide_run"><a href="#n57">57</a></p>
<p id="n58" class="stm run hide_run"><a href="#n58">58</a></p>
<p id="n59" class="stm run hide_run"><a href="#n59">59</a></p>
<p id="n60" class="stm run hide_run"><a href="#n60">60</a></p>
<p id="n61" class="pln"><a href="#n61">61</a></p>
<p id="n62" class="stm run hide_run"><a href="#n62">62</a></p>
<p id="n63" class="pln"><a href="#n63">63</a></p>
<p id="n64" class="stm run hide_run"><a href="#n64">64</a></p>
<p id="n65" class="stm run hide_run"><a href="#n65">65</a></p>
<p id="n66" class="stm run hide_run"><a href="#n66">66</a></p>
<p id="n67" class="stm run hide_run"><a href="#n67">67</a></p>
<p id="n68" class="stm run hide_run"><a href="#n68">68</a></p>
<p id="n69" class="stm run hide_run"><a href="#n69">69</a></p>
<p id="n70" class="stm run hide_run"><a href="#n70">70</a></p>
<p id="n71" class="stm run hide_run"><a href="#n71">71</a></p>
<p id="n72" class="stm run hide_run"><a href="#n72">72</a></p>
<p id="n73" class="pln"><a href="#n73">73</a></p>
<p id="n74" class="pln"><a href="#n74">74</a></p>
<p id="n75" class="stm run hide_run"><a href="#n75">75</a></p>
<p id="n76" class="pln"><a href="#n76">76</a></p>
<p id="n77" class="pln"><a href="#n77">77</a></p>
<p id="n78" class="pln"><a href="#n78">78</a></p>
<p id="n79" class="pln"><a href="#n79">79</a></p>
<p id="n80" class="pln"><a href="#n80">80</a></p>
<p id="n81" class="pln"><a href="#n81">81</a></p>
<p id="n82" class="pln"><a href="#n82">82</a></p>
<p id="n83" class="pln"><a href="#n83">83</a></p>
<p id="n84" class="stm run hide_run"><a href="#n84">84</a></p>
<p id="n85" class="stm run hide_run"><a href="#n85">85</a></p>
<p id="n86" class="stm run hide_run"><a href="#n86">86</a></p>
<p id="n87" class="stm run hide_run"><a href="#n87">87</a></p>
<p id="n88" class="stm run hide_run"><a href="#n88">88</a></p>
<p id="n89" class="stm run hide_run"><a href="#n89">89</a></p>
<p id="n90" class="stm run hide_run"><a href="#n90">90</a></p>
<p id="n91" class="stm run hide_run"><a href="#n91">91</a></p>
<p id="n92" class="stm run hide_run"><a href="#n92">92</a></p>
<p id="n93" class="stm run hide_run"><a href="#n93">93</a></p>
<p id="n94" class="stm mis"><a href="#n94">94</a></p>
<p id="n95" class="pln"><a href="#n95">95</a></p>
<p id="n96" class="stm run hide_run"><a href="#n96">96</a></p>
<p id="n97" class="stm run hide_run"><a href="#n97">97</a></p>
<p id="n98" class="stm run hide_run"><a href="#n98">98</a></p>
<p id="n99" class="stm run hide_run"><a href="#n99">99</a></p>
<p id="n100" class="stm run hide_run"><a href="#n100">100</a></p>
<p id="n101" class="pln"><a href="#n101">101</a></p>
<p id="n102" class="pln"><a href="#n102">102</a></p>
<p id="n103" class="stm run hide_run"><a href="#n103">103</a></p>
<p id="n104" class="pln"><a href="#n104">104</a></p>
<p id="n105" class="pln"><a href="#n105">105</a></p>
<p id="n106" class="pln"><a href="#n106">106</a></p>
<p id="n107" class="pln"><a href="#n107">107</a></p>
<p id="n108" class="pln"><a href="#n108">108</a></p>
<p id="n109" class="pln"><a href="#n109">109</a></p>
<p id="n110" class="pln"><a href="#n110">110</a></p>
<p id="n111" class="pln"><a href="#n111">111</a></p>
<p id="n112" class="pln"><a href="#n112">112</a></p>
<p id="n113" class="stm run hide_run"><a href="#n113">113</a></p>
<p id="n114" class="stm run hide_run"><a href="#n114">114</a></p>
<p id="n115" class="stm run hide_run"><a href="#n115">115</a></p>
<p id="n116" class="stm mis"><a href="#n116">116</a></p>
<p id="n117" class="stm mis"><a href="#n117">117</a></p>
<p id="n118" class="stm mis"><a href="#n118">118</a></p>
<p id="n119" class="pln"><a href="#n119">119</a></p>
<p id="n120" class="stm mis"><a href="#n120">120</a></p>
<p id="n121" class="pln"><a href="#n121">121</a></p>
<p id="n122" class="stm run hide_run"><a href="#n122">122</a></p>
<p id="n123" class="stm run hide_run"><a href="#n123">123</a></p>
<p id="n124" class="stm run hide_run"><a href="#n124">124</a></p>
<p id="n125" class="stm run hide_run"><a href="#n125">125</a></p>
<p id="n126" class="pln"><a href="#n126">126</a></p>
<p id="n127" class="stm run hide_run"><a href="#n127">127</a></p>
<p id="n128" class="stm mis"><a href="#n128">128</a></p>
<p id="n129" class="pln"><a href="#n129">129</a></p>
<p id="n130" class="stm run hide_run"><a href="#n130">130</a></p>
<p id="n131" class="stm mis"><a href="#n131">131</a></p>
<p id="n132" class="stm run hide_run"><a href="#n132">132</a></p>
<p id="n133" class="stm mis"><a href="#n133">133</a></p>
<p id="n134" class="pln"><a href="#n134">134</a></p>
<p id="n135" class="stm run hide_run"><a href="#n135">135</a></p>
<p id="n136" class="stm run hide_run"><a href="#n136">136</a></p>
<p id="n137" class="stm run hide_run"><a href="#n137">137</a></p>
<p id="n138" class="stm run hide_run"><a href="#n138">138</a></p>
<p id="n139" class="stm run hide_run"><a href="#n139">139</a></p>
<p id="n140" class="stm mis"><a href="#n140">140</a></p>
<p id="n141" class="stm run hide_run"><a href="#n141">141</a></p>
<p id="n142" class="stm run hide_run"><a href="#n142">142</a></p>
<p id="n143" class="stm run hide_run"><a href="#n143">143</a></p>
<p id="n144" class="stm run hide_run"><a href="#n144">144</a></p>
<p id="n145" class="stm run hide_run"><a href="#n145">145</a></p>
<p id="n146" class="stm run hide_run"><a href="#n146">146</a></p>
<p id="n147" class="pln"><a href="#n147">147</a></p>
<p id="n148" class="pln"><a href="#n148">148</a></p>
<p id="n149" class="stm run hide_run"><a href="#n149">149</a></p>
<p id="n150" class="stm run hide_run"><a href="#n150">150</a></p>
<p id="n151" class="stm run hide_run"><a href="#n151">151</a></p>
<p id="n152" class="stm run hide_run"><a href="#n152">152</a></p>
<p id="n153" class="pln"><a href="#n153">153</a></p>
<p id="n154" class="stm run hide_run"><a href="#n154">154</a></p>
<p id="n155" class="stm run hide_run"><a href="#n155">155</a></p>
<p id="n156" class="stm run hide_run"><a href="#n156">156</a></p>
<p id="n157" class="pln"><a href="#n157">157</a></p>
<p id="n158" class="stm run hide_run"><a href="#n158">158</a></p>
<p id="n159" class="stm run hide_run"><a href="#n159">159</a></p>
<p id="n160" class="pln"><a href="#n160">160</a></p>
<p id="n161" class="pln"><a href="#n161">161</a></p>
<p id="n162" class="stm run hide_run"><a href="#n162">162</a></p>
<p id="n163" class="pln"><a href="#n163">163</a></p>
<p id="n164" class="pln"><a href="#n164">164</a></p>
<p id="n165" class="pln"><a href="#n165">165</a></p>
<p id="n166" class="pln"><a href="#n166">166</a></p>
<p id="n167" class="pln"><a href="#n167">167</a></p>
<p id="n168" class="pln"><a href="#n168">168</a></p>
<p id="n169" class="pln"><a href="#n169">169</a></p>
<p id="n170" class="pln"><a href="#n170">170</a></p>
<p id="n171" class="stm run hide_run"><a href="#n171">171</a></p>
<p id="n172" class="stm run hide_run"><a href="#n172">172</a></p>
<p id="n173" class="stm run hide_run"><a href="#n173">173</a></p>
<p id="n174" class="stm run hide_run"><a href="#n174">174</a></p>
<p id="n175" class="pln"><a href="#n175">175</a></p>
<p id="n176" class="stm run hide_run"><a href="#n176">176</a></p>
<p id="n177" class="stm mis"><a href="#n177">177</a></p>
<p id="n178" class="pln"><a href="#n178">178</a></p>
<p id="n179" class="stm run hide_run"><a href="#n179">179</a></p>
<p id="n180" class="stm run hide_run"><a href="#n180">180</a></p>
<p id="n181" class="stm run hide_run"><a href="#n181">181</a></p>
<p id="n182" class="stm mis"><a href="#n182">182</a></p>
<p id="n183" class="stm mis"><a href="#n183">183</a></p>
<p id="n184" class="pln"><a href="#n184">184</a></p>
<p id="n185" class="stm mis"><a href="#n185">185</a></p>
<p id="n186" class="pln"><a href="#n186">186</a></p>
<p id="n187" class="pln"><a href="#n187">187</a></p>
<p id="n188" class="stm run hide_run"><a href="#n188">188</a></p>
<p id="n189" class="pln"><a href="#n189">189</a></p>
<p id="n190" class="pln"><a href="#n190">190</a></p>
<p id="n191" class="pln"><a href="#n191">191</a></p>
<p id="n192" class="pln"><a href="#n192">192</a></p>
<p id="n193" class="pln"><a href="#n193">193</a></p>
<p id="n194" class="pln"><a href="#n194">194</a></p>
<p id="n195" class="pln"><a href="#n195">195</a></p>
<p id="n196" class="pln"><a href="#n196">196</a></p>
<p id="n197" class="pln"><a href="#n197">197</a></p>
<p id="n198" class="pln"><a href="#n198">198</a></p>
<p id="n199" class="pln"><a href="#n199">199</a></p>
<p id="n200" class="pln"><a href="#n200">200</a></p>
<p id="n201" class="pln"><a href="#n201">201</a></p>
<p id="n202" class="pln"><a href="#n202">202</a></p>
<p id="n203" class="pln"><a href="#n203">203</a></p>
<p id="n204" class="pln"><a href="#n204">204</a></p>
<p id="n205" class="stm mis"><a href="#n205">205</a></p>
<p id="n206" class="pln"><a href="#n206">206</a></p>
<p id="n207" class="stm mis"><a href="#n207">207</a></p>
<p id="n208" class="stm mis"><a href="#n208">208</a></p>
<p id="n209" class="pln"><a href="#n209">209</a></p>
<p id="n210" class="stm mis"><a href="#n210">210</a></p>
<p id="n211" class="stm mis"><a href="#n211">211</a></p>
<p id="n212" class="stm mis"><a href="#n212">212</a></p>
<p id="n213" class="stm mis"><a href="#n213">213</a></p>
<p id="n214" class="stm mis"><a href="#n214">214</a></p>
<p id="n215" class="stm mis"><a href="#n215">215</a></p>
<p id="n216" class="stm mis"><a href="#n216">216</a></p>
<p id="n217" class="stm mis"><a href="#n217">217</a></p>
<p id="n218" class="stm mis"><a href="#n218">218</a></p>
<p id="n219" class="stm mis"><a href="#n219">219</a></p>
<p id="n220" class="stm mis"><a href="#n220">220</a></p>
<p id="n221" class="stm mis"><a href="#n221">221</a></p>
<p id="n222" class="stm mis"><a href="#n222">222</a></p>
<p id="n223" class="stm mis"><a href="#n223">223</a></p>
<p id="n224" class="stm mis"><a href="#n224">224</a></p>
<p id="n225" class="stm mis"><a href="#n225">225</a></p>
<p id="n226" class="pln"><a href="#n226">226</a></p>
<p id="n227" class="stm mis"><a href="#n227">227</a></p>
<p id="n228" class="stm mis"><a href="#n228">228</a></p>
<p id="n229" class="pln"><a href="#n229">229</a></p>
<p id="n230" class="stm mis"><a href="#n230">230</a></p>
<p id="n231" class="stm mis"><a href="#n231">231</a></p>
<p id="n232" class="stm mis"><a href="#n232">232</a></p>
<p id="n233" class="stm mis"><a href="#n233">233</a></p>
<p id="n234" class="pln"><a href="#n234">234</a></p>
<p id="n235" class="stm mis"><a href="#n235">235</a></p>
<p id="n236" class="stm mis"><a href="#n236">236</a></p>
<p id="n237" class="stm mis"><a href="#n237">237</a></p>
<p id="n238" class="stm mis"><a href="#n238">238</a></p>
<p id="n239" class="stm mis"><a href="#n239">239</a></p>
<p id="n240" class="stm mis"><a href="#n240">240</a></p>
</td>
<td class="text">
<p id="t1" class="pln"><span class="str">"""</span><span class="strut"> </span></p>
<p id="t2" class="pln"><span class="str">place code derived from scene</span><span class="strut"> </span></p>
<p id="t3" class="pln"><span class="str">"""</span><span class="strut"> </span></p>
<p id="t4" class="stm run hide_run"><span class="key">import</span> <span class="nam">numpy</span> <span class="key">as</span> <span class="nam">np</span><span class="strut"> </span></p>
<p id="t5" class="stm run hide_run"><span class="key">import</span> <span class="nam">pandas</span> <span class="key">as</span> <span class="nam">pd</span><span class="strut"> </span></p>
<p id="t6" class="stm run hide_run"><span class="key">from</span> <span class="nam">scipy</span><span class="op">.</span><span class="nam">ndimage</span> <span class="key">import</span> <span class="nam">maximum_filter</span><span class="op">,</span> <span class="nam">minimum_filter</span><span class="strut"> </span></p>
<p id="t7" class="stm run hide_run"><span class="key">from</span> <span class="nam">navipy</span><span class="op">.</span><span class="nam">scene</span> <span class="key">import</span> <span class="nam">__spherical_indeces__</span><span class="strut"> </span></p>
<p id="t8" class="stm run hide_run"><span class="key">from</span> <span class="nam">navipy</span><span class="op">.</span><span class="nam">scene</span> <span class="key">import</span> <span class="nam">__cartesian_indeces__</span><span class="strut"> </span></p>
<p id="t9" class="stm run hide_run"><span class="key">from</span> <span class="nam">navipy</span><span class="op">.</span><span class="nam">scene</span> <span class="key">import</span> <span class="nam">__ibpc_indeces__</span><span class="strut"> </span></p>
<p id="t10" class="stm run hide_run"><span class="key">from</span> <span class="nam">navipy</span><span class="op">.</span><span class="nam">scene</span> <span class="key">import</span> <span class="nam">__obpc_indeces__</span><span class="strut"> </span></p>
<p id="t11" class="stm run hide_run"><span class="key">from</span> <span class="nam">navipy</span><span class="op">.</span><span class="nam">scene</span> <span class="key">import</span> <span class="nam">is_ibpc</span><span class="strut"> </span></p>
<p id="t12" class="stm run hide_run"><span class="key">from</span> <span class="nam">navipy</span><span class="op">.</span><span class="nam">scene</span> <span class="key">import</span> <span class="nam">is_obpc</span><span class="strut"> </span></p>
<p id="t13" class="stm run hide_run"><span class="key">from</span> <span class="nam">navipy</span><span class="op">.</span><span class="nam">maths</span><span class="op">.</span><span class="nam">coordinates</span> <span class="key">import</span> <span class="nam">spherical_to_cartesian</span><span class="strut"> </span></p>
<p id="t14" class="stm run hide_run"><span class="key">from</span> <span class="nam">navipy</span><span class="op">.</span><span class="nam">scene</span> <span class="key">import</span> <span class="nam">check_scene</span><span class="strut"> </span></p>
<p id="t15" class="stm run hide_run"><span class="key">from</span> <span class="nam">navipy</span><span class="op">.</span><span class="nam">scene</span> <span class="key">import</span> <span class="nam">check_viewing_direction</span><span class="strut"> </span></p>
<p id="t16" class="pln"><span class="strut"> </span></p>
<p id="t17" class="pln"><span class="strut"> </span></p>
<p id="t18" class="stm run hide_run"><span class="key">def</span> <span class="nam">skyline</span><span class="op">(</span><span class="nam">scene</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t19" class="pln"> <span class="str">"""Return the average along the elevation of a scene</span><span class="strut"> </span></p>
<p id="t20" class="pln"><span class="strut"> </span></p>
<p id="t21" class="pln"><span class="str"> :param scene: the scenery at a given location (a 4d numpy array)</span><span class="strut"> </span></p>
<p id="t22" class="pln"><span class="str"> :returns: the skyline [1,azimuth,channel,1]</span><span class="strut"> </span></p>
<p id="t23" class="pln"><span class="str"> :rtype: np.ndarray</span><span class="strut"> </span></p>
<p id="t24" class="pln"><span class="strut"> </span></p>
<p id="t25" class="pln"><span class="str"> """</span><span class="strut"> </span></p>
<p id="t26" class="stm run hide_run"> <span class="key">if</span> <span class="key">not</span> <span class="nam">is_ibpc</span><span class="op">(</span><span class="nam">scene</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t27" class="stm run hide_run"> <span class="key">raise</span> <span class="nam">TypeError</span><span class="op">(</span><span class="str">'scene should be image based to compute a skyline'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t28" class="stm run hide_run"> <span class="nam">check_scene</span><span class="op">(</span><span class="nam">scene</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t29" class="stm run hide_run"> <span class="nam">skyline</span> <span class="op">=</span> <span class="nam">scene</span><span class="op">.</span><span class="nam">mean</span><span class="op">(</span><span class="nam">axis</span><span class="op">=</span><span class="nam">__ibpc_indeces__</span><span class="op">[</span><span class="str">'elevation'</span><span class="op">]</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t30" class="stm run hide_run"> <span class="key">return</span> <span class="nam">skyline</span><span class="op">[</span><span class="nam">np</span><span class="op">.</span><span class="nam">newaxis</span><span class="op">,</span> <span class="op">:</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t31" class="pln"><span class="strut"> </span></p>
<p id="t32" class="pln"><span class="strut"> </span></p>
<p id="t33" class="stm run hide_run"><span class="key">def</span> <span class="nam">michelson_contrast</span><span class="op">(</span><span class="nam">scene</span><span class="op">,</span> <span class="nam">size</span><span class="op">=</span><span class="num">3</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t34" class="pln"> <span class="str">"""Return the michelson constrast</span><span class="strut"> </span></p>
<p id="t35" class="pln"><span class="strut"> </span></p>
<p id="t36" class="pln"><span class="str"> .. math::</span><span class="strut"> </span></p>
<p id="t37" class="pln"><span class="strut"> </span></p>
<p id="t38" class="pln"><span class="str"> \\frac{I_\\text{max}-I_\\text{min}}{I_\\text{max}+I_\\text{min}}</span><span class="strut"> </span></p>
<p id="t39" class="pln"><span class="strut"> </span></p>
<p id="t40" class="pln"><span class="str"> with :math:`I_\\text{max}` and :math:`I_\\text{min}` representing the \</span><span class="strut"> </span></p>
<p id="t41" class="pln"><span class="str">highest and lowest luminance in an image region around each pixel.</span><span class="strut"> </span></p>
<p id="t42" class="pln"><span class="strut"> </span></p>
<p id="t43" class="pln"><span class="str"> :param scene: an image based scene</span><span class="strut"> </span></p>
<p id="t44" class="pln"><span class="str"> :param size: the size of the region to calculate the maximum \</span><span class="strut"> </span></p>
<p id="t45" class="pln"><span class="str">and minimum of the local image intensity</span><span class="strut"> </span></p>
<p id="t46" class="pln"><span class="str"> :returns: the michelson-contrast</span><span class="strut"> </span></p>
<p id="t47" class="pln"><span class="str"> :rtype: np.ndarray</span><span class="strut"> </span></p>
<p id="t48" class="pln"><span class="strut"> </span></p>
<p id="t49" class="pln"><span class="str"> """</span><span class="strut"> </span></p>
<p id="t50" class="stm run hide_run"> <span class="nam">check_scene</span><span class="op">(</span><span class="nam">scene</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t51" class="stm run hide_run"> <span class="key">if</span> <span class="key">not</span> <span class="nam">is_ibpc</span><span class="op">(</span><span class="nam">scene</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t52" class="stm mis"> <span class="key">raise</span> <span class="nam">TypeError</span><span class="op">(</span><span class="str">'scene should be image based\</span><span class="strut"> </span></p>
<p id="t53" class="pln"><span class="str"> to compute the michelson constrast'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t54" class="stm run hide_run"> <span class="key">if</span> <span class="key">not</span> <span class="nam">isinstance</span><span class="op">(</span><span class="nam">size</span><span class="op">,</span> <span class="nam">int</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t55" class="stm run hide_run"> <span class="key">raise</span> <span class="nam">TypeError</span><span class="op">(</span><span class="str">'size must be integer'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t56" class="stm run hide_run"> <span class="key">if</span> <span class="op">(</span><span class="nam">size</span> <span class="op"><</span> <span class="num">2</span> <span class="key">or</span> <span class="nam">size</span> <span class="op">></span> <span class="num">5</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t57" class="stm run hide_run"> <span class="key">raise</span> <span class="nam">ValueError</span><span class="op">(</span><span class="str">'size must be between 2 and 5'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t58" class="stm run hide_run"> <span class="nam">contrast</span> <span class="op">=</span> <span class="nam">np</span><span class="op">.</span><span class="nam">zeros_like</span><span class="op">(</span><span class="nam">scene</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t59" class="stm run hide_run"> <span class="key">for</span> <span class="nam">channel</span> <span class="key">in</span> <span class="nam">range</span><span class="op">(</span><span class="nam">scene</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="nam">__ibpc_indeces__</span><span class="op">[</span><span class="str">'channel'</span><span class="op">]</span><span class="op">]</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t60" class="stm run hide_run"> <span class="nam">i_max</span> <span class="op">=</span> <span class="nam">maximum_filter</span><span class="op">(</span><span class="nam">scene</span><span class="op">[</span><span class="op">...</span><span class="op">,</span> <span class="nam">channel</span><span class="op">,</span> <span class="num">0</span><span class="op">]</span><span class="op">,</span><span class="strut"> </span></p>
<p id="t61" class="pln"> <span class="nam">size</span><span class="op">=</span><span class="nam">size</span><span class="op">,</span> <span class="nam">mode</span><span class="op">=</span><span class="str">'wrap'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t62" class="stm run hide_run"> <span class="nam">i_min</span> <span class="op">=</span> <span class="nam">minimum_filter</span><span class="op">(</span><span class="nam">scene</span><span class="op">[</span><span class="op">...</span><span class="op">,</span> <span class="nam">channel</span><span class="op">,</span> <span class="num">0</span><span class="op">]</span><span class="op">,</span><span class="strut"> </span></p>
<p id="t63" class="pln"> <span class="nam">size</span><span class="op">=</span><span class="nam">size</span><span class="op">,</span> <span class="nam">mode</span><span class="op">=</span><span class="str">'wrap'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t64" class="stm run hide_run"> <span class="nam">divider</span> <span class="op">=</span> <span class="nam">i_max</span> <span class="op">+</span> <span class="nam">i_min</span><span class="strut"> </span></p>
<p id="t65" class="stm run hide_run"> <span class="nam">nonzero</span> <span class="op">=</span> <span class="nam">divider</span> <span class="op">!=</span> <span class="num">0</span><span class="strut"> </span></p>
<p id="t66" class="stm run hide_run"> <span class="nam">eqzero</span> <span class="op">=</span> <span class="nam">divider</span> <span class="op">==</span> <span class="num">0</span><span class="strut"> </span></p>
<p id="t67" class="stm run hide_run"> <span class="nam">i_min</span> <span class="op">=</span> <span class="nam">i_min</span><span class="op">[</span><span class="nam">nonzero</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t68" class="stm run hide_run"> <span class="nam">i_max</span> <span class="op">=</span> <span class="nam">i_max</span><span class="op">[</span><span class="nam">nonzero</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t69" class="stm run hide_run"> <span class="nam">divider</span> <span class="op">=</span> <span class="nam">divider</span><span class="op">[</span><span class="nam">nonzero</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t70" class="stm run hide_run"> <span class="nam">contrast</span><span class="op">[</span><span class="nam">nonzero</span><span class="op">,</span> <span class="nam">channel</span><span class="op">,</span> <span class="num">0</span><span class="op">]</span> <span class="op">=</span> <span class="op">(</span><span class="nam">i_max</span> <span class="op">-</span> <span class="nam">i_min</span><span class="op">)</span> <span class="op">/</span> <span class="nam">divider</span><span class="strut"> </span></p>
<p id="t71" class="stm run hide_run"> <span class="nam">contrast</span><span class="op">[</span><span class="nam">eqzero</span><span class="op">,</span> <span class="nam">channel</span><span class="op">,</span> <span class="num">0</span><span class="op">]</span> <span class="op">=</span> <span class="num">0</span><span class="strut"> </span></p>
<p id="t72" class="stm run hide_run"> <span class="key">return</span> <span class="nam">contrast</span><span class="strut"> </span></p>
<p id="t73" class="pln"><span class="strut"> </span></p>
<p id="t74" class="pln"><span class="strut"> </span></p>
<p id="t75" class="stm run hide_run"><span class="key">def</span> <span class="nam">contrast_weighted_nearness</span><span class="op">(</span><span class="nam">scene</span><span class="op">,</span> <span class="nam">contrast_size</span><span class="op">=</span><span class="num">3</span><span class="op">,</span> <span class="nam">distance_channel</span><span class="op">=</span><span class="num">3</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t76" class="pln"> <span class="str">"""Return the michelson contrast wheighted nearness</span><span class="strut"> </span></p>
<p id="t77" class="pln"><span class="strut"> </span></p>
<p id="t78" class="pln"><span class="str"> :param scene: an image based scene</span><span class="strut"> </span></p>
<p id="t79" class="pln"><span class="str"> :param contrast_size: the size of the region to calculate the maximum \</span><span class="strut"> </span></p>
<p id="t80" class="pln"><span class="str">and minimum of the local image intensity in the michelson-contrast.</span><span class="strut"> </span></p>
<p id="t81" class="pln"><span class="str"> :param distance_channel: the index of the distance-channel.</span><span class="strut"> </span></p>
<p id="t82" class="pln"><span class="strut"> </span></p>
<p id="t83" class="pln"><span class="str"> """</span><span class="strut"> </span></p>
<p id="t84" class="stm run hide_run"> <span class="nam">check_scene</span><span class="op">(</span><span class="nam">scene</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t85" class="stm run hide_run"> <span class="key">if</span> <span class="key">not</span> <span class="nam">isinstance</span><span class="op">(</span><span class="nam">contrast_size</span><span class="op">,</span> <span class="nam">int</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t86" class="stm run hide_run"> <span class="key">raise</span> <span class="nam">TypeError</span><span class="op">(</span><span class="str">'constrast size must be of type integer'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t87" class="stm run hide_run"> <span class="key">if</span> <span class="key">not</span> <span class="nam">isinstance</span><span class="op">(</span><span class="nam">distance_channel</span><span class="op">,</span> <span class="nam">int</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t88" class="stm run hide_run"> <span class="key">raise</span> <span class="nam">TypeError</span><span class="op">(</span><span class="str">'distance channel must be of type integer'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t89" class="stm run hide_run"> <span class="key">if</span> <span class="nam">contrast_size</span> <span class="key">not</span> <span class="key">in</span> <span class="nam">range</span><span class="op">(</span><span class="num">2</span><span class="op">,</span> <span class="num">6</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t90" class="stm run hide_run"> <span class="key">raise</span> <span class="nam">ValueError</span><span class="op">(</span><span class="str">'contrast size out of range'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t91" class="stm run hide_run"> <span class="key">if</span> <span class="nam">distance_channel</span> <span class="key">not</span> <span class="key">in</span> <span class="nam">range</span><span class="op">(</span><span class="num">4</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t92" class="stm run hide_run"> <span class="key">raise</span> <span class="nam">ValueError</span><span class="op">(</span><span class="str">'distance channel out of range'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t93" class="stm run hide_run"> <span class="key">if</span> <span class="key">not</span> <span class="nam">is_ibpc</span><span class="op">(</span><span class="nam">scene</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t94" class="stm mis"> <span class="key">raise</span> <span class="nam">TypeError</span><span class="op">(</span><span class="str">'scene should be image based to\</span><span class="strut"> </span></p>
<p id="t95" class="pln"><span class="str"> compute the contrast weighted nearness'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t96" class="stm run hide_run"> <span class="nam">contrast</span> <span class="op">=</span> <span class="nam">michelson_contrast</span><span class="op">(</span><span class="nam">scene</span><span class="op">,</span> <span class="nam">size</span><span class="op">=</span><span class="nam">contrast_size</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t97" class="stm run hide_run"> <span class="nam">distance</span> <span class="op">=</span> <span class="nam">scene</span><span class="op">[</span><span class="op">...</span><span class="op">,</span> <span class="nam">distance_channel</span><span class="op">,</span> <span class="num">0</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t98" class="stm run hide_run"> <span class="nam">distance</span> <span class="op">=</span> <span class="nam">distance</span><span class="op">[</span><span class="op">...</span><span class="op">,</span> <span class="nam">np</span><span class="op">.</span><span class="nam">newaxis</span><span class="op">,</span> <span class="nam">np</span><span class="op">.</span><span class="nam">newaxis</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t99" class="stm run hide_run"> <span class="nam">distance</span> <span class="op">=</span> <span class="nam">np</span><span class="op">.</span><span class="nam">tile</span><span class="op">(</span><span class="nam">distance</span><span class="op">,</span> <span class="op">(</span><span class="num">1</span><span class="op">,</span> <span class="num">1</span><span class="op">,</span> <span class="nam">scene</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="op">-</span><span class="num">2</span><span class="op">]</span><span class="op">,</span> <span class="num">1</span><span class="op">)</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t100" class="stm run hide_run"> <span class="key">return</span> <span class="nam">contrast</span> <span class="op">/</span> <span class="nam">distance</span><span class="strut"> </span></p>
<p id="t101" class="pln"><span class="strut"> </span></p>
<p id="t102" class="pln"><span class="strut"> </span></p>
<p id="t103" class="stm run hide_run"><span class="key">def</span> <span class="nam">pcv</span><span class="op">(</span><span class="nam">place_code</span><span class="op">,</span> <span class="nam">viewing_directions</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t104" class="pln"> <span class="str">"""Place code vectors</span><span class="strut"> </span></p>
<p id="t105" class="pln"><span class="strut"> </span></p>
<p id="t106" class="pln"><span class="str"> :param place_code: the place code at a given location (e.g. an ibs scene)</span><span class="strut"> </span></p>
<p id="t107" class="pln"><span class="str"> :param viewing_directions: viewing direction of each pixel</span><span class="strut"> </span></p>
<p id="t108" class="pln"><span class="str"> :returns: the place code vectors in cartesian coordinates</span><span class="strut"> </span></p>
<p id="t109" class="pln"><span class="str"> :rtype: (np.ndarray)</span><span class="strut"> </span></p>
<p id="t110" class="pln"><span class="strut"> </span></p>
<p id="t111" class="pln"><span class="str"> """</span><span class="strut"> </span></p>
<p id="t112" class="pln"> <span class="com"># print("place code shape",place_code.shape)</span><span class="strut"> </span></p>
<p id="t113" class="stm run hide_run"> <span class="key">if</span> <span class="nam">is_ibpc</span><span class="op">(</span><span class="nam">place_code</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t114" class="stm run hide_run"> <span class="nam">component_dim</span> <span class="op">=</span> <span class="nam">__ibpc_indeces__</span><span class="op">[</span><span class="str">'component'</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t115" class="stm run hide_run"> <span class="nam">channel_dim</span> <span class="op">=</span> <span class="nam">__ibpc_indeces__</span><span class="op">[</span><span class="str">'channel'</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t116" class="stm mis"> <span class="key">elif</span> <span class="nam">is_obpc</span><span class="op">(</span><span class="nam">place_code</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t117" class="stm mis"> <span class="nam">component_dim</span> <span class="op">=</span> <span class="nam">__obpc_indeces__</span><span class="op">[</span><span class="str">'component'</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t118" class="stm mis"> <span class="nam">channel_dim</span> <span class="op">=</span> <span class="nam">__obpc_indeces__</span><span class="op">[</span><span class="str">'channel'</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t119" class="pln"> <span class="key">else</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t120" class="stm mis"> <span class="key">raise</span> <span class="nam">TypeError</span><span class="op">(</span><span class="str">'place code should be either an ibpc or obpc'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t121" class="pln"><span class="strut"> </span></p>
<p id="t122" class="stm run hide_run"> <span class="nam">check_scene</span><span class="op">(</span><span class="nam">place_code</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t123" class="stm run hide_run"> <span class="nam">check_viewing_direction</span><span class="op">(</span><span class="nam">viewing_directions</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t124" class="stm run hide_run"> <span class="key">if</span> <span class="key">not</span> <span class="nam">place_code</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="num">0</span><span class="op">]</span> <span class="op">==</span> <span class="nam">viewing_directions</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="num">0</span><span class="op">]</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t125" class="stm run hide_run"> <span class="key">raise</span> <span class="nam">Exception</span><span class="op">(</span><span class="str">'dimensions of place code and viewing\</span><span class="strut"> </span></p>
<p id="t126" class="pln"><span class="str"> direction do not match'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t127" class="stm run hide_run"> <span class="key">if</span> <span class="key">not</span> <span class="nam">place_code</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="num">1</span><span class="op">]</span> <span class="op">==</span> <span class="nam">viewing_directions</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="num">1</span><span class="op">]</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t128" class="stm mis"> <span class="key">raise</span> <span class="nam">Exception</span><span class="op">(</span><span class="str">'dimensions of place code and viewing\</span><span class="strut"> </span></p>
<p id="t129" class="pln"><span class="str"> direction do not match'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t130" class="stm run hide_run"> <span class="key">if</span> <span class="key">not</span> <span class="nam">isinstance</span><span class="op">(</span><span class="nam">viewing_directions</span><span class="op">,</span> <span class="nam">np</span><span class="op">.</span><span class="nam">ndarray</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t131" class="stm mis"> <span class="key">raise</span> <span class="nam">TypeError</span><span class="op">(</span><span class="str">'viewing_directions should be a numpy array'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t132" class="stm run hide_run"> <span class="key">if</span> <span class="key">not</span> <span class="nam">place_code</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="nam">component_dim</span><span class="op">]</span> <span class="op">==</span> <span class="num">1</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t133" class="stm mis"> <span class="key">raise</span> <span class="nam">Exception</span><span class="op">(</span><span class="str">'the last dimension ({}) of the place-code\</span><span class="strut"> </span></p>
<p id="t134" class="pln"><span class="str"> should be 1'</span><span class="op">.</span><span class="nam">format</span><span class="op">(</span><span class="nam">place_code</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="nam">component_dim</span><span class="op">]</span><span class="op">)</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t135" class="stm run hide_run"> <span class="nam">elevation</span> <span class="op">=</span> <span class="nam">viewing_directions</span><span class="op">[</span><span class="op">...</span><span class="op">,</span> <span class="nam">__spherical_indeces__</span><span class="op">[</span><span class="str">'elevation'</span><span class="op">]</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t136" class="stm run hide_run"> <span class="nam">azimuth</span> <span class="op">=</span> <span class="nam">viewing_directions</span><span class="op">[</span><span class="op">...</span><span class="op">,</span> <span class="nam">__spherical_indeces__</span><span class="op">[</span><span class="str">'azimuth'</span><span class="op">]</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t137" class="stm run hide_run"> <span class="key">if</span> <span class="op">(</span><span class="nam">np</span><span class="op">.</span><span class="nam">any</span><span class="op">(</span><span class="nam">elevation</span> <span class="op"><=</span> <span class="op">-</span><span class="nam">np</span><span class="op">.</span><span class="nam">pi</span><span class="op">)</span> <span class="key">or</span> <span class="nam">np</span><span class="op">.</span><span class="nam">any</span><span class="op">(</span><span class="nam">elevation</span> <span class="op">>=</span> <span class="nam">np</span><span class="op">.</span><span class="nam">pi</span><span class="op">)</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t138" class="stm run hide_run"> <span class="key">raise</span> <span class="nam">ValueError</span><span class="op">(</span><span class="str">" Elevation must be radians in range [-pi;pi]"</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t139" class="stm run hide_run"> <span class="key">if</span> <span class="op">(</span><span class="nam">np</span><span class="op">.</span><span class="nam">max</span><span class="op">(</span><span class="nam">elevation</span><span class="op">)</span> <span class="op">-</span> <span class="nam">np</span><span class="op">.</span><span class="nam">min</span><span class="op">(</span><span class="nam">elevation</span><span class="op">)</span> <span class="op">>=</span> <span class="num">2</span> <span class="op">*</span> <span class="nam">np</span><span class="op">.</span><span class="nam">pi</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t140" class="stm mis"> <span class="key">raise</span> <span class="nam">ValueError</span><span class="op">(</span><span class="str">" max difference in elevation must be < 2*pi"</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t141" class="stm run hide_run"> <span class="key">if</span> <span class="op">(</span><span class="nam">np</span><span class="op">.</span><span class="nam">any</span><span class="op">(</span><span class="nam">azimuth</span> <span class="op"><=</span> <span class="op">-</span><span class="num">2</span><span class="op">*</span><span class="nam">np</span><span class="op">.</span><span class="nam">pi</span><span class="op">)</span> <span class="key">or</span> <span class="nam">np</span><span class="op">.</span><span class="nam">any</span><span class="op">(</span><span class="nam">azimuth</span> <span class="op">>=</span> <span class="num">2</span><span class="op">*</span><span class="nam">np</span><span class="op">.</span><span class="nam">pi</span><span class="op">)</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t142" class="stm run hide_run"> <span class="key">raise</span> <span class="nam">ValueError</span><span class="op">(</span><span class="str">" Azimuth must be radians in range [-2*pi;2*pi]"</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t143" class="stm run hide_run"> <span class="key">if</span> <span class="op">(</span><span class="nam">np</span><span class="op">.</span><span class="nam">max</span><span class="op">(</span><span class="nam">azimuth</span><span class="op">)</span> <span class="op">-</span> <span class="nam">np</span><span class="op">.</span><span class="nam">min</span><span class="op">(</span><span class="nam">azimuth</span><span class="op">)</span> <span class="op">></span> <span class="num">2</span> <span class="op">*</span> <span class="nam">np</span><span class="op">.</span><span class="nam">pi</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t144" class="stm run hide_run"> <span class="key">raise</span> <span class="nam">ValueError</span><span class="op">(</span><span class="str">" max difference in azimuth must be <= 2*pi"</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t145" class="stm run hide_run"> <span class="nam">x</span><span class="op">,</span> <span class="nam">y</span><span class="op">,</span> <span class="nam">z</span> <span class="op">=</span> <span class="nam">spherical_to_cartesian</span><span class="op">(</span><span class="nam">elevation</span><span class="op">,</span> <span class="nam">azimuth</span><span class="op">,</span> <span class="nam">radius</span><span class="op">=</span><span class="num">1</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t146" class="stm run hide_run"> <span class="nam">unscaled_lv</span> <span class="op">=</span> <span class="nam">np</span><span class="op">.</span><span class="nam">zeros</span><span class="op">(</span><span class="op">(</span><span class="nam">viewing_directions</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="num">0</span><span class="op">]</span><span class="op">,</span><span class="strut"> </span></p>
<p id="t147" class="pln"> <span class="nam">viewing_directions</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="num">1</span><span class="op">]</span><span class="op">,</span><span class="strut"> </span></p>
<p id="t148" class="pln"> <span class="num">3</span><span class="op">)</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t149" class="stm run hide_run"> <span class="nam">unscaled_lv</span><span class="op">[</span><span class="op">...</span><span class="op">,</span> <span class="nam">__cartesian_indeces__</span><span class="op">[</span><span class="str">'x'</span><span class="op">]</span><span class="op">]</span> <span class="op">=</span> <span class="nam">x</span><span class="strut"> </span></p>
<p id="t150" class="stm run hide_run"> <span class="nam">unscaled_lv</span><span class="op">[</span><span class="op">...</span><span class="op">,</span> <span class="nam">__cartesian_indeces__</span><span class="op">[</span><span class="str">'y'</span><span class="op">]</span><span class="op">]</span> <span class="op">=</span> <span class="nam">y</span><span class="strut"> </span></p>
<p id="t151" class="stm run hide_run"> <span class="nam">unscaled_lv</span><span class="op">[</span><span class="op">...</span><span class="op">,</span> <span class="nam">__cartesian_indeces__</span><span class="op">[</span><span class="str">'z'</span><span class="op">]</span><span class="op">]</span> <span class="op">=</span> <span class="nam">z</span><span class="strut"> </span></p>
<p id="t152" class="stm run hide_run"> <span class="nam">scaled_lv</span> <span class="op">=</span> <span class="nam">np</span><span class="op">.</span><span class="nam">zeros_like</span><span class="op">(</span><span class="nam">place_code</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t153" class="pln"> <span class="com"># (3,) -> (1,1,3) or (1,1,1,3) see numpy.tile</span><span class="strut"> </span></p>
<p id="t154" class="stm run hide_run"> <span class="nam">scaled_lv</span> <span class="op">=</span> <span class="nam">np</span><span class="op">.</span><span class="nam">tile</span><span class="op">(</span><span class="nam">scaled_lv</span><span class="op">,</span> <span class="op">(</span><span class="nam">unscaled_lv</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="op">-</span><span class="num">1</span><span class="op">]</span><span class="op">,</span><span class="op">)</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t155" class="stm run hide_run"> <span class="key">for</span> <span class="nam">channel_index</span> <span class="key">in</span> <span class="nam">range</span><span class="op">(</span><span class="num">0</span><span class="op">,</span> <span class="nam">scaled_lv</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="nam">channel_dim</span><span class="op">]</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t156" class="stm run hide_run"> <span class="nam">radius</span> <span class="op">=</span> <span class="nam">np</span><span class="op">.</span><span class="nam">tile</span><span class="op">(</span><span class="nam">place_code</span><span class="op">[</span><span class="op">...</span><span class="op">,</span> <span class="nam">channel_index</span><span class="op">,</span> <span class="num">0</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t157" class="pln"> <span class="op">[</span><span class="op">...</span><span class="op">,</span> <span class="nam">np</span><span class="op">.</span><span class="nam">newaxis</span><span class="op">]</span><span class="op">,</span> <span class="op">(</span><span class="nam">scaled_lv</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="op">-</span><span class="num">1</span><span class="op">]</span><span class="op">,</span><span class="op">)</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t158" class="stm run hide_run"> <span class="nam">scaled_lv</span><span class="op">[</span><span class="op">...</span><span class="op">,</span> <span class="nam">channel_index</span><span class="op">,</span> <span class="op">:</span><span class="op">]</span> <span class="op">=</span> <span class="nam">unscaled_lv</span> <span class="op">*</span> <span class="nam">radius</span><span class="strut"> </span></p>
<p id="t159" class="stm run hide_run"> <span class="key">return</span> <span class="nam">scaled_lv</span><span class="strut"> </span></p>
<p id="t160" class="pln"><span class="strut"> </span></p>
<p id="t161" class="pln"><span class="strut"> </span></p>
<p id="t162" class="stm run hide_run"><span class="key">def</span> <span class="nam">apcv</span><span class="op">(</span><span class="nam">place_code</span><span class="op">,</span> <span class="nam">viewing_directions</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t163" class="pln"> <span class="str">"""Calculate the average scene vector</span><span class="strut"> </span></p>
<p id="t164" class="pln"><span class="strut"> </span></p>
<p id="t165" class="pln"><span class="str"> :param place_code: the place code at a given location (e.g. an ibs scene)</span><span class="strut"> </span></p>
<p id="t166" class="pln"><span class="str"> :param viewing_directions: viewing direction of each pixel</span><span class="strut"> </span></p>
<p id="t167" class="pln"><span class="str"> :returns: the average place-code vector</span><span class="strut"> </span></p>
<p id="t168" class="pln"><span class="str"> :rtype: (np.ndarray)</span><span class="strut"> </span></p>
<p id="t169" class="pln"><span class="strut"> </span></p>
<p id="t170" class="pln"><span class="str"> """</span><span class="strut"> </span></p>
<p id="t171" class="stm run hide_run"> <span class="nam">check_scene</span><span class="op">(</span><span class="nam">place_code</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t172" class="stm run hide_run"> <span class="nam">check_viewing_direction</span><span class="op">(</span><span class="nam">viewing_directions</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t173" class="stm run hide_run"> <span class="key">if</span> <span class="key">not</span> <span class="nam">place_code</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="num">0</span><span class="op">]</span> <span class="op">==</span> <span class="nam">viewing_directions</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="num">0</span><span class="op">]</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t174" class="stm run hide_run"> <span class="key">raise</span> <span class="nam">Exception</span><span class="op">(</span><span class="str">'dimensions of place code and viewing\</span><span class="strut"> </span></p>
<p id="t175" class="pln"><span class="str"> direction do not match'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t176" class="stm run hide_run"> <span class="key">if</span> <span class="key">not</span> <span class="nam">place_code</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="num">1</span><span class="op">]</span> <span class="op">==</span> <span class="nam">viewing_directions</span><span class="op">.</span><span class="nam">shape</span><span class="op">[</span><span class="num">1</span><span class="op">]</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t177" class="stm mis"> <span class="key">raise</span> <span class="nam">Exception</span><span class="op">(</span><span class="str">'dimensions of place code and viewing\</span><span class="strut"> </span></p>
<p id="t178" class="pln"><span class="str"> direction do not match'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t179" class="stm run hide_run"> <span class="nam">scaled_lv</span> <span class="op">=</span> <span class="nam">pcv</span><span class="op">(</span><span class="nam">place_code</span><span class="op">,</span> <span class="nam">viewing_directions</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t180" class="stm run hide_run"> <span class="key">if</span> <span class="nam">is_ibpc</span><span class="op">(</span><span class="nam">place_code</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t181" class="stm run hide_run"> <span class="key">return</span> <span class="op">(</span><span class="nam">scaled_lv</span><span class="op">.</span><span class="nam">sum</span><span class="op">(</span><span class="nam">axis</span><span class="op">=</span><span class="num">0</span><span class="op">)</span><span class="op">.</span><span class="nam">sum</span><span class="op">(</span><span class="nam">axis</span><span class="op">=</span><span class="num">0</span><span class="op">)</span><span class="op">)</span><span class="op">[</span><span class="nam">np</span><span class="op">.</span><span class="nam">newaxis</span><span class="op">,</span> <span class="nam">np</span><span class="op">.</span><span class="nam">newaxis</span><span class="op">,</span> <span class="op">...</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t182" class="stm mis"> <span class="key">elif</span> <span class="nam">is_obpc</span><span class="op">(</span><span class="nam">place_code</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t183" class="stm mis"> <span class="key">return</span> <span class="op">(</span><span class="nam">scaled_lv</span><span class="op">.</span><span class="nam">sum</span><span class="op">(</span><span class="nam">axis</span><span class="op">=</span><span class="num">0</span><span class="op">)</span><span class="op">)</span><span class="op">[</span><span class="nam">np</span><span class="op">.</span><span class="nam">newaxis</span><span class="op">,</span> <span class="op">...</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t184" class="pln"> <span class="key">else</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t185" class="stm mis"> <span class="key">raise</span> <span class="nam">TypeError</span><span class="op">(</span><span class="str">'place code is neither an ibpc nor obpc'</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t186" class="pln"><span class="strut"> </span></p>
<p id="t187" class="pln"><span class="strut"> </span></p>
<p id="t188" class="stm run hide_run"><span class="key">def</span> <span class="nam">nposorient_around_ref</span><span class="op">(</span><span class="nam">mydb</span><span class="op">,</span><span class="strut"> </span></p>
<p id="t189" class="pln"> <span class="nam">position_df</span><span class="op">,</span><span class="strut"> </span></p>
<p id="t190" class="pln"> <span class="nam">ref_pos</span><span class="op">,</span><span class="strut"> </span></p>
<p id="t191" class="pln"> <span class="nam">nb_snapshot</span><span class="op">,</span><span class="strut"> </span></p>
<p id="t192" class="pln"> <span class="nam">radius</span><span class="op">,</span><span class="strut"> </span></p>
<p id="t193" class="pln"> <span class="nam">blender_view</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t194" class="pln"> <span class="str">"""Return set of views around and oriented towards memorized location</span><span class="strut"> </span></p>
<p id="t195" class="pln"><span class="str"> :param mydb: Database environment</span><span class="strut"> </span></p>
<p id="t196" class="pln"><span class="str"> :param position_df: dataframe with the positions of the grid</span><span class="strut"> </span></p>
<p id="t197" class="pln"><span class="str"> :param ref_pos: df with x, y and z position of the reference snapshot</span><span class="strut"> </span></p>
<p id="t198" class="pln"><span class="str"> :param nb_snapshot: number of wanted set of views (multiple of 2)</span><span class="strut"> </span></p>
<p id="t199" class="pln"><span class="str"> :param radius: distance from memorized location to take snapshots</span><span class="strut"> </span></p>
<p id="t200" class="pln"><span class="str"> :param blender_view: viewing axis camera id y=90, if x=0</span><span class="strut"> </span></p>
<p id="t201" class="pln"><span class="str"> :returns: list of reoriented image array, snaphots positions</span><span class="strut"> </span></p>
<p id="t202" class="pln"><span class="str"> :rtypes: array of np.array, pd.DataFrame</span><span class="strut"> </span></p>
<p id="t203" class="pln"><span class="str"> """</span><span class="strut"> </span></p>
<p id="t204" class="pln"><span class="strut"> </span></p>
<p id="t205" class="stm mis"> <span class="nam">svp_all</span> <span class="op">=</span> <span class="nam">pd</span><span class="op">.</span><span class="nam">DataFrame</span><span class="op">(</span><span class="nam">columns</span><span class="op">=</span><span class="op">[</span><span class="str">'x'</span><span class="op">,</span> <span class="str">'y'</span><span class="op">,</span> <span class="str">'z'</span><span class="op">,</span> <span class="str">'frame'</span><span class="op">]</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t206" class="pln"> <span class="com"># angle of rotation</span><span class="strut"> </span></p>
<p id="t207" class="stm mis"> <span class="nam">ang_deg</span> <span class="op">=</span> <span class="num">360</span> <span class="op">/</span> <span class="nam">nb_snapshot</span><span class="strut"> </span></p>
<p id="t208" class="stm mis"> <span class="nam">ang</span> <span class="op">=</span> <span class="nam">np</span><span class="op">.</span><span class="nam">deg2rad</span><span class="op">(</span><span class="nam">ang_deg</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t209" class="pln"> <span class="com"># make the different view</span><span class="strut"> </span></p>
<p id="t210" class="stm mis"> <span class="key">for</span> <span class="nam">i</span> <span class="key">in</span> <span class="nam">range</span><span class="op">(</span><span class="num">0</span><span class="op">,</span> <span class="nam">nb_snapshot</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t211" class="stm mis"> <span class="nam">x</span> <span class="op">=</span> <span class="nam">ref_pos</span><span class="op">.</span><span class="nam">x</span> <span class="op">+</span> <span class="nam">radius</span> <span class="op">*</span> <span class="nam">np</span><span class="op">.</span><span class="nam">cos</span><span class="op">(</span><span class="nam">ang</span> <span class="op">*</span> <span class="nam">i</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t212" class="stm mis"> <span class="nam">y</span> <span class="op">=</span> <span class="nam">ref_pos</span><span class="op">.</span><span class="nam">y</span> <span class="op">+</span> <span class="nam">radius</span> <span class="op">*</span> <span class="nam">np</span><span class="op">.</span><span class="nam">sin</span><span class="op">(</span><span class="nam">ang</span> <span class="op">*</span> <span class="nam">i</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t213" class="stm mis"> <span class="nam">z</span> <span class="op">=</span> <span class="nam">ref_pos</span><span class="op">.</span><span class="nam">z</span><span class="strut"> </span></p>
<p id="t214" class="stm mis"> <span class="nam">svp_frame</span> <span class="op">=</span> <span class="nam">pd</span><span class="op">.</span><span class="nam">Series</span><span class="op">(</span><span class="nam">index</span><span class="op">=</span><span class="op">[</span><span class="str">'frame'</span><span class="op">,</span> <span class="str">'x'</span><span class="op">,</span> <span class="str">'y'</span><span class="op">,</span> <span class="str">'z'</span><span class="op">]</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t215" class="stm mis"> <span class="nam">distance_arr</span> <span class="op">=</span> <span class="nam">pd</span><span class="op">.</span><span class="nam">Series</span><span class="op">(</span><span class="nam">index</span><span class="op">=</span><span class="nam">position_df</span><span class="op">.</span><span class="nam">index</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t216" class="stm mis"> <span class="key">for</span> <span class="nam">index</span><span class="op">,</span> <span class="nam">pos</span> <span class="key">in</span> <span class="nam">position_df</span><span class="op">.</span><span class="nam">dropna</span><span class="op">(</span><span class="op">)</span><span class="op">.</span><span class="nam">iterrows</span><span class="op">(</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t217" class="stm mis"> <span class="nam">distance</span> <span class="op">=</span> <span class="op">(</span><span class="nam">pos</span><span class="op">.</span><span class="nam">x</span> <span class="op">-</span> <span class="nam">x</span><span class="op">)</span><span class="op">**</span><span class="num">2</span><span class="strut"> </span></p>
<p id="t218" class="stm mis"> <span class="nam">distance</span> <span class="op">+=</span> <span class="op">(</span><span class="nam">pos</span><span class="op">.</span><span class="nam">y</span> <span class="op">-</span> <span class="nam">y</span><span class="op">)</span><span class="op">**</span><span class="num">2</span><span class="strut"> </span></p>
<p id="t219" class="stm mis"> <span class="nam">distance</span> <span class="op">+=</span> <span class="op">(</span><span class="nam">pos</span><span class="op">.</span><span class="nam">z</span> <span class="op">-</span> <span class="nam">z</span><span class="op">)</span><span class="op">**</span><span class="num">2</span><span class="strut"> </span></p>
<p id="t220" class="stm mis"> <span class="nam">distance_arr</span><span class="op">[</span><span class="nam">index</span><span class="op">]</span> <span class="op">=</span> <span class="nam">distance</span><span class="strut"> </span></p>
<p id="t221" class="stm mis"> <span class="nam">svp_frame</span><span class="op">.</span><span class="nam">frame</span> <span class="op">=</span> <span class="nam">int</span><span class="op">(</span><span class="nam">distance_arr</span><span class="op">.</span><span class="nam">dropna</span><span class="op">(</span><span class="op">)</span><span class="op">.</span><span class="nam">argmin</span><span class="op">(</span><span class="op">)</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t222" class="stm mis"> <span class="nam">svp_frame</span><span class="op">.</span><span class="nam">x</span> <span class="op">=</span> <span class="nam">position_df</span><span class="op">.</span><span class="nam">x</span><span class="op">[</span><span class="nam">svp_frame</span><span class="op">.</span><span class="nam">frame</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t223" class="stm mis"> <span class="nam">svp_frame</span><span class="op">.</span><span class="nam">y</span> <span class="op">=</span> <span class="nam">position_df</span><span class="op">.</span><span class="nam">y</span><span class="op">[</span><span class="nam">svp_frame</span><span class="op">.</span><span class="nam">frame</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t224" class="stm mis"> <span class="nam">svp_frame</span><span class="op">.</span><span class="nam">z</span> <span class="op">=</span> <span class="nam">position_df</span><span class="op">.</span><span class="nam">z</span><span class="op">[</span><span class="nam">svp_frame</span><span class="op">.</span><span class="nam">frame</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t225" class="stm mis"> <span class="nam">svp_all</span><span class="op">.</span><span class="nam">loc</span><span class="op">[</span><span class="nam">i</span><span class="op">]</span> <span class="op">=</span> <span class="op">[</span><span class="nam">svp_frame</span><span class="op">.</span><span class="nam">x</span><span class="op">,</span> <span class="nam">svp_frame</span><span class="op">.</span><span class="nam">y</span><span class="op">,</span><span class="strut"> </span></p>
<p id="t226" class="pln"> <span class="nam">svp_frame</span><span class="op">.</span><span class="nam">z</span><span class="op">,</span> <span class="nam">int</span><span class="op">(</span><span class="nam">svp_frame</span><span class="op">.</span><span class="nam">frame</span><span class="op">)</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t227" class="stm mis"> <span class="nam">reoriented_mem</span> <span class="op">=</span> <span class="op">[</span><span class="op">]</span><span class="strut"> </span></p>
<p id="t228" class="stm mis"> <span class="nam">rot</span> <span class="op">=</span> <span class="nam">list</span><span class="op">(</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t229" class="pln"><span class="strut"> </span></p>
<p id="t230" class="stm mis"> <span class="key">for</span> <span class="nam">i</span><span class="op">,</span> <span class="nam">j</span> <span class="key">in</span> <span class="nam">svp_all</span><span class="op">.</span><span class="nam">iterrows</span><span class="op">(</span><span class="op">)</span><span class="op">:</span><span class="strut"> </span></p>
<p id="t231" class="stm mis"> <span class="nam">ide</span> <span class="op">=</span> <span class="nam">int</span><span class="op">(</span><span class="nam">j</span><span class="op">.</span><span class="nam">frame</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t232" class="stm mis"> <span class="nam">image</span> <span class="op">=</span> <span class="nam">mydb</span><span class="op">.</span><span class="nam">scene</span><span class="op">(</span><span class="nam">rowid</span><span class="op">=</span><span class="nam">ide</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t233" class="stm mis"> <span class="nam">alpha</span> <span class="op">=</span> <span class="nam">np</span><span class="op">.</span><span class="nam">floor</span><span class="op">(</span><span class="nam">np</span><span class="op">.</span><span class="nam">rad2deg</span><span class="op">(</span><span class="nam">np</span><span class="op">.</span><span class="nam">arctan2</span><span class="op">(</span><span class="strut"> </span></p>
<p id="t234" class="pln"> <span class="op">(</span><span class="nam">ref_pos</span><span class="op">.</span><span class="nam">y</span> <span class="op">-</span> <span class="nam">j</span><span class="op">.</span><span class="nam">y</span><span class="op">)</span><span class="op">,</span> <span class="op">(</span><span class="nam">ref_pos</span><span class="op">.</span><span class="nam">x</span> <span class="op">-</span> <span class="nam">j</span><span class="op">.</span><span class="nam">x</span><span class="op">)</span><span class="op">)</span><span class="op">)</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t235" class="stm mis"> <span class="nam">alpha</span> <span class="op">=</span> <span class="nam">alpha</span> <span class="op">+</span> <span class="nam">blender_view</span> <span class="com"># because y view on blender</span><span class="strut"> </span></p>
<p id="t236" class="stm mis"> <span class="nam">rot</span><span class="op">.</span><span class="nam">append</span><span class="op">(</span><span class="nam">alpha</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t237" class="stm mis"> <span class="nam">alpha</span> <span class="op">=</span> <span class="nam">int</span><span class="op">(</span><span class="nam">alpha</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t238" class="stm mis"> <span class="nam">svp_reorient</span> <span class="op">=</span> <span class="nam">np</span><span class="op">.</span><span class="nam">roll</span><span class="op">(</span><span class="nam">image</span><span class="op">,</span> <span class="nam">alpha</span><span class="op">,</span> <span class="num">1</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t239" class="stm mis"> <span class="nam">reoriented_mem</span><span class="op">.</span><span class="nam">append</span><span class="op">(</span><span class="nam">svp_reorient</span><span class="op">)</span><span class="strut"> </span></p>
<p id="t240" class="stm mis"> <span class="key">return</span> <span class="nam">reoriented_mem</span><span class="op">,</span> <span class="nam">svp_all</span><span class="strut"> </span></p>
</td>
</tr>
</table>
</div>
<div id="footer">
<div class="content">
<p>
<a class="nav" href="index.html">« index</a> <a class="nav" href="https://coverage.readthedocs.io">coverage.py v4.5.2</a>,
created at 2019-01-16 18:11
</p>
</div>
</div>
</body>
</html>