solver.html 56 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699
  1. <!DOCTYPE html>
  2. <!--[if IE 8]><html class="no-js lt-ie9" lang="en" > <![endif]-->
  3. <!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]-->
  4. <head>
  5. <meta charset="utf-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>CBD.solver &mdash; CBD Simulation Development Kit documentation</title>
  8. <link rel="stylesheet" href="../../_static/css/theme.css" type="text/css" />
  9. <!-- <link rel="stylesheet" href="../../_static/pygments.css" type="text/css" /> -->
  10. <link rel="stylesheet" href="../../_static/style.css" type="text/css" />
  11. <link rel="index" title="Index" href="../../genindex.html" />
  12. <link rel="search" title="Search" href="../../search.html" />
  13. <script async src="https://www.googletagmanager.com/gtag/js?id=UA-167094275-1"></script>
  14. <script src="../../_static/js/googleanalytics.min.js"></script>
  15. <script src="../../_static/js/modernizr.min.js"></script>
  16. <!-- Preload the theme fonts -->
  17. <link rel="preload" href="../../_static/fonts/FreightSans/freight-sans-book.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  18. <link rel="preload" href="../../_static/fonts/FreightSans/freight-sans-medium.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  19. <link rel="preload" href="../../_static/fonts/IBMPlexMono/IBMPlexMono-Medium.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  20. <link rel="preload" href="../../_static/fonts/FreightSans/freight-sans-bold.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  21. <link rel="preload" href="../../_static/fonts/FreightSans/freight-sans-medium-italic.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  22. <link rel="preload" href="../../_static/fonts/IBMPlexMono/IBMPlexMono-SemiBold.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  23. <!-- Preload the katex fonts -->
  24. <link rel="preload" href="https://cdn.jsdelivr.net/npm/katex@0.10.0/dist/fonts/KaTeX_Math-Italic.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  25. <link rel="preload" href="https://cdn.jsdelivr.net/npm/katex@0.10.0/dist/fonts/KaTeX_Main-Regular.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  26. <link rel="preload" href="https://cdn.jsdelivr.net/npm/katex@0.10.0/dist/fonts/KaTeX_Main-Bold.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  27. <link rel="preload" href="https://cdn.jsdelivr.net/npm/katex@0.10.0/dist/fonts/KaTeX_Size1-Regular.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  28. <link rel="preload" href="https://cdn.jsdelivr.net/npm/katex@0.10.0/dist/fonts/KaTeX_Size4-Regular.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  29. <link rel="preload" href="https://cdn.jsdelivr.net/npm/katex@0.10.0/dist/fonts/KaTeX_Size2-Regular.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  30. <link rel="preload" href="https://cdn.jsdelivr.net/npm/katex@0.10.0/dist/fonts/KaTeX_Size3-Regular.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  31. <link rel="preload" href="https://cdn.jsdelivr.net/npm/katex@0.10.0/dist/fonts/KaTeX_Caligraphic-Regular.woff2" as="font" type="font/woff2" crossorigin="anonymous">
  32. </head>
  33. <div class="container-fluid header-holder tutorials-header" id="header-holder">
  34. <div class="container">
  35. <div class="header-container">
  36. <a class="header-logo" href="https://catalyst-team.com/" aria-label="Catalyst"></a>
  37. <div class="main-menu">
  38. <ul>
  39. <li>
  40. <div class="ecosystem-dropdown">
  41. <a id="dropdownMenuButtonEcosystem" data-toggle="ecosystem-dropdown">
  42. Ecosystem
  43. </a>
  44. <div class="ecosystem-dropdown-menu">
  45. <a class="nav-dropdown-item" href="https://alchemy.host">
  46. <span class=dropdown-title>Alchemy</span>
  47. <p>Experiments logging & visualization</p>
  48. </a>
  49. <a class="nav-dropdown-item" href="https://github.com/catalyst-team/catalyst">
  50. <span class=dropdown-title>Catalyst</span>
  51. <p>Accelerated deep learning R&D</p>
  52. </a>
  53. <a class="nav-dropdown-item" href="https://github.com/catalyst-team/reaction">
  54. <span class=dropdown-title>Reaction</span>
  55. <p>Convenient deep learning models serving</p>
  56. </a>
  57. </div>
  58. </div>
  59. </li>
  60. <li>
  61. <div class="projects-dropdown">
  62. <a id="dropdownMenuButtonProjects" data-toggle="projects-dropdown">
  63. Projects
  64. </a>
  65. <div class="projects-dropdown-menu">
  66. <a class="nav-dropdown-item" href="https://github.com/catalyst-team/codestyle">
  67. <span class=dropdown-title>Codestyle</span>
  68. <p>Joint R&D codestyle</p>
  69. </a>
  70. <a class="nav-dropdown-item" href="https://github.com/catalyst-team/neuro">
  71. <span class=dropdown-title>Catalyst.Neuro</span>
  72. <p>Catalyst.Team and TReNDS collaborative project</p>
  73. </a>
  74. <a class="nav-dropdown-item" href="https://github.com/catalyst-team/classification">
  75. <span class=dropdown-title>Classification</span>
  76. <p>Image classification pipeline with transfer learning</p>
  77. </a>
  78. <a class="nav-dropdown-item" href="https://github.com/catalyst-team/detection">
  79. <span class=dropdown-title>Detection</span>
  80. <p>Object detection pipeline</p>
  81. </a>
  82. <a class="nav-dropdown-item" href="https://github.com/catalyst-team/segmentation">
  83. <span class=dropdown-title>Segmentation</span>
  84. <p>Image semantic segmentation pipeline</p>
  85. </a>
  86. <a class="nav-dropdown-item" href="https://github.com/catalyst-team/gan">
  87. <span class=dropdown-title>Catalyst.GAN</span>
  88. <p>GAN pipelines</p>
  89. </a>
  90. </div>
  91. </div>
  92. </li>
  93. <li>
  94. <a href="https://github.com/catalyst-team/dl-course">Deep learning course</a>
  95. </li>
  96. </ul>
  97. </div>
  98. <a class="main-menu-open-button" href="#" data-behavior="open-mobile-menu"></a>
  99. </div>
  100. </div>
  101. </div>
  102. <body class="catalyst-body">
  103. <div class="table-of-contents-link-wrapper">
  104. <span>Table of Contents</span>
  105. <a href="#" class="toggle-table-of-contents" data-behavior="toggle-table-of-contents"></a>
  106. </div>
  107. <nav data-toggle="wy-nav-shift" class="catalyst-left-menu" id="catalyst-left-menu">
  108. <div class="catalyst-side-scroll">
  109. <div class="catalyst-menu catalyst-menu-vertical" data-spy="affix" role="navigation" aria-label="main navigation">
  110. <div class="catalyst-left-menu-search">
  111. <div role="search">
  112. <form id="rtd-search-form" class="wy-form" action="../../search.html" method="get">
  113. <input type="text" name="q" placeholder="Search Docs" />
  114. <input type="hidden" name="check_keywords" value="yes" />
  115. <input type="hidden" name="area" value="default" />
  116. </form>
  117. </div>
  118. </div>
  119. <p class="caption"><span class="caption-text">Setup</span></p>
  120. <ul>
  121. <li class="toctree-l1"><a class="reference internal" href="../../install.html">How to install the CBD framework?</a></li>
  122. <li class="toctree-l1"><a class="reference internal" href="../../running.html">How to run a CBD simulation?</a></li>
  123. <li class="toctree-l1"><a class="reference internal" href="../../changelog.html">Changelog</a></li>
  124. </ul>
  125. <p class="caption"><span class="caption-text">Simple Examples</span></p>
  126. <ul>
  127. <li class="toctree-l1"><a class="reference internal" href="../../examples/SinGen.html">Sine Generator</a></li>
  128. <li class="toctree-l1"><a class="reference internal" href="../../examples/EvenNumberGen.html">Hierarchical Even Number Generator</a></li>
  129. <li class="toctree-l1"><a class="reference internal" href="../../examples/Fibonacci.html">Fibonacci Sequence Generator</a></li>
  130. <li class="toctree-l1"><a class="reference internal" href="../../examples/LCG.html">Linear Congruential Generator</a></li>
  131. </ul>
  132. <p class="caption"><span class="caption-text">Advanced Examples</span></p>
  133. <ul>
  134. <li class="toctree-l1"><a class="reference internal" href="../../examples/RealTime.html">Realtime Simulation</a></li>
  135. <li class="toctree-l1"><a class="reference internal" href="../../examples/LivePlot.html">Live Plotting of Data During the Simulation</a></li>
  136. <li class="toctree-l1"><a class="reference internal" href="../../examples/Dashboard.html">TkInter Dashboard with Editable Values</a></li>
  137. </ul>
  138. <p class="caption"><span class="caption-text">Internal Documentation</span></p>
  139. <ul>
  140. <li class="toctree-l1"><a class="reference internal" href="../../CBD.html">CBD package</a></li>
  141. </ul>
  142. </div>
  143. </div>
  144. </nav>
  145. <div class="catalyst-container">
  146. <div class="catalyst-page-level-bar" id="catalyst-page-level-bar">
  147. <div class="catalyst-breadcrumbs-wrapper">
  148. <div role="navigation" aria-label="breadcrumbs navigation">
  149. <ul class="catalyst-breadcrumbs">
  150. <li>
  151. <a href="../../index.html">
  152. Docs
  153. </a> &gt;
  154. </li>
  155. <li><a href="../index.html">Module code</a> &gt;</li>
  156. <li>CBD.solver</li>
  157. <li class="catalyst-breadcrumbs-aside">
  158. </li>
  159. </ul>
  160. </div>
  161. </div>
  162. <div class="catalyst-shortcuts-wrapper" id="catalyst-shortcuts-wrapper">
  163. Shortcuts
  164. </div>
  165. </div>
  166. <section data-toggle="wy-nav-shift" id="catalyst-content-wrap" class="catalyst-content-wrap">
  167. <div class="catalyst-content-left">
  168. <div class="rst-content">
  169. <div role="main" class="main-content" itemscope="itemscope" itemtype="http://schema.org/Article">
  170. <article itemprop="articleBody" id="catalyst-article" class="catalyst-article">
  171. <h1>Source code for CBD.solver</h1><div class="highlight"><pre>
  172. <span></span><span class="kn">import</span> <span class="nn">math</span>
  173. <span class="kn">from</span> <span class="nn">.CBD</span> <span class="kn">import</span> <span class="n">CBD</span>
  174. <span class="kn">from</span> <span class="nn">.util</span> <span class="kn">import</span> <span class="n">PYTHON_VERSION</span>
  175. <span class="k">if</span> <span class="n">PYTHON_VERSION</span> <span class="o">==</span> <span class="mi">3</span><span class="p">:</span>
  176. <span class="c1"># Python 2 complient</span>
  177. <span class="kn">from</span> <span class="nn">functools</span> <span class="kn">import</span> <span class="n">reduce</span>
  178. <span class="c1"># Superclass for possible additional solvers</span>
  179. <div class="viewcode-block" id="Solver"><a class="viewcode-back" href="../../CBD.solver.html#CBD.solver.Solver">[docs]</a><span class="k">class</span> <span class="nc">Solver</span><span class="p">:</span>
  180. <span class="sd">&quot;&quot;&quot;</span>
  181. <span class="sd"> Superclass that can solve algebraic loops.</span>
  182. <span class="sd"> Args:</span>
  183. <span class="sd"> logger (Logger): The logger to use.</span>
  184. <span class="sd"> &quot;&quot;&quot;</span>
  185. <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">logger</span><span class="p">):</span>
  186. <span class="bp">self</span><span class="o">.</span><span class="n">_logger</span> <span class="o">=</span> <span class="n">logger</span>
  187. <div class="viewcode-block" id="Solver.checkValidity"><a class="viewcode-back" href="../../CBD.solver.html#CBD.solver.Solver.checkValidity">[docs]</a> <span class="k">def</span> <span class="nf">checkValidity</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">path</span><span class="p">,</span> <span class="n">component</span><span class="p">):</span>
  188. <span class="sd">&quot;&quot;&quot;</span>
  189. <span class="sd"> Checks the validity of an algebraic loop.</span>
  190. <span class="sd"> Args:</span>
  191. <span class="sd"> path (str): The path of the top-level block.</span>
  192. <span class="sd"> component (list): The blocks in the algebraic loop.</span>
  193. <span class="sd"> &quot;&quot;&quot;</span>
  194. <span class="k">raise</span> <span class="ne">NotImplementedError</span><span class="p">()</span></div>
  195. <div class="viewcode-block" id="Solver.constructInput"><a class="viewcode-back" href="../../CBD.solver.html#CBD.solver.Solver.constructInput">[docs]</a> <span class="k">def</span> <span class="nf">constructInput</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">component</span><span class="p">,</span> <span class="n">curIt</span><span class="p">):</span>
  196. <span class="sd">&quot;&quot;&quot;</span>
  197. <span class="sd"> Constructs input for the solver.</span>
  198. <span class="sd"> Args:</span>
  199. <span class="sd"> component (list): The blocks in the algebraic loop.</span>
  200. <span class="sd"> curIt (int): The current iteration of the simulation.</span>
  201. <span class="sd"> See Also:</span>
  202. <span class="sd"> :func:`solve`</span>
  203. <span class="sd"> &quot;&quot;&quot;</span>
  204. <span class="k">raise</span> <span class="ne">NotImplementedError</span><span class="p">()</span></div>
  205. <div class="viewcode-block" id="Solver.solve"><a class="viewcode-back" href="../../CBD.solver.html#CBD.solver.Solver.solve">[docs]</a> <span class="k">def</span> <span class="nf">solve</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">solverInput</span><span class="p">):</span>
  206. <span class="sd">&quot;&quot;&quot;</span>
  207. <span class="sd"> Solves the algebraic loop.</span>
  208. <span class="sd"> Args:</span>
  209. <span class="sd"> solverInput: The constructed input.</span>
  210. <span class="sd"> See Also:</span>
  211. <span class="sd"> :func:`constructInput`</span>
  212. <span class="sd"> &quot;&quot;&quot;</span>
  213. <span class="k">raise</span> <span class="ne">NotImplementedError</span><span class="p">()</span></div></div>
  214. <div class="viewcode-block" id="GaussianJordanLinearSolver"><a class="viewcode-back" href="../../CBD.solver.html#CBD.solver.GaussianJordanLinearSolver">[docs]</a><span class="k">class</span> <span class="nc">GaussianJordanLinearSolver</span><span class="p">(</span><span class="n">Solver</span><span class="p">):</span>
  215. <span class="sd">&quot;&quot;&quot;</span>
  216. <span class="sd"> Solves linear algebraic loops via Gaussian-Jordan Elimination.</span>
  217. <span class="sd"> &quot;&quot;&quot;</span>
  218. <div class="viewcode-block" id="GaussianJordanLinearSolver.checkValidity"><a class="viewcode-back" href="../../CBD.solver.html#CBD.solver.GaussianJordanLinearSolver.checkValidity">[docs]</a> <span class="k">def</span> <span class="nf">checkValidity</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">path</span><span class="p">,</span> <span class="n">component</span><span class="p">):</span>
  219. <span class="k">if</span> <span class="ow">not</span> <span class="bp">self</span><span class="o">.</span><span class="n">__isLinear</span><span class="p">(</span><span class="n">component</span><span class="p">):</span>
  220. <span class="bp">self</span><span class="o">.</span><span class="n">_logger</span><span class="o">.</span><span class="n">fatal</span><span class="p">(</span><span class="s2">&quot;Cannot solve non-linear algebraic loop.</span><span class="se">\n</span><span class="s2">Self: </span><span class="si">{}</span><span class="se">\n</span><span class="s2">Components: </span><span class="si">{}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">path</span><span class="p">,</span> <span class="n">component</span><span class="p">))</span></div>
  221. <span class="k">def</span> <span class="nf">__isLinear</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">strongComponent</span><span class="p">):</span>
  222. <span class="sd">&quot;&quot;&quot;Determines if an algebraic loop describes a linear equation or not</span>
  223. <span class="sd"> Args:</span>
  224. <span class="sd"> strongComponent (list): The detected loop, in a list (of BaseBlock instances)</span>
  225. <span class="sd"> Returns:</span>
  226. <span class="sd"> :class:`True` if the loop is linear, else :code:`False`.</span>
  227. <span class="sd"> &quot;&quot;&quot;</span>
  228. <span class="c1"># TO IMPLEMENT</span>
  229. <span class="sd">&quot;&quot;&quot;</span>
  230. <span class="sd"> The strong component parameter is a list of blocks that comprise the strong component.</span>
  231. <span class="sd"> For a block to comprise the strong component, at least one of its dependencies must be in the strong</span>
  232. <span class="sd"> component as well.</span>
  233. <span class="sd"> </span>
  234. <span class="sd"> A non-linear equation is generated when the following conditions occur:</span>
  235. <span class="sd"> (1) there is a multiplication operation being performed between two unknowns.</span>
  236. <span class="sd"> (2) there is an invertion operation being performed in an unknown.</span>
  237. <span class="sd"> (3) some non-linear block belongs to the strong component</span>
  238. <span class="sd"> </span>
  239. <span class="sd"> The condition (1) can be operationalized by finding a product block that has two dependencies belonging to</span>
  240. <span class="sd"> the strong component. This will immediatly tell us that it is a product between two unknowns.</span>
  241. <span class="sd"> The condition (2) can be operationalized simply by finding an inverter block in the strong component. </span>
  242. <span class="sd"> Because the inverter block only has one input, if it is in the strong component, it means that its only</span>
  243. <span class="sd"> dependency is in the strong component.</span>
  244. <span class="sd"> &quot;&quot;&quot;</span>
  245. <span class="c1"># WON&#39;T APPEAR: Constant, Sequence, Time, Logging</span>
  246. <span class="c1"># LINEAR: Negator, Adder, Delay, Input, Output, Wire, TimedGate</span>
  247. <span class="c1"># NON-LINEAR: Inverter, Modulo, Root, LT, EQ, LTE, Not, Or, And, MUX, Generic, ABS, Int</span>
  248. <span class="c1"># SEMI-LINEAR: Product</span>
  249. <span class="k">for</span> <span class="n">block</span> <span class="ow">in</span> <span class="n">strongComponent</span><span class="p">:</span>
  250. <span class="c1"># condition (1)</span>
  251. <span class="k">if</span> <span class="n">block</span><span class="o">.</span><span class="n">getBlockType</span><span class="p">()</span> <span class="o">==</span> <span class="s2">&quot;ProductBlock&quot;</span><span class="p">:</span>
  252. <span class="n">dependenciesUnknown</span> <span class="o">=</span> <span class="p">[</span><span class="n">x</span> <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">block</span><span class="o">.</span><span class="n">getDependencies</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span> <span class="k">if</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">strongComponent</span><span class="p">]</span>
  253. <span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">dependenciesUnknown</span><span class="p">)</span> <span class="o">==</span> <span class="mi">2</span><span class="p">:</span>
  254. <span class="k">return</span> <span class="kc">False</span>
  255. <span class="c1"># condition (2) and (3)</span>
  256. <span class="k">if</span> <span class="n">block</span><span class="o">.</span><span class="n">getBlockType</span><span class="p">()</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">&quot;InverterBlock&quot;</span><span class="p">,</span> <span class="s2">&quot;ModuloBlock&quot;</span><span class="p">,</span> <span class="s2">&quot;RootBlock&quot;</span><span class="p">,</span> <span class="s2">&quot;LessThanBlock&quot;</span><span class="p">,</span> <span class="s2">&quot;EqualsBlock&quot;</span><span class="p">,</span>
  257. <span class="s2">&quot;LessThanOrEqualsBlock&quot;</span><span class="p">,</span> <span class="s2">&quot;NotBlock&quot;</span><span class="p">,</span> <span class="s2">&quot;OrBlock&quot;</span><span class="p">,</span> <span class="s2">&quot;AndBlock&quot;</span><span class="p">,</span>
  258. <span class="s2">&quot;MultiplexerBlock&quot;</span><span class="p">,</span> <span class="s2">&quot;GenericBlock&quot;</span><span class="p">,</span> <span class="s2">&quot;AbsBlock&quot;</span><span class="p">,</span> <span class="s2">&quot;IntBlock&quot;</span><span class="p">]:</span>
  259. <span class="k">return</span> <span class="kc">False</span>
  260. <span class="k">return</span> <span class="kc">True</span>
  261. <div class="viewcode-block" id="GaussianJordanLinearSolver.constructInput"><a class="viewcode-back" href="../../CBD.solver.html#CBD.solver.GaussianJordanLinearSolver.constructInput">[docs]</a> <span class="k">def</span> <span class="nf">constructInput</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">strongComponent</span><span class="p">,</span> <span class="n">curIteration</span><span class="p">):</span>
  262. <span class="sd">&quot;&quot;&quot;</span>
  263. <span class="sd"> Constructs input for a solver of systems of linear equations</span>
  264. <span class="sd"> Input consists of two matrices:</span>
  265. <span class="sd"> - M1: coefficient matrix, where each row represents an equation of the system</span>
  266. <span class="sd"> - M2: result matrix, where each element is the result for the corresponding equation in M1</span>
  267. <span class="sd"> &quot;&quot;&quot;</span>
  268. <span class="c1"># Initialize matrices with zeros</span>
  269. <span class="n">size</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">strongComponent</span><span class="p">)</span>
  270. <span class="n">M1</span> <span class="o">=</span> <span class="n">Matrix</span><span class="p">(</span><span class="n">size</span><span class="p">,</span> <span class="n">size</span><span class="p">)</span>
  271. <span class="n">M2</span> <span class="o">=</span> <span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="o">*</span> <span class="n">size</span>
  272. <span class="c1"># block -&gt; index of block</span>
  273. <span class="n">indexdict</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span>
  274. <span class="k">for</span> <span class="n">i</span><span class="p">,</span> <span class="n">block</span> <span class="ow">in</span> <span class="nb">enumerate</span><span class="p">(</span><span class="n">strongComponent</span><span class="p">):</span>
  275. <span class="n">indexdict</span><span class="p">[</span><span class="n">block</span><span class="p">]</span> <span class="o">=</span> <span class="n">i</span>
  276. <span class="c1"># Get low-level dependency</span>
  277. <span class="n">resolveBlock</span> <span class="o">=</span> <span class="k">lambda</span> <span class="n">possibleDep</span><span class="p">,</span> <span class="n">output_port</span><span class="p">:</span> <span class="n">possibleDep</span> <span class="k">if</span> <span class="ow">not</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">possibleDep</span><span class="p">,</span> <span class="n">CBD</span><span class="p">)</span> <span class="k">else</span> <span class="n">possibleDep</span><span class="o">.</span><span class="n">getBlockByName</span><span class="p">(</span><span class="n">output_port</span><span class="p">)</span>
  278. <span class="c1"># Get list of low-level dependencies from two inputs</span>
  279. <span class="k">def</span> <span class="nf">getBlockDependencies2</span><span class="p">(</span><span class="n">block</span><span class="p">):</span>
  280. <span class="k">return</span> <span class="p">(</span><span class="n">resolveBlock</span><span class="p">(</span><span class="n">b</span><span class="p">,</span> <span class="n">output_port</span><span class="p">)</span> <span class="k">for</span> <span class="p">(</span><span class="n">b</span><span class="p">,</span> <span class="n">output_port</span><span class="p">)</span> <span class="ow">in</span> <span class="p">[</span><span class="n">block</span><span class="o">.</span><span class="n">getBlockConnectedToInput</span><span class="p">(</span><span class="s2">&quot;IN1&quot;</span><span class="p">),</span> <span class="n">block</span><span class="o">.</span><span class="n">getBlockConnectedToInput</span><span class="p">(</span><span class="s2">&quot;IN2&quot;</span><span class="p">)])</span>
  281. <span class="k">for</span> <span class="n">i</span><span class="p">,</span> <span class="n">block</span> <span class="ow">in</span> <span class="nb">enumerate</span><span class="p">(</span><span class="n">strongComponent</span><span class="p">):</span>
  282. <span class="k">if</span> <span class="n">block</span><span class="o">.</span><span class="n">getBlockType</span><span class="p">()</span> <span class="o">==</span> <span class="s2">&quot;AdderBlock&quot;</span><span class="p">:</span>
  283. <span class="k">for</span> <span class="n">external</span> <span class="ow">in</span> <span class="p">[</span><span class="n">x</span> <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">getBlockDependencies2</span><span class="p">(</span><span class="n">block</span><span class="p">)</span> <span class="k">if</span> <span class="n">x</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">strongComponent</span><span class="p">]:</span>
  284. <span class="n">M2</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">-=</span> <span class="n">external</span><span class="o">.</span><span class="n">getSignal</span><span class="p">()[</span><span class="n">curIteration</span><span class="p">]</span><span class="o">.</span><span class="n">value</span>
  285. <span class="n">M1</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="o">-</span><span class="mi">1</span>
  286. <span class="k">for</span> <span class="n">compInStrong</span> <span class="ow">in</span> <span class="p">[</span><span class="n">x</span> <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">getBlockDependencies2</span><span class="p">(</span><span class="n">block</span><span class="p">)</span> <span class="k">if</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">strongComponent</span><span class="p">]:</span>
  287. <span class="n">M1</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">indexdict</span><span class="p">[</span><span class="n">compInStrong</span><span class="p">]]</span> <span class="o">=</span> <span class="mi">1</span>
  288. <span class="k">elif</span> <span class="n">block</span><span class="o">.</span><span class="n">getBlockType</span><span class="p">()</span> <span class="o">==</span> <span class="s2">&quot;ProductBlock&quot;</span><span class="p">:</span>
  289. <span class="c1"># M2 can stay 0</span>
  290. <span class="n">M1</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="o">-</span><span class="mi">1</span>
  291. <span class="n">M1</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">indexdict</span><span class="p">[[</span><span class="n">x</span> <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">getBlockDependencies2</span><span class="p">(</span><span class="n">block</span><span class="p">)</span> <span class="k">if</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">strongComponent</span><span class="p">][</span><span class="mi">0</span><span class="p">]]]</span> <span class="o">=</span> <span class="n">reduce</span><span class="p">(</span><span class="k">lambda</span> <span class="n">x</span><span class="p">,</span> <span class="n">y</span><span class="p">:</span> <span class="n">x</span> <span class="o">*</span> <span class="n">y</span><span class="p">,</span> <span class="p">[</span><span class="n">x</span><span class="o">.</span><span class="n">getSignal</span><span class="p">()[</span><span class="n">curIteration</span><span class="p">]</span><span class="o">.</span><span class="n">value</span> <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">getBlockDependencies2</span><span class="p">(</span><span class="n">block</span><span class="p">)</span> <span class="k">if</span> <span class="n">x</span> <span class="ow">not</span> <span class="ow">in</span> <span class="n">strongComponent</span><span class="p">])</span>
  292. <span class="k">elif</span> <span class="n">block</span><span class="o">.</span><span class="n">getBlockType</span><span class="p">()</span> <span class="o">==</span> <span class="s2">&quot;NegatorBlock&quot;</span><span class="p">:</span>
  293. <span class="c1"># M2 can stay 0</span>
  294. <span class="n">M1</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="o">-</span><span class="mi">1</span>
  295. <span class="n">possibleDep</span><span class="p">,</span> <span class="n">output_port</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">getBlockConnectedToInput</span><span class="p">(</span><span class="s2">&quot;IN1&quot;</span><span class="p">)</span>
  296. <span class="n">M1</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">indexdict</span><span class="p">[</span><span class="n">resolveBlock</span><span class="p">(</span><span class="n">possibleDep</span><span class="p">,</span> <span class="n">output_port</span><span class="p">)]]</span> <span class="o">=</span> <span class="o">-</span> <span class="mi">1</span>
  297. <span class="k">elif</span> <span class="n">block</span><span class="o">.</span><span class="n">getBlockType</span><span class="p">()</span> <span class="o">==</span> <span class="s2">&quot;InputPortBlock&quot;</span><span class="p">:</span>
  298. <span class="c1"># M2 can stay 0</span>
  299. <span class="n">M1</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="mi">1</span>
  300. <span class="n">possibleDep</span><span class="p">,</span> <span class="n">output_port</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">parent</span><span class="o">.</span><span class="n">getBlockConnectedToInput</span><span class="p">(</span><span class="n">block</span><span class="o">.</span><span class="n">getBlockName</span><span class="p">())</span>
  301. <span class="n">M1</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">indexdict</span><span class="p">[</span><span class="n">resolveBlock</span><span class="p">(</span><span class="n">possibleDep</span><span class="p">,</span> <span class="n">output_port</span><span class="p">)]]</span> <span class="o">=</span> <span class="o">-</span> <span class="mi">1</span>
  302. <span class="k">elif</span> <span class="n">block</span><span class="o">.</span><span class="n">getBlockType</span><span class="p">()</span> <span class="o">==</span> <span class="s2">&quot;OutputPortBlock&quot;</span> <span class="ow">or</span> <span class="n">block</span><span class="o">.</span><span class="n">getBlockType</span><span class="p">()</span> <span class="o">==</span> <span class="s2">&quot;WireBlock&quot;</span><span class="p">:</span>
  303. <span class="c1"># M2 can stay 0</span>
  304. <span class="n">M1</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="mi">1</span>
  305. <span class="n">M1</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">indexdict</span><span class="p">[</span><span class="n">block</span><span class="o">.</span><span class="n">getDependencies</span><span class="p">(</span><span class="mi">0</span><span class="p">)[</span><span class="mi">0</span><span class="p">]]]</span> <span class="o">=</span> <span class="o">-</span> <span class="mi">1</span>
  306. <span class="k">elif</span> <span class="n">block</span><span class="o">.</span><span class="n">getBlockType</span><span class="p">()</span> <span class="o">==</span> <span class="s2">&quot;DelayBlock&quot;</span><span class="p">:</span>
  307. <span class="c1"># If a delay is in a strong component, this is the first iteration</span>
  308. <span class="k">assert</span> <span class="n">curIteration</span> <span class="o">==</span> <span class="mi">0</span>
  309. <span class="c1"># And so the dependency is the IC</span>
  310. <span class="c1"># M2 can stay 0 because we have an equation of the type -x = -ic &lt;=&gt; -x + ic = 0</span>
  311. <span class="n">M1</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="o">-</span><span class="mi">1</span>
  312. <span class="n">possibleDep</span><span class="p">,</span> <span class="n">output_port</span> <span class="o">=</span> <span class="n">block</span><span class="o">.</span><span class="n">getBlockConnectedToInput</span><span class="p">(</span><span class="s2">&quot;IC&quot;</span><span class="p">)</span>
  313. <span class="n">dependency</span> <span class="o">=</span> <span class="n">resolveBlock</span><span class="p">(</span><span class="n">possibleDep</span><span class="p">,</span> <span class="n">output_port</span><span class="p">)</span>
  314. <span class="k">assert</span> <span class="n">dependency</span> <span class="ow">in</span> <span class="n">strongComponent</span>
  315. <span class="n">M1</span><span class="p">[</span><span class="n">i</span><span class="p">,</span> <span class="n">indexdict</span><span class="p">[</span><span class="n">dependency</span><span class="p">]]</span> <span class="o">=</span> <span class="mi">1</span>
  316. <span class="k">else</span><span class="p">:</span>
  317. <span class="bp">self</span><span class="o">.</span><span class="n">_logger</span><span class="o">.</span><span class="n">fatal</span><span class="p">(</span><span class="s2">&quot;Unknown element &#39;</span><span class="si">{}</span><span class="s2">&#39;, please implement&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">block</span><span class="o">.</span><span class="n">getBlockType</span><span class="p">()))</span>
  318. <span class="k">return</span> <span class="n">M1</span><span class="p">,</span> <span class="n">M2</span></div>
  319. <div class="viewcode-block" id="GaussianJordanLinearSolver.solve"><a class="viewcode-back" href="../../CBD.solver.html#CBD.solver.GaussianJordanLinearSolver.solve">[docs]</a> <span class="k">def</span> <span class="nf">solve</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">solverInput</span><span class="p">):</span>
  320. <span class="n">M1</span><span class="p">,</span> <span class="n">M2</span> <span class="o">=</span> <span class="n">solverInput</span>
  321. <span class="n">n</span> <span class="o">=</span> <span class="n">M1</span><span class="o">.</span><span class="n">rows</span>
  322. <span class="n">indxc</span> <span class="o">=</span> <span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="o">*</span> <span class="n">n</span>
  323. <span class="n">indxr</span> <span class="o">=</span> <span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="o">*</span> <span class="n">n</span>
  324. <span class="n">ipiv</span> <span class="o">=</span> <span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="o">*</span> <span class="n">n</span>
  325. <span class="n">icol</span> <span class="o">=</span> <span class="mi">0</span>
  326. <span class="n">irow</span> <span class="o">=</span> <span class="mi">0</span>
  327. <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span><span class="p">):</span>
  328. <span class="n">big</span> <span class="o">=</span> <span class="mf">0.0</span>
  329. <span class="k">for</span> <span class="n">j</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span><span class="p">):</span>
  330. <span class="k">if</span> <span class="n">ipiv</span><span class="p">[</span><span class="n">j</span><span class="p">]</span> <span class="o">!=</span> <span class="mi">1</span><span class="p">:</span>
  331. <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span><span class="p">):</span>
  332. <span class="k">if</span> <span class="n">ipiv</span><span class="p">[</span><span class="n">k</span><span class="p">]</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
  333. <span class="n">nb</span> <span class="o">=</span> <span class="n">math</span><span class="o">.</span><span class="n">fabs</span><span class="p">(</span><span class="n">M1</span><span class="p">[</span><span class="n">j</span><span class="p">,</span> <span class="n">k</span><span class="p">])</span>
  334. <span class="k">if</span> <span class="n">nb</span> <span class="o">&gt;=</span> <span class="n">big</span><span class="p">:</span>
  335. <span class="n">big</span> <span class="o">=</span> <span class="n">nb</span>
  336. <span class="n">irow</span> <span class="o">=</span> <span class="n">j</span>
  337. <span class="n">icol</span> <span class="o">=</span> <span class="n">k</span>
  338. <span class="k">elif</span> <span class="n">ipiv</span><span class="p">[</span><span class="n">k</span><span class="p">]</span> <span class="o">&gt;</span> <span class="mi">1</span><span class="p">:</span>
  339. <span class="k">raise</span> <span class="ne">ValueError</span><span class="p">(</span><span class="s2">&quot;GAUSSJ: Singular Matrix-1&quot;</span><span class="p">)</span>
  340. <span class="n">ipiv</span><span class="p">[</span><span class="n">icol</span><span class="p">]</span> <span class="o">+=</span> <span class="mi">1</span>
  341. <span class="k">if</span> <span class="n">irow</span> <span class="o">!=</span> <span class="n">icol</span><span class="p">:</span>
  342. <span class="k">for</span> <span class="n">l</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span><span class="p">):</span>
  343. <span class="n">M1</span><span class="p">[</span><span class="n">irow</span><span class="p">,</span> <span class="n">l</span><span class="p">],</span> <span class="n">M1</span><span class="p">[</span><span class="n">icol</span><span class="p">,</span> <span class="n">l</span><span class="p">]</span> <span class="o">=</span> <span class="n">M1</span><span class="p">[</span><span class="n">icol</span><span class="p">,</span> <span class="n">l</span><span class="p">],</span> <span class="n">M1</span><span class="p">[</span><span class="n">irow</span><span class="p">,</span> <span class="n">l</span><span class="p">]</span>
  344. <span class="n">M2</span><span class="p">[</span><span class="n">irow</span><span class="p">],</span> <span class="n">M2</span><span class="p">[</span><span class="n">icol</span><span class="p">]</span> <span class="o">=</span> <span class="n">M2</span><span class="p">[</span><span class="n">icol</span><span class="p">],</span> <span class="n">M2</span><span class="p">[</span><span class="n">irow</span><span class="p">]</span>
  345. <span class="n">indxr</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="n">irow</span>
  346. <span class="n">indxc</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="n">icol</span>
  347. <span class="k">if</span> <span class="n">M1</span><span class="p">[</span><span class="n">icol</span><span class="p">,</span> <span class="n">icol</span><span class="p">]</span> <span class="o">==</span> <span class="mf">0.0</span><span class="p">:</span>
  348. <span class="k">raise</span> <span class="ne">ValueError</span><span class="p">(</span><span class="s2">&quot;GAUSSJ: Singular Matrix-2&quot;</span><span class="p">)</span>
  349. <span class="n">pivinv</span> <span class="o">=</span> <span class="mf">1.0</span> <span class="o">/</span> <span class="n">M1</span><span class="p">[</span><span class="n">icol</span><span class="p">,</span> <span class="n">icol</span><span class="p">]</span>
  350. <span class="n">M1</span><span class="p">[</span><span class="n">icol</span><span class="p">,</span> <span class="n">icol</span><span class="p">]</span> <span class="o">=</span> <span class="mf">1.0</span>
  351. <span class="k">for</span> <span class="n">l</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span><span class="p">):</span>
  352. <span class="n">M1</span><span class="p">[</span><span class="n">icol</span><span class="p">,</span> <span class="n">l</span><span class="p">]</span> <span class="o">*=</span> <span class="n">pivinv</span>
  353. <span class="n">M2</span><span class="p">[</span><span class="n">icol</span><span class="p">]</span> <span class="o">*=</span> <span class="n">pivinv</span>
  354. <span class="k">for</span> <span class="n">ll</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span><span class="p">):</span>
  355. <span class="k">if</span> <span class="n">ll</span> <span class="o">!=</span> <span class="n">icol</span><span class="p">:</span>
  356. <span class="n">dum</span> <span class="o">=</span> <span class="n">M1</span><span class="p">[</span><span class="n">ll</span><span class="p">,</span> <span class="n">icol</span><span class="p">]</span>
  357. <span class="n">M1</span><span class="p">[</span><span class="n">ll</span><span class="p">,</span> <span class="n">icol</span><span class="p">]</span> <span class="o">=</span> <span class="mf">0.0</span>
  358. <span class="k">for</span> <span class="n">l</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span><span class="p">):</span>
  359. <span class="n">M1</span><span class="p">[</span><span class="n">ll</span><span class="p">,</span> <span class="n">l</span><span class="p">]</span> <span class="o">-=</span> <span class="n">M1</span><span class="p">[</span><span class="n">icol</span><span class="p">,</span> <span class="n">l</span><span class="p">]</span> <span class="o">*</span> <span class="n">dum</span>
  360. <span class="n">M2</span><span class="p">[</span><span class="n">ll</span><span class="p">]</span> <span class="o">-=</span> <span class="n">M2</span><span class="p">[</span><span class="n">icol</span><span class="p">]</span> <span class="o">*</span> <span class="n">dum</span>
  361. <span class="k">for</span> <span class="n">l</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span> <span class="o">-</span> <span class="mi">1</span><span class="p">,</span> <span class="mi">0</span><span class="p">,</span> <span class="o">-</span><span class="mi">1</span><span class="p">):</span>
  362. <span class="k">if</span> <span class="n">indxr</span><span class="p">[</span><span class="n">l</span><span class="p">]</span> <span class="o">!=</span> <span class="n">indxc</span><span class="p">[</span><span class="n">l</span><span class="p">]:</span>
  363. <span class="k">for</span> <span class="n">k</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n</span><span class="p">):</span>
  364. <span class="n">M1</span><span class="p">[</span><span class="n">k</span><span class="p">,</span> <span class="n">indxr</span><span class="p">[</span><span class="n">l</span><span class="p">]],</span> <span class="n">M1</span><span class="p">[</span><span class="n">k</span><span class="p">,</span> <span class="n">indxc</span><span class="p">[</span><span class="n">l</span><span class="p">]]</span> <span class="o">=</span> <span class="n">M1</span><span class="p">[</span><span class="n">k</span><span class="p">,</span> <span class="n">indxc</span><span class="p">[</span><span class="n">l</span><span class="p">]],</span> <span class="n">M1</span><span class="p">[</span><span class="n">k</span><span class="p">,</span> <span class="n">indxr</span><span class="p">[</span><span class="n">l</span><span class="p">]]</span></div></div>
  365. <div class="viewcode-block" id="Matrix"><a class="viewcode-back" href="../../CBD.solver.html#CBD.solver.Matrix">[docs]</a><span class="k">class</span> <span class="nc">Matrix</span><span class="p">:</span>
  366. <span class="sd">&quot;&quot;&quot;Custom, efficient matrix class. This class is used for efficiency purposes.</span>
  367. <span class="sd"> - Using a while/for loop is slow.</span>
  368. <span class="sd"> - Using :class:`[[0] * n] * n` will have n references to the same list.</span>
  369. <span class="sd"> - Using :class:`[[0] * size for _ in range(size)]` can be 5 times slower</span>
  370. <span class="sd"> than this class!</span>
  371. <span class="sd"> Numpy could be used to even further increase efficiency, but this increases the</span>
  372. <span class="sd"> required dependencies for external hardware systems (that may not provide these options).</span>
  373. <span class="sd"> Note:</span>
  374. <span class="sd"> Internally, the matrix is segmented into chunks of 500.000.000 items.</span>
  375. <span class="sd"> &quot;&quot;&quot;</span>
  376. <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">rows</span><span class="p">,</span> <span class="n">cols</span><span class="p">):</span>
  377. <span class="bp">self</span><span class="o">.</span><span class="n">rows</span> <span class="o">=</span> <span class="n">rows</span>
  378. <span class="bp">self</span><span class="o">.</span><span class="n">cols</span> <span class="o">=</span> <span class="n">cols</span>
  379. <span class="bp">self</span><span class="o">.</span><span class="n">size</span> <span class="o">=</span> <span class="n">rows</span> <span class="o">*</span> <span class="n">cols</span>
  380. <span class="bp">self</span><span class="o">.</span><span class="n">__max_list_size</span> <span class="o">=</span> <span class="mi">500</span> <span class="o">*</span> <span class="mi">1000</span> <span class="o">*</span> <span class="mi">1000</span>
  381. <span class="bp">self</span><span class="o">.</span><span class="n">data</span> <span class="o">=</span> <span class="p">[[</span><span class="mi">0</span><span class="p">]</span> <span class="o">*</span> <span class="p">((</span><span class="n">rows</span> <span class="o">*</span> <span class="n">cols</span><span class="p">)</span> <span class="o">%</span> <span class="bp">self</span><span class="o">.</span><span class="n">__max_list_size</span><span class="p">)]</span>
  382. <span class="k">for</span> <span class="n">r</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">size</span> <span class="o">//</span> <span class="bp">self</span><span class="o">.</span><span class="n">__max_list_size</span><span class="p">):</span>
  383. <span class="bp">self</span><span class="o">.</span><span class="n">data</span><span class="o">.</span><span class="n">append</span><span class="p">([</span><span class="mi">0</span><span class="p">]</span> <span class="o">*</span> <span class="bp">self</span><span class="o">.</span><span class="n">__max_list_size</span><span class="p">)</span>
  384. <span class="k">def</span> <span class="fm">__getitem__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">idx</span><span class="p">):</span>
  385. <span class="n">absolute</span> <span class="o">=</span> <span class="n">idx</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="o">*</span> <span class="bp">self</span><span class="o">.</span><span class="n">cols</span> <span class="o">+</span> <span class="n">idx</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span>
  386. <span class="n">outer</span> <span class="o">=</span> <span class="n">absolute</span> <span class="o">//</span> <span class="bp">self</span><span class="o">.</span><span class="n">__max_list_size</span>
  387. <span class="n">inner</span> <span class="o">=</span> <span class="n">absolute</span> <span class="o">%</span> <span class="bp">self</span><span class="o">.</span><span class="n">__max_list_size</span>
  388. <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">data</span><span class="p">[</span><span class="n">outer</span><span class="p">][</span><span class="n">inner</span><span class="p">]</span>
  389. <span class="k">def</span> <span class="fm">__setitem__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">idx</span><span class="p">,</span> <span class="n">value</span><span class="p">):</span>
  390. <span class="n">absolute</span> <span class="o">=</span> <span class="n">idx</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="o">*</span> <span class="bp">self</span><span class="o">.</span><span class="n">cols</span> <span class="o">+</span> <span class="n">idx</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span>
  391. <span class="n">outer</span> <span class="o">=</span> <span class="n">absolute</span> <span class="o">//</span> <span class="bp">self</span><span class="o">.</span><span class="n">__max_list_size</span>
  392. <span class="n">inner</span> <span class="o">=</span> <span class="n">absolute</span> <span class="o">%</span> <span class="bp">self</span><span class="o">.</span><span class="n">__max_list_size</span>
  393. <span class="bp">self</span><span class="o">.</span><span class="n">data</span><span class="p">[</span><span class="n">outer</span><span class="p">][</span><span class="n">inner</span><span class="p">]</span> <span class="o">=</span> <span class="n">value</span></div>
  394. </pre></div>
  395. </article>
  396. </div>
  397. <footer>
  398. <hr>
  399. <div role="contentinfo">
  400. <p>
  401. &copy; Copyright 2020, Randy Paredis.
  402. </p>
  403. </div>
  404. <div>
  405. Built with <a href="http://sphinx-doc.org/">Sphinx</a> using a <a href="https://github.com/rtfd/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
  406. </div>
  407. </footer>
  408. </div>
  409. </div>
  410. <div class="catalyst-content-right" id="catalyst-content-right">
  411. <div class="catalyst-right-menu" id="catalyst-right-menu">
  412. <div class="catalyst-side-scroll" id="catalyst-side-scroll-right">
  413. </div>
  414. </div>
  415. </div>
  416. </section>
  417. </div>
  418. <script type="text/javascript" id="documentation_options" data-url_root="../../" src="../../_static/documentation_options.js"></script>
  419. <script type="text/javascript" src="../../_static/jquery.js"></script>
  420. <script type="text/javascript" src="../../_static/underscore.js"></script>
  421. <script type="text/javascript" src="../../_static/doctools.js"></script>
  422. <script type="text/javascript" src="../../_static/language_data.js"></script>
  423. <script async="async" type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/latest.js?config=TeX-AMS-MML_HTMLorMML"></script>
  424. <script type="text/javascript" src="../../_static/js/vendor/popper.min.js"></script>
  425. <script type="text/javascript" src="../../_static/js/vendor/bootstrap.min.js"></script>
  426. <script type="text/javascript" src="../../_static/js/theme.js"></script>
  427. <script type="text/javascript">
  428. jQuery(function () {
  429. SphinxRtdTheme.Navigation.enable(true);
  430. });
  431. </script>
  432. <!-- Begin Footer -->
  433. <footer class="site-footer" id="site-footer">
  434. <div class="container footer-container">
  435. <div class="footer-logo-wrapper">
  436. <a href="https://catalyst-team.com/" class="footer-logo"></a>
  437. </div>
  438. <div class="footer-links-wrapper">
  439. <div class="footer-links-col">
  440. <ul>
  441. <li class="list-title"><a href="https://github.com/catalyst-team">Ecosystem</a></li>
  442. <li><a class="nav-dropdown-item" href="https://alchemy.host">Alchemy</a></li>
  443. <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/catalyst">Catalyst</a></li>
  444. <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/reaction">Reaction</a></li>
  445. </ul>
  446. </div>
  447. <div class="footer-links-col">
  448. <ul>
  449. <li class="list-title"><a href="https://github.com/catalyst-team">Projects</a></li>
  450. <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/codestyle">Codestyle</a></li>
  451. <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/neuro">Catalyst.Neuro</a></li>
  452. <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/classification">Classification</a></li>
  453. <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/detection">Detection</a></li>
  454. <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/segmentation">Segmentation</a></li>
  455. <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/gan">Catalyst.GAN</a></li>
  456. </ul>
  457. </div>
  458. <div class="footer-links-col">
  459. <ul>
  460. <li class="list-title"><a href="https://catalyst-team.com/">Support</a></li>
  461. <li><a href="https://github.com/catalyst-team/catalyst/issues" target="_blank">Github Issues</a></li>
  462. <li><a href="https://github.com/catalyst-team/catalyst/blob/master/CONTRIBUTING.md" target="_blank">Contributing</a></li>
  463. <li><a href="https://www.patreon.com/catalyst_team" target="_blank">Patreon</a></li>
  464. </ul>
  465. </div>
  466. <div class="footer-links-col follow-us-col">
  467. <div class="footer-social-icons">
  468. <a href="https://t.me/catalyst_team" target="_blank" class="telegram"></a>
  469. <a href="https://twitter.com/catalyst_core" target="_blank" class="twitter"></a>
  470. <a href="https://join.slack.com/t/catalyst-team-core/shared_invite/zt-d9miirnn-z86oKDzFMKlMG4fgFdZafw" target="_blank" class="ods"></a>
  471. </div>
  472. </div>
  473. </div>
  474. </div>
  475. </footer>
  476. <!-- End Footer -->
  477. <!-- Begin Mobile Menu -->
  478. <div class="mobile-main-menu">
  479. <div class="container-fluid">
  480. <div class="container">
  481. <div class="mobile-main-menu-header-container">
  482. <a class="header-logo" href="https://catalyst-team.com/" aria-label="Catalyst"></a>
  483. <a class="main-menu-close-button" href="#" data-behavior="close-mobile-menu"></a>
  484. </div>
  485. </div>
  486. </div>
  487. <div class="mobile-main-menu-links-container">
  488. <div class="main-menu">
  489. <ul>
  490. <li>
  491. <a href="">Get Started</a>
  492. </li>
  493. <li>
  494. <a href="https://github.com/catalyst-team/catalyst">Github</a>
  495. </li>
  496. </ul>
  497. </div>
  498. </div>
  499. </div>
  500. <!-- End Mobile Menu -->
  501. <script type="text/javascript" src="../../_static/js/vendor/anchor.min.js"></script>
  502. <script type="text/javascript">
  503. $(document).ready(function() {
  504. mobileMenu.bind();
  505. mobileTOC.bind();
  506. catalystAnchors.bind();
  507. sideMenus.bind();
  508. scrollToAnchor.bind();
  509. highlightNavigation.bind();
  510. mainMenuDropdown.bind();
  511. // Add class to links that have code blocks, since we cannot create links in code blocks
  512. $("article.catalyst-article a span.pre").each(function(e) {
  513. $(this).closest("a").addClass("has-code");
  514. });
  515. })
  516. </script>
  517. </body>
  518. </html>