| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699 |
- <!DOCTYPE html>
- <!--[if IE 8]><html class="no-js lt-ie9" lang="en" > <![endif]-->
- <!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]-->
- <head>
- <meta charset="utf-8">
-
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
-
- <title>CBD.solver — CBD Simulation Development Kit documentation</title>
-
-
-
-
-
-
-
-
-
-
- <link rel="stylesheet" href="../../_static/css/theme.css" type="text/css" />
- <!-- <link rel="stylesheet" href="../../_static/pygments.css" type="text/css" /> -->
- <link rel="stylesheet" href="../../_static/style.css" type="text/css" />
- <link rel="index" title="Index" href="../../genindex.html" />
- <link rel="search" title="Search" href="../../search.html" />
-
- <script async src="https://www.googletagmanager.com/gtag/js?id=UA-167094275-1"></script>
- <script src="../../_static/js/googleanalytics.min.js"></script>
-
- <script src="../../_static/js/modernizr.min.js"></script>
- <!-- Preload the theme fonts -->
- <link rel="preload" href="../../_static/fonts/FreightSans/freight-sans-book.woff2" as="font" type="font/woff2" crossorigin="anonymous">
- <link rel="preload" href="../../_static/fonts/FreightSans/freight-sans-medium.woff2" as="font" type="font/woff2" crossorigin="anonymous">
- <link rel="preload" href="../../_static/fonts/IBMPlexMono/IBMPlexMono-Medium.woff2" as="font" type="font/woff2" crossorigin="anonymous">
- <link rel="preload" href="../../_static/fonts/FreightSans/freight-sans-bold.woff2" as="font" type="font/woff2" crossorigin="anonymous">
- <link rel="preload" href="../../_static/fonts/FreightSans/freight-sans-medium-italic.woff2" as="font" type="font/woff2" crossorigin="anonymous">
- <link rel="preload" href="../../_static/fonts/IBMPlexMono/IBMPlexMono-SemiBold.woff2" as="font" type="font/woff2" crossorigin="anonymous">
- <!-- Preload the katex fonts -->
- <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">
- <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">
- <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">
- <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">
- <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">
- <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">
- <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">
- <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">
- </head>
- <div class="container-fluid header-holder tutorials-header" id="header-holder">
- <div class="container">
- <div class="header-container">
- <a class="header-logo" href="https://catalyst-team.com/" aria-label="Catalyst"></a>
- <div class="main-menu">
- <ul>
- <li>
- <div class="ecosystem-dropdown">
- <a id="dropdownMenuButtonEcosystem" data-toggle="ecosystem-dropdown">
- Ecosystem
- </a>
- <div class="ecosystem-dropdown-menu">
- <a class="nav-dropdown-item" href="https://alchemy.host">
- <span class=dropdown-title>Alchemy</span>
- <p>Experiments logging & visualization</p>
- </a>
- <a class="nav-dropdown-item" href="https://github.com/catalyst-team/catalyst">
- <span class=dropdown-title>Catalyst</span>
- <p>Accelerated deep learning R&D</p>
- </a>
- <a class="nav-dropdown-item" href="https://github.com/catalyst-team/reaction">
- <span class=dropdown-title>Reaction</span>
- <p>Convenient deep learning models serving</p>
- </a>
- </div>
- </div>
- </li>
- <li>
- <div class="projects-dropdown">
- <a id="dropdownMenuButtonProjects" data-toggle="projects-dropdown">
- Projects
- </a>
- <div class="projects-dropdown-menu">
- <a class="nav-dropdown-item" href="https://github.com/catalyst-team/codestyle">
- <span class=dropdown-title>Codestyle</span>
- <p>Joint R&D codestyle</p>
- </a>
- <a class="nav-dropdown-item" href="https://github.com/catalyst-team/neuro">
- <span class=dropdown-title>Catalyst.Neuro</span>
- <p>Catalyst.Team and TReNDS collaborative project</p>
- </a>
- <a class="nav-dropdown-item" href="https://github.com/catalyst-team/classification">
- <span class=dropdown-title>Classification</span>
- <p>Image classification pipeline with transfer learning</p>
- </a>
- <a class="nav-dropdown-item" href="https://github.com/catalyst-team/detection">
- <span class=dropdown-title>Detection</span>
- <p>Object detection pipeline</p>
- </a>
- <a class="nav-dropdown-item" href="https://github.com/catalyst-team/segmentation">
- <span class=dropdown-title>Segmentation</span>
- <p>Image semantic segmentation pipeline</p>
- </a>
- <a class="nav-dropdown-item" href="https://github.com/catalyst-team/gan">
- <span class=dropdown-title>Catalyst.GAN</span>
- <p>GAN pipelines</p>
- </a>
- </div>
- </div>
- </li>
- <li>
- <a href="https://github.com/catalyst-team/dl-course">Deep learning course</a>
- </li>
- </ul>
- </div>
- <a class="main-menu-open-button" href="#" data-behavior="open-mobile-menu"></a>
- </div>
- </div>
- </div>
- <body class="catalyst-body">
-
-
- <div class="table-of-contents-link-wrapper">
- <span>Table of Contents</span>
- <a href="#" class="toggle-table-of-contents" data-behavior="toggle-table-of-contents"></a>
- </div>
- <nav data-toggle="wy-nav-shift" class="catalyst-left-menu" id="catalyst-left-menu">
- <div class="catalyst-side-scroll">
- <div class="catalyst-menu catalyst-menu-vertical" data-spy="affix" role="navigation" aria-label="main navigation">
- <div class="catalyst-left-menu-search">
-
-
-
-
-
-
-
- <div role="search">
- <form id="rtd-search-form" class="wy-form" action="../../search.html" method="get">
- <input type="text" name="q" placeholder="Search Docs" />
- <input type="hidden" name="check_keywords" value="yes" />
- <input type="hidden" name="area" value="default" />
- </form>
- </div>
-
- </div>
-
-
-
-
-
-
- <p class="caption"><span class="caption-text">Setup</span></p>
- <ul>
- <li class="toctree-l1"><a class="reference internal" href="../../install.html">How to install the CBD framework?</a></li>
- <li class="toctree-l1"><a class="reference internal" href="../../running.html">How to run a CBD simulation?</a></li>
- <li class="toctree-l1"><a class="reference internal" href="../../changelog.html">Changelog</a></li>
- </ul>
- <p class="caption"><span class="caption-text">Simple Examples</span></p>
- <ul>
- <li class="toctree-l1"><a class="reference internal" href="../../examples/SinGen.html">Sine Generator</a></li>
- <li class="toctree-l1"><a class="reference internal" href="../../examples/EvenNumberGen.html">Hierarchical Even Number Generator</a></li>
- <li class="toctree-l1"><a class="reference internal" href="../../examples/Fibonacci.html">Fibonacci Sequence Generator</a></li>
- <li class="toctree-l1"><a class="reference internal" href="../../examples/LCG.html">Linear Congruential Generator</a></li>
- </ul>
- <p class="caption"><span class="caption-text">Advanced Examples</span></p>
- <ul>
- <li class="toctree-l1"><a class="reference internal" href="../../examples/RealTime.html">Realtime Simulation</a></li>
- <li class="toctree-l1"><a class="reference internal" href="../../examples/LivePlot.html">Live Plotting of Data During the Simulation</a></li>
- <li class="toctree-l1"><a class="reference internal" href="../../examples/Dashboard.html">TkInter Dashboard with Editable Values</a></li>
- </ul>
- <p class="caption"><span class="caption-text">Internal Documentation</span></p>
- <ul>
- <li class="toctree-l1"><a class="reference internal" href="../../CBD.html">CBD package</a></li>
- </ul>
-
-
- </div>
- </div>
- </nav>
- <div class="catalyst-container">
- <div class="catalyst-page-level-bar" id="catalyst-page-level-bar">
- <div class="catalyst-breadcrumbs-wrapper">
-
- <div role="navigation" aria-label="breadcrumbs navigation">
- <ul class="catalyst-breadcrumbs">
-
- <li>
- <a href="../../index.html">
-
- Docs
-
- </a> >
- </li>
-
- <li><a href="../index.html">Module code</a> ></li>
-
- <li>CBD.solver</li>
-
-
- <li class="catalyst-breadcrumbs-aside">
-
- </li>
-
- </ul>
-
- </div>
- </div>
- <div class="catalyst-shortcuts-wrapper" id="catalyst-shortcuts-wrapper">
- Shortcuts
- </div>
- </div>
- <section data-toggle="wy-nav-shift" id="catalyst-content-wrap" class="catalyst-content-wrap">
- <div class="catalyst-content-left">
-
- <div class="rst-content">
-
- <div role="main" class="main-content" itemscope="itemscope" itemtype="http://schema.org/Article">
- <article itemprop="articleBody" id="catalyst-article" class="catalyst-article">
-
- <h1>Source code for CBD.solver</h1><div class="highlight"><pre>
- <span></span><span class="kn">import</span> <span class="nn">math</span>
- <span class="kn">from</span> <span class="nn">.CBD</span> <span class="kn">import</span> <span class="n">CBD</span>
- <span class="kn">from</span> <span class="nn">.util</span> <span class="kn">import</span> <span class="n">PYTHON_VERSION</span>
- <span class="k">if</span> <span class="n">PYTHON_VERSION</span> <span class="o">==</span> <span class="mi">3</span><span class="p">:</span>
- <span class="c1"># Python 2 complient</span>
- <span class="kn">from</span> <span class="nn">functools</span> <span class="kn">import</span> <span class="n">reduce</span>
- <span class="c1"># Superclass for possible additional solvers</span>
- <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>
- <span class="sd">"""</span>
- <span class="sd"> Superclass that can solve algebraic loops.</span>
- <span class="sd"> Args:</span>
- <span class="sd"> logger (Logger): The logger to use.</span>
- <span class="sd"> """</span>
- <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>
- <span class="bp">self</span><span class="o">.</span><span class="n">_logger</span> <span class="o">=</span> <span class="n">logger</span>
- <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>
- <span class="sd">"""</span>
- <span class="sd"> Checks the validity of an algebraic loop.</span>
- <span class="sd"> Args:</span>
- <span class="sd"> path (str): The path of the top-level block.</span>
- <span class="sd"> component (list): The blocks in the algebraic loop.</span>
- <span class="sd"> """</span>
- <span class="k">raise</span> <span class="ne">NotImplementedError</span><span class="p">()</span></div>
- <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>
- <span class="sd">"""</span>
- <span class="sd"> Constructs input for the solver.</span>
- <span class="sd"> Args:</span>
- <span class="sd"> component (list): The blocks in the algebraic loop.</span>
- <span class="sd"> curIt (int): The current iteration of the simulation.</span>
- <span class="sd"> See Also:</span>
- <span class="sd"> :func:`solve`</span>
- <span class="sd"> """</span>
- <span class="k">raise</span> <span class="ne">NotImplementedError</span><span class="p">()</span></div>
- <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>
- <span class="sd">"""</span>
- <span class="sd"> Solves the algebraic loop.</span>
- <span class="sd"> Args:</span>
- <span class="sd"> solverInput: The constructed input.</span>
- <span class="sd"> See Also:</span>
- <span class="sd"> :func:`constructInput`</span>
- <span class="sd"> """</span>
- <span class="k">raise</span> <span class="ne">NotImplementedError</span><span class="p">()</span></div></div>
- <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>
- <span class="sd">"""</span>
- <span class="sd"> Solves linear algebraic loops via Gaussian-Jordan Elimination.</span>
- <span class="sd"> """</span>
- <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>
- <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>
- <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">"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">"</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>
- <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>
- <span class="sd">"""Determines if an algebraic loop describes a linear equation or not</span>
- <span class="sd"> Args:</span>
- <span class="sd"> strongComponent (list): The detected loop, in a list (of BaseBlock instances)</span>
- <span class="sd"> Returns:</span>
- <span class="sd"> :class:`True` if the loop is linear, else :code:`False`.</span>
- <span class="sd"> """</span>
- <span class="c1"># TO IMPLEMENT</span>
- <span class="sd">"""</span>
- <span class="sd"> The strong component parameter is a list of blocks that comprise the strong component.</span>
- <span class="sd"> For a block to comprise the strong component, at least one of its dependencies must be in the strong</span>
- <span class="sd"> component as well.</span>
- <span class="sd"> </span>
- <span class="sd"> A non-linear equation is generated when the following conditions occur:</span>
- <span class="sd"> (1) there is a multiplication operation being performed between two unknowns.</span>
- <span class="sd"> (2) there is an invertion operation being performed in an unknown.</span>
- <span class="sd"> (3) some non-linear block belongs to the strong component</span>
- <span class="sd"> </span>
- <span class="sd"> The condition (1) can be operationalized by finding a product block that has two dependencies belonging to</span>
- <span class="sd"> the strong component. This will immediatly tell us that it is a product between two unknowns.</span>
- <span class="sd"> The condition (2) can be operationalized simply by finding an inverter block in the strong component. </span>
- <span class="sd"> Because the inverter block only has one input, if it is in the strong component, it means that its only</span>
- <span class="sd"> dependency is in the strong component.</span>
- <span class="sd"> """</span>
- <span class="c1"># WON'T APPEAR: Constant, Sequence, Time, Logging</span>
- <span class="c1"># LINEAR: Negator, Adder, Delay, Input, Output, Wire, TimedGate</span>
- <span class="c1"># NON-LINEAR: Inverter, Modulo, Root, LT, EQ, LTE, Not, Or, And, MUX, Generic, ABS, Int</span>
- <span class="c1"># SEMI-LINEAR: Product</span>
- <span class="k">for</span> <span class="n">block</span> <span class="ow">in</span> <span class="n">strongComponent</span><span class="p">:</span>
- <span class="c1"># condition (1)</span>
- <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">"ProductBlock"</span><span class="p">:</span>
- <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>
- <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>
- <span class="k">return</span> <span class="kc">False</span>
- <span class="c1"># condition (2) and (3)</span>
- <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">"InverterBlock"</span><span class="p">,</span> <span class="s2">"ModuloBlock"</span><span class="p">,</span> <span class="s2">"RootBlock"</span><span class="p">,</span> <span class="s2">"LessThanBlock"</span><span class="p">,</span> <span class="s2">"EqualsBlock"</span><span class="p">,</span>
- <span class="s2">"LessThanOrEqualsBlock"</span><span class="p">,</span> <span class="s2">"NotBlock"</span><span class="p">,</span> <span class="s2">"OrBlock"</span><span class="p">,</span> <span class="s2">"AndBlock"</span><span class="p">,</span>
- <span class="s2">"MultiplexerBlock"</span><span class="p">,</span> <span class="s2">"GenericBlock"</span><span class="p">,</span> <span class="s2">"AbsBlock"</span><span class="p">,</span> <span class="s2">"IntBlock"</span><span class="p">]:</span>
- <span class="k">return</span> <span class="kc">False</span>
- <span class="k">return</span> <span class="kc">True</span>
- <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>
- <span class="sd">"""</span>
- <span class="sd"> Constructs input for a solver of systems of linear equations</span>
- <span class="sd"> Input consists of two matrices:</span>
- <span class="sd"> - M1: coefficient matrix, where each row represents an equation of the system</span>
- <span class="sd"> - M2: result matrix, where each element is the result for the corresponding equation in M1</span>
- <span class="sd"> """</span>
- <span class="c1"># Initialize matrices with zeros</span>
- <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>
- <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>
- <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>
- <span class="c1"># block -> index of block</span>
- <span class="n">indexdict</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span>
- <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>
- <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>
- <span class="c1"># Get low-level dependency</span>
- <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>
- <span class="c1"># Get list of low-level dependencies from two inputs</span>
- <span class="k">def</span> <span class="nf">getBlockDependencies2</span><span class="p">(</span><span class="n">block</span><span class="p">):</span>
- <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">"IN1"</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">"IN2"</span><span class="p">)])</span>
- <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>
- <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">"AdderBlock"</span><span class="p">:</span>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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">"ProductBlock"</span><span class="p">:</span>
- <span class="c1"># M2 can stay 0</span>
- <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>
- <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>
- <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">"NegatorBlock"</span><span class="p">:</span>
- <span class="c1"># M2 can stay 0</span>
- <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>
- <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">"IN1"</span><span class="p">)</span>
- <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>
- <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">"InputPortBlock"</span><span class="p">:</span>
- <span class="c1"># M2 can stay 0</span>
- <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>
- <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>
- <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>
- <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">"OutputPortBlock"</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">"WireBlock"</span><span class="p">:</span>
- <span class="c1"># M2 can stay 0</span>
- <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>
- <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>
- <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">"DelayBlock"</span><span class="p">:</span>
- <span class="c1"># If a delay is in a strong component, this is the first iteration</span>
- <span class="k">assert</span> <span class="n">curIteration</span> <span class="o">==</span> <span class="mi">0</span>
- <span class="c1"># And so the dependency is the IC</span>
- <span class="c1"># M2 can stay 0 because we have an equation of the type -x = -ic <=> -x + ic = 0</span>
- <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>
- <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">"IC"</span><span class="p">)</span>
- <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>
- <span class="k">assert</span> <span class="n">dependency</span> <span class="ow">in</span> <span class="n">strongComponent</span>
- <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>
- <span class="k">else</span><span class="p">:</span>
- <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">"Unknown element '</span><span class="si">{}</span><span class="s2">', please implement"</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>
- <span class="k">return</span> <span class="n">M1</span><span class="p">,</span> <span class="n">M2</span></div>
- <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>
- <span class="n">M1</span><span class="p">,</span> <span class="n">M2</span> <span class="o">=</span> <span class="n">solverInput</span>
- <span class="n">n</span> <span class="o">=</span> <span class="n">M1</span><span class="o">.</span><span class="n">rows</span>
- <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>
- <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>
- <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>
- <span class="n">icol</span> <span class="o">=</span> <span class="mi">0</span>
- <span class="n">irow</span> <span class="o">=</span> <span class="mi">0</span>
- <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>
- <span class="n">big</span> <span class="o">=</span> <span class="mf">0.0</span>
- <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>
- <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>
- <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>
- <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>
- <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>
- <span class="k">if</span> <span class="n">nb</span> <span class="o">>=</span> <span class="n">big</span><span class="p">:</span>
- <span class="n">big</span> <span class="o">=</span> <span class="n">nb</span>
- <span class="n">irow</span> <span class="o">=</span> <span class="n">j</span>
- <span class="n">icol</span> <span class="o">=</span> <span class="n">k</span>
- <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">></span> <span class="mi">1</span><span class="p">:</span>
- <span class="k">raise</span> <span class="ne">ValueError</span><span class="p">(</span><span class="s2">"GAUSSJ: Singular Matrix-1"</span><span class="p">)</span>
- <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>
- <span class="k">if</span> <span class="n">irow</span> <span class="o">!=</span> <span class="n">icol</span><span class="p">:</span>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <span class="k">raise</span> <span class="ne">ValueError</span><span class="p">(</span><span class="s2">"GAUSSJ: Singular Matrix-2"</span><span class="p">)</span>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <span class="k">if</span> <span class="n">ll</span> <span class="o">!=</span> <span class="n">icol</span><span class="p">:</span>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <span class="sd">"""Custom, efficient matrix class. This class is used for efficiency purposes.</span>
- <span class="sd"> - Using a while/for loop is slow.</span>
- <span class="sd"> - Using :class:`[[0] * n] * n` will have n references to the same list.</span>
- <span class="sd"> - Using :class:`[[0] * size for _ in range(size)]` can be 5 times slower</span>
- <span class="sd"> than this class!</span>
- <span class="sd"> Numpy could be used to even further increase efficiency, but this increases the</span>
- <span class="sd"> required dependencies for external hardware systems (that may not provide these options).</span>
- <span class="sd"> Note:</span>
- <span class="sd"> Internally, the matrix is segmented into chunks of 500.000.000 items.</span>
- <span class="sd"> """</span>
- <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>
- <span class="bp">self</span><span class="o">.</span><span class="n">rows</span> <span class="o">=</span> <span class="n">rows</span>
- <span class="bp">self</span><span class="o">.</span><span class="n">cols</span> <span class="o">=</span> <span class="n">cols</span>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- <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>
- </pre></div>
- </article>
-
- </div>
- <footer>
-
- <hr>
- <div role="contentinfo">
- <p>
- © Copyright 2020, Randy Paredis.
- </p>
- </div>
-
- <div>
- 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>.
- </div>
-
- </footer>
- </div>
- </div>
- <div class="catalyst-content-right" id="catalyst-content-right">
- <div class="catalyst-right-menu" id="catalyst-right-menu">
- <div class="catalyst-side-scroll" id="catalyst-side-scroll-right">
-
- </div>
- </div>
- </div>
- </section>
- </div>
-
-
-
- <script type="text/javascript" id="documentation_options" data-url_root="../../" src="../../_static/documentation_options.js"></script>
- <script type="text/javascript" src="../../_static/jquery.js"></script>
- <script type="text/javascript" src="../../_static/underscore.js"></script>
- <script type="text/javascript" src="../../_static/doctools.js"></script>
- <script type="text/javascript" src="../../_static/language_data.js"></script>
- <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>
-
-
- <script type="text/javascript" src="../../_static/js/vendor/popper.min.js"></script>
- <script type="text/javascript" src="../../_static/js/vendor/bootstrap.min.js"></script>
- <script type="text/javascript" src="../../_static/js/theme.js"></script>
- <script type="text/javascript">
- jQuery(function () {
- SphinxRtdTheme.Navigation.enable(true);
- });
- </script>
- <!-- Begin Footer -->
- <footer class="site-footer" id="site-footer">
- <div class="container footer-container">
- <div class="footer-logo-wrapper">
- <a href="https://catalyst-team.com/" class="footer-logo"></a>
- </div>
- <div class="footer-links-wrapper">
- <div class="footer-links-col">
- <ul>
- <li class="list-title"><a href="https://github.com/catalyst-team">Ecosystem</a></li>
- <li><a class="nav-dropdown-item" href="https://alchemy.host">Alchemy</a></li>
- <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/catalyst">Catalyst</a></li>
- <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/reaction">Reaction</a></li>
- </ul>
- </div>
- <div class="footer-links-col">
- <ul>
- <li class="list-title"><a href="https://github.com/catalyst-team">Projects</a></li>
- <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/codestyle">Codestyle</a></li>
- <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/neuro">Catalyst.Neuro</a></li>
- <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/classification">Classification</a></li>
- <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/detection">Detection</a></li>
- <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/segmentation">Segmentation</a></li>
- <li><a class="nav-dropdown-item" href="https://github.com/catalyst-team/gan">Catalyst.GAN</a></li>
- </ul>
- </div>
- <div class="footer-links-col">
- <ul>
- <li class="list-title"><a href="https://catalyst-team.com/">Support</a></li>
- <li><a href="https://github.com/catalyst-team/catalyst/issues" target="_blank">Github Issues</a></li>
- <li><a href="https://github.com/catalyst-team/catalyst/blob/master/CONTRIBUTING.md" target="_blank">Contributing</a></li>
- <li><a href="https://www.patreon.com/catalyst_team" target="_blank">Patreon</a></li>
- </ul>
- </div>
- <div class="footer-links-col follow-us-col">
- <div class="footer-social-icons">
- <a href="https://t.me/catalyst_team" target="_blank" class="telegram"></a>
- <a href="https://twitter.com/catalyst_core" target="_blank" class="twitter"></a>
- <a href="https://join.slack.com/t/catalyst-team-core/shared_invite/zt-d9miirnn-z86oKDzFMKlMG4fgFdZafw" target="_blank" class="ods"></a>
- </div>
- </div>
- </div>
- </div>
- </footer>
- <!-- End Footer -->
- <!-- Begin Mobile Menu -->
- <div class="mobile-main-menu">
- <div class="container-fluid">
- <div class="container">
- <div class="mobile-main-menu-header-container">
- <a class="header-logo" href="https://catalyst-team.com/" aria-label="Catalyst"></a>
- <a class="main-menu-close-button" href="#" data-behavior="close-mobile-menu"></a>
- </div>
- </div>
- </div>
- <div class="mobile-main-menu-links-container">
- <div class="main-menu">
- <ul>
- <li>
- <a href="">Get Started</a>
- </li>
- <li>
- <a href="https://github.com/catalyst-team/catalyst">Github</a>
- </li>
- </ul>
- </div>
- </div>
- </div>
- <!-- End Mobile Menu -->
- <script type="text/javascript" src="../../_static/js/vendor/anchor.min.js"></script>
- <script type="text/javascript">
- $(document).ready(function() {
- mobileMenu.bind();
- mobileTOC.bind();
- catalystAnchors.bind();
- sideMenus.bind();
- scrollToAnchor.bind();
- highlightNavigation.bind();
- mainMenuDropdown.bind();
- // Add class to links that have code blocks, since we cannot create links in code blocks
- $("article.catalyst-article a span.pre").each(function(e) {
- $(this).closest("a").addClass("has-code");
- });
- })
- </script>
- </body>
- </html>
|