diff --git a/.buildinfo b/.buildinfo
new file mode 100644
index 000000000..48f5d1149
--- /dev/null
+++ b/.buildinfo
@@ -0,0 +1,4 @@
+# Sphinx build info version 1
+# This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done.
+config: 28c5309dbc5c6cbf1d19ea5a9ccffce7
+tags: 645f666f9bcd5a90fca523b33c5a78b7
diff --git a/.nojekyll b/.nojekyll
new file mode 100644
index 000000000..e69de29bb
diff --git a/_images/assembly.svg b/_images/assembly.svg
new file mode 100644
index 000000000..5c87b8d89
--- /dev/null
+++ b/_images/assembly.svg
@@ -0,0 +1,3364 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:ns0="http://www.iki.fi/pav/software/textext/"
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:xlink="http://www.w3.org/1999/xlink"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="420"
+   height="280"
+   id="svg91417"
+   version="1.1"
+   inkscape:version="0.48.4 r9939"
+   sodipodi:docname="assembly.svg">
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="2.6939502"
+     inkscape:cx="268.23503"
+     inkscape:cy="138.03898"
+     inkscape:current-layer="layer9"
+     inkscape:document-units="px"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     inkscape:window-width="1920"
+     inkscape:window-height="1043"
+     inkscape:window-x="0"
+     inkscape:window-y="1098"
+     inkscape:window-maximized="0"
+     borderlayer="true">
+    <inkscape:grid
+       id="grid91425"
+       type="xygrid"
+       empspacing="5"
+       visible="true"
+       enabled="true"
+       snapvisiblegridlinesonly="true" />
+    <sodipodi:guide
+       id="guide91596"
+       position="0,10"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide91598"
+       position="40,180"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide91600"
+       position="0,30"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide91602"
+       position="280,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10739"
+       position="60,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10741"
+       position="80,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10743"
+       position="100,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10745"
+       position="120,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10749"
+       position="160,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10751"
+       position="180,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10753"
+       position="200,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10755"
+       position="220,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10757"
+       position="240,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10759"
+       position="260,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10761"
+       position="0,250"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10763"
+       position="0,230"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10765"
+       position="0,50"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10767"
+       position="0,70"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10769"
+       position="0,90"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10771"
+       position="0,110"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10775"
+       position="0,150"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10777"
+       position="0,170"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10779"
+       position="0,190"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10781"
+       position="0,210"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide11285"
+       position="760,380"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide11287"
+       position="730,390"
+       orientation="1,0" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="140,280"
+       id="guide33937" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,130"
+       id="guide33941" />
+  </sodipodi:namedview>
+  <defs
+     id="defs91419">
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow1Mend"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow1Mend">
+      <path
+         transform="matrix(-0.4,0,0,-0.4,-4,0)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt"
+         d="M 0,0 5,-5 -12.5,0 5,5 0,0 z"
+         id="path12664"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="DotM"
+       style="overflow:visible">
+      <path
+         id="path21623"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91297"
+       style="overflow:visible">
+      <path
+         id="path91299"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91301"
+       style="overflow:visible">
+      <path
+         id="path91303"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91305"
+       style="overflow:visible">
+      <path
+         id="path91307"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91309"
+       style="overflow:visible">
+      <path
+         id="path91311"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91313"
+       style="overflow:visible">
+      <path
+         id="path91315"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker6626"
+       style="overflow:visible">
+      <path
+         id="path6628"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91319"
+       style="overflow:visible">
+      <path
+         id="path91321"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91323"
+       style="overflow:visible">
+      <path
+         id="path91325"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91327"
+       style="overflow:visible">
+      <path
+         id="path91329"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91331"
+       style="overflow:visible">
+      <path
+         id="path91333"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91335"
+       style="overflow:visible">
+      <path
+         id="path91337"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91339"
+       style="overflow:visible">
+      <path
+         id="path91341"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91343"
+       style="overflow:visible">
+      <path
+         id="path91345"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91347"
+       style="overflow:visible">
+      <path
+         id="path91349"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91351"
+       style="overflow:visible">
+      <path
+         id="path91353"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91355"
+       style="overflow:visible">
+      <path
+         id="path91357"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91359"
+       style="overflow:visible">
+      <path
+         id="path91361"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="DotM-8"
+       style="overflow:visible">
+      <path
+         id="path21623-3"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker11181"
+       style="overflow:visible">
+      <path
+         id="path11183"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-7"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-3"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-2"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-1"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-5"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-4"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-3"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-6"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-50"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-9"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-6"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-42"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-64"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-92"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-55"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-17"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-0"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-7"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-1"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-90"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-51"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-95"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-4"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-68"
+         inkscape:connector-curvature="0" />
+    </marker>
+  </defs>
+  <metadata
+     id="metadata91422">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     style="display:inline"
+     inkscape:groupmode="layer"
+     inkscape:label="grey matrix"
+     id="layer1"
+     transform="translate(0,-320)">
+    <rect
+       y="350.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10783"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10785"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10787"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="350.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10789"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10791"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10793"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="350.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10795"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10797"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10799"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="350.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10801"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10803"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10805"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="350.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10807"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10809"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10811"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="350.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10813"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10815"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10817"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="350.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10819"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10821"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10823"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="350.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10825"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10827"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10829"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="350.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10831"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10833"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10835"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10837"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10843"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10845"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10847"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10849"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10851"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10853"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10855"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10857"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10859"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10861"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10863"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10865"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10869"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10871"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10920"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10922"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10924"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10926"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10928"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10930"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10932"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10934"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10936"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10938"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10940"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10942"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10944"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10946"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10948"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10950"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10952"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10954"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10956"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10958"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10960"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10962"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10964"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10966"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10968"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10970"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10972"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10974"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10976"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10978"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10980"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10982"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10984"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10986"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10988"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10990"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10992"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10994"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10996"
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     inkscape:label="red matrix"
+     id="layer3"
+     inkscape:groupmode="layer"
+     transform="translate(0,-320)">
+    <rect
+       y="350.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect10999"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11001"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11003"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect11005"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect11007"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect11009"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11011"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11013"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="350.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11015"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11017"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11019"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect11021"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect11023"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect11025"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect11027"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect11029"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="350.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11031"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11033"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11035"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect11037"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11039"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect11041"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect11043"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect11045"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect11047"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect11049"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect11051"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect11053"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect11055"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect11057"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11059"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11061"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11063"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11065"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11067"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect11069"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect11071"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect11073"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect11075"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect11077"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11079"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11081"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11083"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11085"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11087"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11089"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11091"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11093"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11095"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11097"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect11099"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect11101"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect11103"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect11105"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     style="display:inline"
+     inkscape:label="blue matrix"
+     id="layer4"
+     inkscape:groupmode="layer"
+     transform="translate(0,-320)">
+    <rect
+       y="410"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11108"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11110"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11114"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11116"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11118"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11120"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11122"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11124"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11126"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     style="display:inline"
+     inkscape:label="local matrix"
+     id="layer5"
+     inkscape:groupmode="layer"
+     transform="translate(0,-320)">
+    <rect
+       y="430.04489"
+       x="320.4729"
+       height="30"
+       width="30"
+       id="rect11122-9"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.04489"
+       x="350.4729"
+       height="30"
+       width="30"
+       id="rect11122-8"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.04489"
+       x="380.4729"
+       height="30"
+       width="30"
+       id="rect11122-4"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="460.04489"
+       x="320.4729"
+       height="30"
+       width="30"
+       id="rect11122-82"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="460.04489"
+       x="350.4729"
+       height="30"
+       width="30"
+       id="rect11122-40"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="460.04489"
+       x="380.4729"
+       height="30"
+       width="30"
+       id="rect11122-2"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.04489"
+       x="320.4729"
+       height="30"
+       width="30"
+       id="rect11122-1"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.04489"
+       x="350.4729"
+       height="30"
+       width="30"
+       id="rect11122-6"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.04489"
+       x="380.4729"
+       height="30"
+       width="30"
+       id="rect11122-26"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     style="display:inline"
+     inkscape:label="matrix labels"
+     id="layer9"
+     inkscape:groupmode="layer"
+     transform="translate(0,-320)">
+    <path
+       sodipodi:nodetypes="cc"
+       inkscape:connector-curvature="0"
+       id="path14850"
+       d="m 395.10259,505.04491 c 0.66559,34.40494 -39.54344,55.31254 -144.11771,54.96592"
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-4)" />
+    <g
+       id="g16970"
+       style="display:inline"
+       transform="matrix(1.5259717,0,0,1.5259717,-339.46025,179.18118)"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       ns0:text="$\\iota_K^1(0)$">
+      <defs
+         id="defs16972">
+        <g
+           id="g16974">
+          <symbol
+             id="textext-22c7ff7c-0"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path16977"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-22c7ff7c-1"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path16980"
+               d="m 3.234375,-1.421875 c 0,-0.109375 -0.09375,-0.109375 -0.125,-0.109375 -0.09375,0 -0.109375,0.046875 -0.125,0.109375 -0.3125,0.984375 -1.140625,1.3125 -1.5625,1.3125 -0.140625,0 -0.265625,-0.03125 -0.265625,-0.328125 0,-0.234375 0.078125,-0.46875 0.171875,-0.734375 C 1.78125,-2.375 2.1875,-4.0625 2.1875,-4.140625 2.1875,-4.3125 2.078125,-4.40625 1.90625,-4.40625 c -0.109375,0 -0.296875,0.0625 -0.375,0.265625 -0.0625,0.1875 -0.15625,0.671875 -0.21875,0.859375 -0.015625,0.046875 -0.265625,0.921875 -0.296875,1.0625 -0.03125,0.09375 -0.125,0.34375 -0.140625,0.4375 -0.078125,0.28125 -0.3125,0.75 -0.3125,1.078125 0,0.40625 0.28125,0.8125 0.828125,0.8125 1.140625,0 1.84375,-1.203125 1.84375,-1.53125 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-22c7ff7c-2"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path16983"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-22c7ff7c-3"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path16986"
+               d="m 2.328125,-4.4375 c 0,-0.1875 0,-0.1875 -0.203125,-0.1875 -0.453125,0.4375 -1.078125,0.4375 -1.359375,0.4375 l 0,0.25 c 0.15625,0 0.625,0 1,-0.1875 l 0,3.546875 c 0,0.234375 0,0.328125 -0.6875,0.328125 l -0.265625,0 0,0.25 c 0.125,0 0.984375,-0.03125 1.234375,-0.03125 0.21875,0 1.09375,0.03125 1.25,0.03125 l 0,-0.25 -0.265625,0 c -0.703125,0 -0.703125,-0.09375 -0.703125,-0.328125 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-22c7ff7c-4"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path16989"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-22c7ff7c-5"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path16992"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-22c7ff7c-6"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path16995"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-22c7ff7c-7"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path16998"
+               d="m 3.296875,2.390625 c 0,-0.03125 0,-0.046875 -0.171875,-0.21875 C 1.890625,0.921875 1.5625,-0.96875 1.5625,-2.5 c 0,-1.734375 0.375,-3.46875 1.609375,-4.703125 0.125,-0.125 0.125,-0.140625 0.125,-0.171875 0,-0.078125 -0.03125,-0.109375 -0.09375,-0.109375 -0.109375,0 -1,0.6875 -1.59375,1.953125 -0.5,1.09375 -0.625,2.203125 -0.625,3.03125 0,0.78125 0.109375,1.984375 0.65625,3.125 C 2.25,1.84375 3.09375,2.5 3.203125,2.5 c 0.0625,0 0.09375,-0.03125 0.09375,-0.109375 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-22c7ff7c-8"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path17001"
+               d="m 4.578125,-3.1875 c 0,-0.796875 -0.046875,-1.59375 -0.390625,-2.328125 -0.453125,-0.96875 -1.28125,-1.125 -1.6875,-1.125 -0.609375,0 -1.328125,0.265625 -1.75,1.1875 -0.3125,0.6875 -0.359375,1.46875 -0.359375,2.265625 0,0.75 0.03125,1.640625 0.453125,2.40625 0.421875,0.796875 1.15625,1 1.640625,1 0.53125,0 1.296875,-0.203125 1.734375,-1.15625 0.3125,-0.6875 0.359375,-1.46875 0.359375,-2.25 z M 2.484375,0 C 2.09375,0 1.5,-0.25 1.328125,-1.203125 1.21875,-1.796875 1.21875,-2.71875 1.21875,-3.3125 c 0,-0.640625 0,-1.296875 0.078125,-1.828125 0.1875,-1.1875 0.9375,-1.28125 1.1875,-1.28125 0.328125,0 0.984375,0.1875 1.171875,1.171875 0.109375,0.5625 0.109375,1.3125 0.109375,1.9375 0,0.75 0,1.421875 -0.109375,2.0625 C 3.5,-0.296875 2.9375,0 2.484375,0 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-22c7ff7c-9"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path17004"
+               d="m 2.875,-2.5 c 0,-0.765625 -0.109375,-1.96875 -0.65625,-3.109375 -0.59375,-1.21875 -1.453125,-1.875 -1.546875,-1.875 -0.0625,0 -0.109375,0.046875 -0.109375,0.109375 0,0.03125 0,0.046875 0.1875,0.234375 0.984375,0.984375 1.546875,2.5625 1.546875,4.640625 0,1.71875 -0.359375,3.46875 -1.59375,4.71875 C 0.5625,2.34375 0.5625,2.359375 0.5625,2.390625 0.5625,2.453125 0.609375,2.5 0.671875,2.5 0.765625,2.5 1.671875,1.8125 2.25,0.546875 2.765625,-0.546875 2.875,-1.65625 2.875,-2.5 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-22c7ff7c-10">
+        <g
+           id="g17007"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use17009"
+             y="134.765"
+             x="223.43201"
+             xlink:href="#textext-22c7ff7c-1"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g17011"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use17013"
+             y="131.149"
+             x="226.95799"
+             xlink:href="#textext-22c7ff7c-3"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g17015"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use17017"
+             y="137.509"
+             x="226.95799"
+             xlink:href="#textext-22c7ff7c-5"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g17019"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use17021"
+             y="134.765"
+             x="234.63901"
+             xlink:href="#textext-22c7ff7c-7"
+             width="800"
+             height="600" />
+          <use
+             id="use17023"
+             y="134.765"
+             x="238.51346"
+             xlink:href="#textext-22c7ff7c-8"
+             width="800"
+             height="600" />
+          <use
+             id="use17025"
+             y="134.765"
+             x="243.49475"
+             xlink:href="#textext-22c7ff7c-9"
+             width="800"
+             height="600" />
+        </g>
+      </g>
+    </g>
+    <g
+       ns0:text="$\\iota_K^1(2)$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       transform="matrix(1.5259717,0,0,1.5259717,-339.46025,359.10361)"
+       style="display:inline"
+       id="g16080-5">
+      <defs
+         id="defs16082-3">
+        <g
+           id="g16084-3">
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-4005323c-0-2">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path16087-8" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-4005323c-1-5">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 3.234375,-1.421875 c 0,-0.109375 -0.09375,-0.109375 -0.125,-0.109375 -0.09375,0 -0.109375,0.046875 -0.125,0.109375 -0.3125,0.984375 -1.140625,1.3125 -1.5625,1.3125 -0.140625,0 -0.265625,-0.03125 -0.265625,-0.328125 0,-0.234375 0.078125,-0.46875 0.171875,-0.734375 C 1.78125,-2.375 2.1875,-4.0625 2.1875,-4.140625 2.1875,-4.3125 2.078125,-4.40625 1.90625,-4.40625 c -0.109375,0 -0.296875,0.0625 -0.375,0.265625 -0.0625,0.1875 -0.15625,0.671875 -0.21875,0.859375 -0.015625,0.046875 -0.265625,0.921875 -0.296875,1.0625 -0.03125,0.09375 -0.125,0.34375 -0.140625,0.4375 -0.078125,0.28125 -0.3125,0.75 -0.3125,1.078125 0,0.40625 0.28125,0.8125 0.828125,0.8125 1.140625,0 1.84375,-1.203125 1.84375,-1.53125 z"
+               id="path16090-4" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-4005323c-2-9">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path16093-5" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-4005323c-3-4">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 2.328125,-4.4375 c 0,-0.1875 0,-0.1875 -0.203125,-0.1875 -0.453125,0.4375 -1.078125,0.4375 -1.359375,0.4375 l 0,0.25 c 0.15625,0 0.625,0 1,-0.1875 l 0,3.546875 c 0,0.234375 0,0.328125 -0.6875,0.328125 l -0.265625,0 0,0.25 c 0.125,0 0.984375,-0.03125 1.234375,-0.03125 0.21875,0 1.09375,0.03125 1.25,0.03125 l 0,-0.25 -0.265625,0 c -0.703125,0 -0.703125,-0.09375 -0.703125,-0.328125 z"
+               id="path16096-1" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-4005323c-4-5">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path16099-8" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-4005323c-5-8">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               id="path16102-9" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-4005323c-6-4">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path16105-3" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-4005323c-7-8">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 3.296875,2.390625 c 0,-0.03125 0,-0.046875 -0.171875,-0.21875 C 1.890625,0.921875 1.5625,-0.96875 1.5625,-2.5 c 0,-1.734375 0.375,-3.46875 1.609375,-4.703125 0.125,-0.125 0.125,-0.140625 0.125,-0.171875 0,-0.078125 -0.03125,-0.109375 -0.09375,-0.109375 -0.109375,0 -1,0.6875 -1.59375,1.953125 -0.5,1.09375 -0.625,2.203125 -0.625,3.03125 0,0.78125 0.109375,1.984375 0.65625,3.125 C 2.25,1.84375 3.09375,2.5 3.203125,2.5 c 0.0625,0 0.09375,-0.03125 0.09375,-0.109375 z"
+               id="path16108-4" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-4005323c-8-0">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 1.265625,-0.765625 1.0625,-1.03125 c 1.546875,-1.375 2.140625,-1.90625 2.140625,-2.90625 0,-1.140625 -0.890625,-1.9375 -2.109375,-1.9375 -1.125,0 -1.859375,0.921875 -1.859375,1.8125 0,0.546875 0.5,0.546875 0.53125,0.546875 0.171875,0 0.515625,-0.109375 0.515625,-0.53125 0,-0.25 -0.1875,-0.515625 -0.53125,-0.515625 -0.078125,0 -0.09375,0 -0.125,0.015625 0.21875,-0.65625 0.765625,-1.015625 1.34375,-1.015625 0.90625,0 1.328125,0.8125 1.328125,1.625 C 3.5625,-3.90625 3.078125,-3.125 2.515625,-2.5 l -1.90625,2.125 C 0.5,-0.265625 0.5,-0.234375 0.5,0 l 3.703125,0 0.265625,-1.734375 -0.234375,0 C 4.171875,-1.4375 4.109375,-1 4,-0.84375 3.9375,-0.765625 3.28125,-0.765625 3.0625,-0.765625 z"
+               id="path16111-5" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-4005323c-9-0">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 2.875,-2.5 c 0,-0.765625 -0.109375,-1.96875 -0.65625,-3.109375 -0.59375,-1.21875 -1.453125,-1.875 -1.546875,-1.875 -0.0625,0 -0.109375,0.046875 -0.109375,0.109375 0,0.03125 0,0.046875 0.1875,0.234375 0.984375,0.984375 1.546875,2.5625 1.546875,4.640625 0,1.71875 -0.359375,3.46875 -1.59375,4.71875 C 0.5625,2.34375 0.5625,2.359375 0.5625,2.390625 0.5625,2.453125 0.609375,2.5 0.671875,2.5 0.765625,2.5 1.671875,1.8125 2.25,0.546875 2.765625,-0.546875 2.875,-1.65625 2.875,-2.5 z"
+               id="path16114-8" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-4005323c-10-2">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g16117-4">
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-4005323c-1-5"
+             x="223.43201"
+             y="134.765"
+             id="use16119-0" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g16121-9">
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-4005323c-3-4"
+             x="226.95799"
+             y="131.149"
+             id="use16123-3" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g16125-8">
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-4005323c-5-8"
+             x="226.95799"
+             y="137.509"
+             id="use16127-8" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g16129-5">
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-4005323c-7-8"
+             x="234.63901"
+             y="134.765"
+             id="use16131-4" />
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-4005323c-8-0"
+             x="238.51346"
+             y="134.765"
+             id="use16133-2" />
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-4005323c-9-0"
+             x="243.49475"
+             y="134.765"
+             id="use16135-1" />
+        </g>
+      </g>
+    </g>
+    <g
+       ns0:text="$\\iota_K^1(1)$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       transform="matrix(1.5259717,0,0,1.5259717,-339.46025,258.99586)"
+       style="display:inline"
+       id="g17870">
+      <defs
+         id="defs17872">
+        <g
+           id="g17874">
+          <symbol
+             overflow="visible"
+             id="textext-040003fe-0"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d=""
+               id="path17877"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-040003fe-1"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d="m 3.234375,-1.421875 c 0,-0.109375 -0.09375,-0.109375 -0.125,-0.109375 -0.09375,0 -0.109375,0.046875 -0.125,0.109375 -0.3125,0.984375 -1.140625,1.3125 -1.5625,1.3125 -0.140625,0 -0.265625,-0.03125 -0.265625,-0.328125 0,-0.234375 0.078125,-0.46875 0.171875,-0.734375 C 1.78125,-2.375 2.1875,-4.0625 2.1875,-4.140625 2.1875,-4.3125 2.078125,-4.40625 1.90625,-4.40625 c -0.109375,0 -0.296875,0.0625 -0.375,0.265625 -0.0625,0.1875 -0.15625,0.671875 -0.21875,0.859375 -0.015625,0.046875 -0.265625,0.921875 -0.296875,1.0625 -0.03125,0.09375 -0.125,0.34375 -0.140625,0.4375 -0.078125,0.28125 -0.3125,0.75 -0.3125,1.078125 0,0.40625 0.28125,0.8125 0.828125,0.8125 1.140625,0 1.84375,-1.203125 1.84375,-1.53125 z"
+               id="path17880"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-040003fe-2"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d=""
+               id="path17883"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-040003fe-3"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d="m 2.328125,-4.4375 c 0,-0.1875 0,-0.1875 -0.203125,-0.1875 -0.453125,0.4375 -1.078125,0.4375 -1.359375,0.4375 l 0,0.25 c 0.15625,0 0.625,0 1,-0.1875 l 0,3.546875 c 0,0.234375 0,0.328125 -0.6875,0.328125 l -0.265625,0 0,0.25 c 0.125,0 0.984375,-0.03125 1.234375,-0.03125 0.21875,0 1.09375,0.03125 1.25,0.03125 l 0,-0.25 -0.265625,0 c -0.703125,0 -0.703125,-0.09375 -0.703125,-0.328125 z"
+               id="path17886"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-040003fe-4"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d=""
+               id="path17889"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-040003fe-5"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               id="path17892"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-040003fe-6"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d=""
+               id="path17895"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-040003fe-7"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d="m 3.296875,2.390625 c 0,-0.03125 0,-0.046875 -0.171875,-0.21875 C 1.890625,0.921875 1.5625,-0.96875 1.5625,-2.5 c 0,-1.734375 0.375,-3.46875 1.609375,-4.703125 0.125,-0.125 0.125,-0.140625 0.125,-0.171875 0,-0.078125 -0.03125,-0.109375 -0.09375,-0.109375 -0.109375,0 -1,0.6875 -1.59375,1.953125 -0.5,1.09375 -0.625,2.203125 -0.625,3.03125 0,0.78125 0.109375,1.984375 0.65625,3.125 C 2.25,1.84375 3.09375,2.5 3.203125,2.5 c 0.0625,0 0.09375,-0.03125 0.09375,-0.109375 z"
+               id="path17898"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-040003fe-8"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d="m 2.9375,-6.375 c 0,-0.25 0,-0.265625 -0.234375,-0.265625 C 2.078125,-6 1.203125,-6 0.890625,-6 l 0,0.3125 c 0.203125,0 0.78125,0 1.296875,-0.265625 l 0,5.171875 c 0,0.359375 -0.03125,0.46875 -0.921875,0.46875 l -0.3125,0 0,0.3125 c 0.34375,-0.03125 1.203125,-0.03125 1.609375,-0.03125 0.390625,0 1.265625,0 1.609375,0.03125 l 0,-0.3125 -0.3125,0 c -0.90625,0 -0.921875,-0.109375 -0.921875,-0.46875 z"
+               id="path17901"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-040003fe-9"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d="m 2.875,-2.5 c 0,-0.765625 -0.109375,-1.96875 -0.65625,-3.109375 -0.59375,-1.21875 -1.453125,-1.875 -1.546875,-1.875 -0.0625,0 -0.109375,0.046875 -0.109375,0.109375 0,0.03125 0,0.046875 0.1875,0.234375 0.984375,0.984375 1.546875,2.5625 1.546875,4.640625 0,1.71875 -0.359375,3.46875 -1.59375,4.71875 C 0.5625,2.34375 0.5625,2.359375 0.5625,2.390625 0.5625,2.453125 0.609375,2.5 0.671875,2.5 0.765625,2.5 1.671875,1.8125 2.25,0.546875 2.765625,-0.546875 2.875,-1.65625 2.875,-2.5 z"
+               id="path17904"
+               inkscape:connector-curvature="0" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-040003fe-10">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g17907">
+          <use
+             xlink:href="#textext-040003fe-1"
+             x="223.43201"
+             y="134.765"
+             id="use17909"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g17911">
+          <use
+             xlink:href="#textext-040003fe-3"
+             x="226.95799"
+             y="131.149"
+             id="use17913"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g17915">
+          <use
+             xlink:href="#textext-040003fe-5"
+             x="226.95799"
+             y="137.509"
+             id="use17917"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g17919">
+          <use
+             xlink:href="#textext-040003fe-7"
+             x="234.63901"
+             y="134.765"
+             id="use17921"
+             width="800"
+             height="600" />
+          <use
+             xlink:href="#textext-040003fe-8"
+             x="238.51346"
+             y="134.765"
+             id="use17923"
+             width="800"
+             height="600" />
+          <use
+             xlink:href="#textext-040003fe-9"
+             x="243.49475"
+             y="134.765"
+             id="use17925"
+             width="800"
+             height="600" />
+        </g>
+      </g>
+    </g>
+    <g
+       id="g19140"
+       style="display:inline"
+       transform="matrix(1.5259717,0,0,1.5259717,-250.66415,135.42153)"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       ns0:text="$\\iota_K^2(0)$">
+      <defs
+         id="defs19142">
+        <g
+           id="g19144">
+          <symbol
+             id="textext-90b3d5c8-0"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path19147"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-90b3d5c8-1"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path19150"
+               d="m 3.234375,-1.421875 c 0,-0.109375 -0.09375,-0.109375 -0.125,-0.109375 -0.09375,0 -0.109375,0.046875 -0.125,0.109375 -0.3125,0.984375 -1.140625,1.3125 -1.5625,1.3125 -0.140625,0 -0.265625,-0.03125 -0.265625,-0.328125 0,-0.234375 0.078125,-0.46875 0.171875,-0.734375 C 1.78125,-2.375 2.1875,-4.0625 2.1875,-4.140625 2.1875,-4.3125 2.078125,-4.40625 1.90625,-4.40625 c -0.109375,0 -0.296875,0.0625 -0.375,0.265625 -0.0625,0.1875 -0.15625,0.671875 -0.21875,0.859375 -0.015625,0.046875 -0.265625,0.921875 -0.296875,1.0625 -0.03125,0.09375 -0.125,0.34375 -0.140625,0.4375 -0.078125,0.28125 -0.3125,0.75 -0.3125,1.078125 0,0.40625 0.28125,0.8125 0.828125,0.8125 1.140625,0 1.84375,-1.203125 1.84375,-1.53125 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-90b3d5c8-2"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path19153"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-90b3d5c8-3"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path19156"
+               d="m 3.515625,-1.265625 -0.234375,0 c -0.015625,0.15625 -0.09375,0.5625 -0.1875,0.625 -0.046875,0.046875 -0.578125,0.046875 -0.6875,0.046875 l -1.28125,0 c 0.734375,-0.640625 0.984375,-0.84375 1.390625,-1.171875 0.515625,-0.40625 1,-0.84375 1,-1.5 0,-0.84375 -0.734375,-1.359375 -1.625,-1.359375 -0.859375,0 -1.453125,0.609375 -1.453125,1.25 0,0.34375 0.296875,0.390625 0.375,0.390625 0.15625,0 0.359375,-0.125 0.359375,-0.375 0,-0.125 -0.046875,-0.375 -0.40625,-0.375 C 0.984375,-4.21875 1.453125,-4.375 1.78125,-4.375 c 0.703125,0 1.0625,0.546875 1.0625,1.109375 0,0.609375 -0.4375,1.078125 -0.65625,1.328125 L 0.515625,-0.265625 C 0.4375,-0.203125 0.4375,-0.1875 0.4375,0 l 2.875,0 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-90b3d5c8-4"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path19159"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-90b3d5c8-5"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path19162"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-90b3d5c8-6"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path19165"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-90b3d5c8-7"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path19168"
+               d="m 3.296875,2.390625 c 0,-0.03125 0,-0.046875 -0.171875,-0.21875 C 1.890625,0.921875 1.5625,-0.96875 1.5625,-2.5 c 0,-1.734375 0.375,-3.46875 1.609375,-4.703125 0.125,-0.125 0.125,-0.140625 0.125,-0.171875 0,-0.078125 -0.03125,-0.109375 -0.09375,-0.109375 -0.109375,0 -1,0.6875 -1.59375,1.953125 -0.5,1.09375 -0.625,2.203125 -0.625,3.03125 0,0.78125 0.109375,1.984375 0.65625,3.125 C 2.25,1.84375 3.09375,2.5 3.203125,2.5 c 0.0625,0 0.09375,-0.03125 0.09375,-0.109375 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-90b3d5c8-8"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path19171"
+               d="m 4.578125,-3.1875 c 0,-0.796875 -0.046875,-1.59375 -0.390625,-2.328125 -0.453125,-0.96875 -1.28125,-1.125 -1.6875,-1.125 -0.609375,0 -1.328125,0.265625 -1.75,1.1875 -0.3125,0.6875 -0.359375,1.46875 -0.359375,2.265625 0,0.75 0.03125,1.640625 0.453125,2.40625 0.421875,0.796875 1.15625,1 1.640625,1 0.53125,0 1.296875,-0.203125 1.734375,-1.15625 0.3125,-0.6875 0.359375,-1.46875 0.359375,-2.25 z M 2.484375,0 C 2.09375,0 1.5,-0.25 1.328125,-1.203125 1.21875,-1.796875 1.21875,-2.71875 1.21875,-3.3125 c 0,-0.640625 0,-1.296875 0.078125,-1.828125 0.1875,-1.1875 0.9375,-1.28125 1.1875,-1.28125 0.328125,0 0.984375,0.1875 1.171875,1.171875 0.109375,0.5625 0.109375,1.3125 0.109375,1.9375 0,0.75 0,1.421875 -0.109375,2.0625 C 3.5,-0.296875 2.9375,0 2.484375,0 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-90b3d5c8-9"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path19174"
+               d="m 2.875,-2.5 c 0,-0.765625 -0.109375,-1.96875 -0.65625,-3.109375 -0.59375,-1.21875 -1.453125,-1.875 -1.546875,-1.875 -0.0625,0 -0.109375,0.046875 -0.109375,0.109375 0,0.03125 0,0.046875 0.1875,0.234375 0.984375,0.984375 1.546875,2.5625 1.546875,4.640625 0,1.71875 -0.359375,3.46875 -1.59375,4.71875 C 0.5625,2.34375 0.5625,2.359375 0.5625,2.390625 0.5625,2.453125 0.609375,2.5 0.671875,2.5 0.765625,2.5 1.671875,1.8125 2.25,0.546875 2.765625,-0.546875 2.875,-1.65625 2.875,-2.5 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-90b3d5c8-10">
+        <g
+           id="g19177"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use19179"
+             y="134.765"
+             x="223.43201"
+             xlink:href="#textext-90b3d5c8-1"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g19181"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use19183"
+             y="131.149"
+             x="226.95799"
+             xlink:href="#textext-90b3d5c8-3"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g19185"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use19187"
+             y="137.509"
+             x="226.95799"
+             xlink:href="#textext-90b3d5c8-5"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g19189"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use19191"
+             y="134.765"
+             x="234.63901"
+             xlink:href="#textext-90b3d5c8-7"
+             width="800"
+             height="600" />
+          <use
+             id="use19193"
+             y="134.765"
+             x="238.51346"
+             xlink:href="#textext-90b3d5c8-8"
+             width="800"
+             height="600" />
+          <use
+             id="use19195"
+             y="134.765"
+             x="243.49475"
+             xlink:href="#textext-90b3d5c8-9"
+             width="800"
+             height="600" />
+        </g>
+      </g>
+    </g>
+    <g
+       ns0:text="$\\iota_K^2(1)$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       transform="matrix(1.5259717,0,0,1.5259717,-210.15159,135.42153)"
+       style="display:inline"
+       id="g20161">
+      <defs
+         id="defs20163">
+        <g
+           id="g20165">
+          <symbol
+             overflow="visible"
+             id="textext-a6d7e82b-0"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d=""
+               id="path20168"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-a6d7e82b-1"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d="m 3.234375,-1.421875 c 0,-0.109375 -0.09375,-0.109375 -0.125,-0.109375 -0.09375,0 -0.109375,0.046875 -0.125,0.109375 -0.3125,0.984375 -1.140625,1.3125 -1.5625,1.3125 -0.140625,0 -0.265625,-0.03125 -0.265625,-0.328125 0,-0.234375 0.078125,-0.46875 0.171875,-0.734375 C 1.78125,-2.375 2.1875,-4.0625 2.1875,-4.140625 2.1875,-4.3125 2.078125,-4.40625 1.90625,-4.40625 c -0.109375,0 -0.296875,0.0625 -0.375,0.265625 -0.0625,0.1875 -0.15625,0.671875 -0.21875,0.859375 -0.015625,0.046875 -0.265625,0.921875 -0.296875,1.0625 -0.03125,0.09375 -0.125,0.34375 -0.140625,0.4375 -0.078125,0.28125 -0.3125,0.75 -0.3125,1.078125 0,0.40625 0.28125,0.8125 0.828125,0.8125 1.140625,0 1.84375,-1.203125 1.84375,-1.53125 z"
+               id="path20171"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-a6d7e82b-2"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d=""
+               id="path20174"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-a6d7e82b-3"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d="m 3.515625,-1.265625 -0.234375,0 c -0.015625,0.15625 -0.09375,0.5625 -0.1875,0.625 -0.046875,0.046875 -0.578125,0.046875 -0.6875,0.046875 l -1.28125,0 c 0.734375,-0.640625 0.984375,-0.84375 1.390625,-1.171875 0.515625,-0.40625 1,-0.84375 1,-1.5 0,-0.84375 -0.734375,-1.359375 -1.625,-1.359375 -0.859375,0 -1.453125,0.609375 -1.453125,1.25 0,0.34375 0.296875,0.390625 0.375,0.390625 0.15625,0 0.359375,-0.125 0.359375,-0.375 0,-0.125 -0.046875,-0.375 -0.40625,-0.375 C 0.984375,-4.21875 1.453125,-4.375 1.78125,-4.375 c 0.703125,0 1.0625,0.546875 1.0625,1.109375 0,0.609375 -0.4375,1.078125 -0.65625,1.328125 L 0.515625,-0.265625 C 0.4375,-0.203125 0.4375,-0.1875 0.4375,0 l 2.875,0 z"
+               id="path20177"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-a6d7e82b-4"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d=""
+               id="path20180"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-a6d7e82b-5"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               id="path20183"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-a6d7e82b-6"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d=""
+               id="path20186"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-a6d7e82b-7"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d="m 3.296875,2.390625 c 0,-0.03125 0,-0.046875 -0.171875,-0.21875 C 1.890625,0.921875 1.5625,-0.96875 1.5625,-2.5 c 0,-1.734375 0.375,-3.46875 1.609375,-4.703125 0.125,-0.125 0.125,-0.140625 0.125,-0.171875 0,-0.078125 -0.03125,-0.109375 -0.09375,-0.109375 -0.109375,0 -1,0.6875 -1.59375,1.953125 -0.5,1.09375 -0.625,2.203125 -0.625,3.03125 0,0.78125 0.109375,1.984375 0.65625,3.125 C 2.25,1.84375 3.09375,2.5 3.203125,2.5 c 0.0625,0 0.09375,-0.03125 0.09375,-0.109375 z"
+               id="path20189"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-a6d7e82b-8"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d="m 2.9375,-6.375 c 0,-0.25 0,-0.265625 -0.234375,-0.265625 C 2.078125,-6 1.203125,-6 0.890625,-6 l 0,0.3125 c 0.203125,0 0.78125,0 1.296875,-0.265625 l 0,5.171875 c 0,0.359375 -0.03125,0.46875 -0.921875,0.46875 l -0.3125,0 0,0.3125 c 0.34375,-0.03125 1.203125,-0.03125 1.609375,-0.03125 0.390625,0 1.265625,0 1.609375,0.03125 l 0,-0.3125 -0.3125,0 c -0.90625,0 -0.921875,-0.109375 -0.921875,-0.46875 z"
+               id="path20192"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             overflow="visible"
+             id="textext-a6d7e82b-9"
+             style="overflow:visible">
+            <path
+               style="stroke:none"
+               d="m 2.875,-2.5 c 0,-0.765625 -0.109375,-1.96875 -0.65625,-3.109375 -0.59375,-1.21875 -1.453125,-1.875 -1.546875,-1.875 -0.0625,0 -0.109375,0.046875 -0.109375,0.109375 0,0.03125 0,0.046875 0.1875,0.234375 0.984375,0.984375 1.546875,2.5625 1.546875,4.640625 0,1.71875 -0.359375,3.46875 -1.59375,4.71875 C 0.5625,2.34375 0.5625,2.359375 0.5625,2.390625 0.5625,2.453125 0.609375,2.5 0.671875,2.5 0.765625,2.5 1.671875,1.8125 2.25,0.546875 2.765625,-0.546875 2.875,-1.65625 2.875,-2.5 z"
+               id="path20195"
+               inkscape:connector-curvature="0" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-a6d7e82b-10">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g20198">
+          <use
+             xlink:href="#textext-a6d7e82b-1"
+             x="223.43201"
+             y="134.765"
+             id="use20200"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g20202">
+          <use
+             xlink:href="#textext-a6d7e82b-3"
+             x="226.95799"
+             y="131.149"
+             id="use20204"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g20206">
+          <use
+             xlink:href="#textext-a6d7e82b-5"
+             x="226.95799"
+             y="137.509"
+             id="use20208"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g20210">
+          <use
+             xlink:href="#textext-a6d7e82b-7"
+             x="234.63901"
+             y="134.765"
+             id="use20212"
+             width="800"
+             height="600" />
+          <use
+             xlink:href="#textext-a6d7e82b-8"
+             x="238.51346"
+             y="134.765"
+             id="use20214"
+             width="800"
+             height="600" />
+          <use
+             xlink:href="#textext-a6d7e82b-9"
+             x="243.49475"
+             y="134.765"
+             id="use20216"
+             width="800"
+             height="600" />
+        </g>
+      </g>
+    </g>
+    <g
+       id="g21182"
+       style="display:inline"
+       transform="matrix(1.5259717,0,0,1.5259717,-110.04385,135.42153)"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       ns0:text="$\\iota_K^2(2)$">
+      <defs
+         id="defs21184">
+        <g
+           id="g21186">
+          <symbol
+             id="textext-ebf5baed-0"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path21189"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-ebf5baed-1"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path21192"
+               d="m 3.234375,-1.421875 c 0,-0.109375 -0.09375,-0.109375 -0.125,-0.109375 -0.09375,0 -0.109375,0.046875 -0.125,0.109375 -0.3125,0.984375 -1.140625,1.3125 -1.5625,1.3125 -0.140625,0 -0.265625,-0.03125 -0.265625,-0.328125 0,-0.234375 0.078125,-0.46875 0.171875,-0.734375 C 1.78125,-2.375 2.1875,-4.0625 2.1875,-4.140625 2.1875,-4.3125 2.078125,-4.40625 1.90625,-4.40625 c -0.109375,0 -0.296875,0.0625 -0.375,0.265625 -0.0625,0.1875 -0.15625,0.671875 -0.21875,0.859375 -0.015625,0.046875 -0.265625,0.921875 -0.296875,1.0625 -0.03125,0.09375 -0.125,0.34375 -0.140625,0.4375 -0.078125,0.28125 -0.3125,0.75 -0.3125,1.078125 0,0.40625 0.28125,0.8125 0.828125,0.8125 1.140625,0 1.84375,-1.203125 1.84375,-1.53125 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-ebf5baed-2"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path21195"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-ebf5baed-3"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path21198"
+               d="m 3.515625,-1.265625 -0.234375,0 c -0.015625,0.15625 -0.09375,0.5625 -0.1875,0.625 -0.046875,0.046875 -0.578125,0.046875 -0.6875,0.046875 l -1.28125,0 c 0.734375,-0.640625 0.984375,-0.84375 1.390625,-1.171875 0.515625,-0.40625 1,-0.84375 1,-1.5 0,-0.84375 -0.734375,-1.359375 -1.625,-1.359375 -0.859375,0 -1.453125,0.609375 -1.453125,1.25 0,0.34375 0.296875,0.390625 0.375,0.390625 0.15625,0 0.359375,-0.125 0.359375,-0.375 0,-0.125 -0.046875,-0.375 -0.40625,-0.375 C 0.984375,-4.21875 1.453125,-4.375 1.78125,-4.375 c 0.703125,0 1.0625,0.546875 1.0625,1.109375 0,0.609375 -0.4375,1.078125 -0.65625,1.328125 L 0.515625,-0.265625 C 0.4375,-0.203125 0.4375,-0.1875 0.4375,0 l 2.875,0 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-ebf5baed-4"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path21201"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-ebf5baed-5"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path21204"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-ebf5baed-6"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path21207"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-ebf5baed-7"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path21210"
+               d="m 3.296875,2.390625 c 0,-0.03125 0,-0.046875 -0.171875,-0.21875 C 1.890625,0.921875 1.5625,-0.96875 1.5625,-2.5 c 0,-1.734375 0.375,-3.46875 1.609375,-4.703125 0.125,-0.125 0.125,-0.140625 0.125,-0.171875 0,-0.078125 -0.03125,-0.109375 -0.09375,-0.109375 -0.109375,0 -1,0.6875 -1.59375,1.953125 -0.5,1.09375 -0.625,2.203125 -0.625,3.03125 0,0.78125 0.109375,1.984375 0.65625,3.125 C 2.25,1.84375 3.09375,2.5 3.203125,2.5 c 0.0625,0 0.09375,-0.03125 0.09375,-0.109375 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-ebf5baed-8"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path21213"
+               d="m 1.265625,-0.765625 1.0625,-1.03125 c 1.546875,-1.375 2.140625,-1.90625 2.140625,-2.90625 0,-1.140625 -0.890625,-1.9375 -2.109375,-1.9375 -1.125,0 -1.859375,0.921875 -1.859375,1.8125 0,0.546875 0.5,0.546875 0.53125,0.546875 0.171875,0 0.515625,-0.109375 0.515625,-0.53125 0,-0.25 -0.1875,-0.515625 -0.53125,-0.515625 -0.078125,0 -0.09375,0 -0.125,0.015625 0.21875,-0.65625 0.765625,-1.015625 1.34375,-1.015625 0.90625,0 1.328125,0.8125 1.328125,1.625 C 3.5625,-3.90625 3.078125,-3.125 2.515625,-2.5 l -1.90625,2.125 C 0.5,-0.265625 0.5,-0.234375 0.5,0 l 3.703125,0 0.265625,-1.734375 -0.234375,0 C 4.171875,-1.4375 4.109375,-1 4,-0.84375 3.9375,-0.765625 3.28125,-0.765625 3.0625,-0.765625 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-ebf5baed-9"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path21216"
+               d="m 2.875,-2.5 c 0,-0.765625 -0.109375,-1.96875 -0.65625,-3.109375 -0.59375,-1.21875 -1.453125,-1.875 -1.546875,-1.875 -0.0625,0 -0.109375,0.046875 -0.109375,0.109375 0,0.03125 0,0.046875 0.1875,0.234375 0.984375,0.984375 1.546875,2.5625 1.546875,4.640625 0,1.71875 -0.359375,3.46875 -1.59375,4.71875 C 0.5625,2.34375 0.5625,2.359375 0.5625,2.390625 0.5625,2.453125 0.609375,2.5 0.671875,2.5 0.765625,2.5 1.671875,1.8125 2.25,0.546875 2.765625,-0.546875 2.875,-1.65625 2.875,-2.5 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-ebf5baed-10">
+        <g
+           id="g21219"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use21221"
+             y="134.765"
+             x="223.43201"
+             xlink:href="#textext-ebf5baed-1"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g21223"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use21225"
+             y="131.149"
+             x="226.95799"
+             xlink:href="#textext-ebf5baed-3"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g21227"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use21229"
+             y="137.509"
+             x="226.95799"
+             xlink:href="#textext-ebf5baed-5"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g21231"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use21233"
+             y="134.765"
+             x="234.63901"
+             xlink:href="#textext-ebf5baed-7"
+             width="800"
+             height="600" />
+          <use
+             id="use21235"
+             y="134.765"
+             x="238.51346"
+             xlink:href="#textext-ebf5baed-8"
+             width="800"
+             height="600" />
+          <use
+             id="use21237"
+             y="134.765"
+             x="243.49475"
+             xlink:href="#textext-ebf5baed-9"
+             width="800"
+             height="600" />
+        </g>
+      </g>
+    </g>
+    <g
+       transform="matrix(1.7910448,0,0,1.7910448,-68.987823,182.54147)"
+       ns0:text="$0$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       id="g22235">
+      <defs
+         id="defs22237">
+        <g
+           id="g22239">
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-df25895d-0">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path22242" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-df25895d-1">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 4.578125,-3.1875 c 0,-0.796875 -0.046875,-1.59375 -0.390625,-2.328125 -0.453125,-0.96875 -1.28125,-1.125 -1.6875,-1.125 -0.609375,0 -1.328125,0.265625 -1.75,1.1875 -0.3125,0.6875 -0.359375,1.46875 -0.359375,2.265625 0,0.75 0.03125,1.640625 0.453125,2.40625 0.421875,0.796875 1.15625,1 1.640625,1 0.53125,0 1.296875,-0.203125 1.734375,-1.15625 0.3125,-0.6875 0.359375,-1.46875 0.359375,-2.25 z M 2.484375,0 C 2.09375,0 1.5,-0.25 1.328125,-1.203125 1.21875,-1.796875 1.21875,-2.71875 1.21875,-3.3125 c 0,-0.640625 0,-1.296875 0.078125,-1.828125 0.1875,-1.1875 0.9375,-1.28125 1.1875,-1.28125 0.328125,0 0.984375,0.1875 1.171875,1.171875 0.109375,0.5625 0.109375,1.3125 0.109375,1.9375 0,0.75 0,1.421875 -0.109375,2.0625 C 3.5,-0.296875 2.9375,0 2.484375,0 z"
+               id="path22245" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-df25895d-2">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g22248">
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-df25895d-1"
+             x="223.43201"
+             y="134.765"
+             id="use22250" />
+        </g>
+      </g>
+    </g>
+    <g
+       id="g23265"
+       style="display:inline"
+       transform="matrix(1.7910448,0,0,1.7910448,-39.722973,182.93326)"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       ns0:text="$1$">
+      <defs
+         id="defs23267">
+        <g
+           id="g23269">
+          <symbol
+             id="textext-c16aad89-0"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path23272"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-c16aad89-1"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path23275"
+               d="m 2.9375,-6.375 c 0,-0.25 0,-0.265625 -0.234375,-0.265625 C 2.078125,-6 1.203125,-6 0.890625,-6 l 0,0.3125 c 0.203125,0 0.78125,0 1.296875,-0.265625 l 0,5.171875 c 0,0.359375 -0.03125,0.46875 -0.921875,0.46875 l -0.3125,0 0,0.3125 c 0.34375,-0.03125 1.203125,-0.03125 1.609375,-0.03125 0.390625,0 1.265625,0 1.609375,0.03125 l 0,-0.3125 -0.3125,0 c -0.90625,0 -0.921875,-0.109375 -0.921875,-0.46875 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-c16aad89-2">
+        <g
+           id="g23278"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use23280"
+             y="134.765"
+             x="223.43201"
+             xlink:href="#textext-c16aad89-1"
+             width="800"
+             height="600" />
+        </g>
+      </g>
+    </g>
+    <g
+       ns0:text="$2$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       transform="matrix(1.7910448,0,0,1.7910448,-9.0130194,182.93326)"
+       style="display:inline"
+       id="g24285">
+      <defs
+         id="defs24287">
+        <g
+           id="g24289">
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-97b990b5-0">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path24292" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-97b990b5-1">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 1.265625,-0.765625 1.0625,-1.03125 c 1.546875,-1.375 2.140625,-1.90625 2.140625,-2.90625 0,-1.140625 -0.890625,-1.9375 -2.109375,-1.9375 -1.125,0 -1.859375,0.921875 -1.859375,1.8125 0,0.546875 0.5,0.546875 0.53125,0.546875 0.171875,0 0.515625,-0.109375 0.515625,-0.53125 0,-0.25 -0.1875,-0.515625 -0.53125,-0.515625 -0.078125,0 -0.09375,0 -0.125,0.015625 0.21875,-0.65625 0.765625,-1.015625 1.34375,-1.015625 0.90625,0 1.328125,0.8125 1.328125,1.625 C 3.5625,-3.90625 3.078125,-3.125 2.515625,-2.5 l -1.90625,2.125 C 0.5,-0.265625 0.5,-0.234375 0.5,0 l 3.703125,0 0.265625,-1.734375 -0.234375,0 C 4.171875,-1.4375 4.109375,-1 4,-0.84375 3.9375,-0.765625 3.28125,-0.765625 3.0625,-0.765625 z"
+               id="path24295" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-97b990b5-2">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g24298">
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-97b990b5-1"
+             x="223.43201"
+             y="134.765"
+             id="use24300" />
+        </g>
+      </g>
+    </g>
+    <g
+       transform="matrix(1.7910448,0,0,1.7910448,-93.836934,209.53037)"
+       ns0:text="$0$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       id="g22235-7"
+       style="display:inline">
+      <defs
+         id="defs22237-6">
+        <g
+           id="g22239-2">
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-df25895d-0-3">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path22242-8" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-df25895d-1-1">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 4.578125,-3.1875 c 0,-0.796875 -0.046875,-1.59375 -0.390625,-2.328125 -0.453125,-0.96875 -1.28125,-1.125 -1.6875,-1.125 -0.609375,0 -1.328125,0.265625 -1.75,1.1875 -0.3125,0.6875 -0.359375,1.46875 -0.359375,2.265625 0,0.75 0.03125,1.640625 0.453125,2.40625 0.421875,0.796875 1.15625,1 1.640625,1 0.53125,0 1.296875,-0.203125 1.734375,-1.15625 0.3125,-0.6875 0.359375,-1.46875 0.359375,-2.25 z M 2.484375,0 C 2.09375,0 1.5,-0.25 1.328125,-1.203125 1.21875,-1.796875 1.21875,-2.71875 1.21875,-3.3125 c 0,-0.640625 0,-1.296875 0.078125,-1.828125 0.1875,-1.1875 0.9375,-1.28125 1.1875,-1.28125 0.328125,0 0.984375,0.1875 1.171875,1.171875 0.109375,0.5625 0.109375,1.3125 0.109375,1.9375 0,0.75 0,1.421875 -0.109375,2.0625 C 3.5,-0.296875 2.9375,0 2.484375,0 z"
+               id="path22245-4" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-df25895d-2-2">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g22248-1">
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-df25895d-1-1"
+             x="223.43201"
+             y="134.765"
+             id="use22250-9" />
+        </g>
+      </g>
+    </g>
+    <g
+       id="g23265-6"
+       style="display:inline"
+       transform="matrix(1.7910448,0,0,1.7910448,-93.920889,239.45479)"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       ns0:text="$1$">
+      <defs
+         id="defs23267-2">
+        <g
+           id="g23269-2">
+          <symbol
+             id="textext-c16aad89-0-2"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path23272-5"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-c16aad89-1-2"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path23275-0"
+               d="m 2.9375,-6.375 c 0,-0.25 0,-0.265625 -0.234375,-0.265625 C 2.078125,-6 1.203125,-6 0.890625,-6 l 0,0.3125 c 0.203125,0 0.78125,0 1.296875,-0.265625 l 0,5.171875 c 0,0.359375 -0.03125,0.46875 -0.921875,0.46875 l -0.3125,0 0,0.3125 c 0.34375,-0.03125 1.203125,-0.03125 1.609375,-0.03125 0.390625,0 1.265625,0 1.609375,0.03125 l 0,-0.3125 -0.3125,0 c -0.90625,0 -0.921875,-0.109375 -0.921875,-0.46875 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-c16aad89-2-8">
+        <g
+           id="g23278-5"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use23280-9"
+             y="134.765"
+             x="223.43201"
+             xlink:href="#textext-c16aad89-1-2"
+             width="800"
+             height="600" />
+        </g>
+      </g>
+    </g>
+    <g
+       ns0:text="$2$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       transform="matrix(1.7910448,0,0,1.7910448,-93.836934,269.97338)"
+       style="display:inline"
+       id="g24285-0">
+      <defs
+         id="defs24287-4">
+        <g
+           id="g24289-5">
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-97b990b5-0-2">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path24292-7" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-97b990b5-1-5">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 1.265625,-0.765625 1.0625,-1.03125 c 1.546875,-1.375 2.140625,-1.90625 2.140625,-2.90625 0,-1.140625 -0.890625,-1.9375 -2.109375,-1.9375 -1.125,0 -1.859375,0.921875 -1.859375,1.8125 0,0.546875 0.5,0.546875 0.53125,0.546875 0.171875,0 0.515625,-0.109375 0.515625,-0.53125 0,-0.25 -0.1875,-0.515625 -0.53125,-0.515625 -0.078125,0 -0.09375,0 -0.125,0.015625 0.21875,-0.65625 0.765625,-1.015625 1.34375,-1.015625 0.90625,0 1.328125,0.8125 1.328125,1.625 C 3.5625,-3.90625 3.078125,-3.125 2.515625,-2.5 l -1.90625,2.125 C 0.5,-0.265625 0.5,-0.234375 0.5,0 l 3.703125,0 0.265625,-1.734375 -0.234375,0 C 4.171875,-1.4375 4.109375,-1 4,-0.84375 3.9375,-0.765625 3.28125,-0.765625 3.0625,-0.765625 z"
+               id="path24295-4" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-97b990b5-2-2">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g24298-8">
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-97b990b5-1-5"
+             x="223.43201"
+             y="134.765"
+             id="use24300-7" />
+        </g>
+      </g>
+    </g>
+    <g
+       id="g26694"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       ns0:text="$A_{\\iota_K(i)} \\stackrel{+}{=} A^K_i$"
+       transform="matrix(1.8616997,0,0,1.8616997,-121.85962,328.33845)">
+      <defs
+         id="defs26696">
+        <g
+           id="g26698">
+          <symbol
+             id="textext-f6ab3895-0"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26701"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-1"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26704"
+               d="M 1.78125,-1.140625 C 1.390625,-0.484375 1,-0.34375 0.5625,-0.3125 0.4375,-0.296875 0.34375,-0.296875 0.34375,-0.109375 0.34375,-0.046875 0.40625,0 0.484375,0 0.75,0 1.0625,-0.03125 1.328125,-0.03125 c 0.34375,0 0.6875,0.03125 1,0.03125 0.0625,0 0.1875,0 0.1875,-0.1875 0,-0.109375 -0.078125,-0.125 -0.15625,-0.125 -0.21875,-0.015625 -0.46875,-0.09375 -0.46875,-0.34375 0,-0.125 0.0625,-0.234375 0.140625,-0.375 l 0.765625,-1.265625 2.5,0 c 0.015625,0.203125 0.15625,1.5625 0.15625,1.65625 0,0.296875 -0.515625,0.328125 -0.71875,0.328125 C 4.59375,-0.3125 4.5,-0.3125 4.5,-0.109375 4.5,0 4.609375,0 4.640625,0 5.046875,0 5.46875,-0.03125 5.875,-0.03125 6.125,-0.03125 6.765625,0 7.015625,0 7.0625,0 7.1875,0 7.1875,-0.203125 7.1875,-0.3125 7.09375,-0.3125 6.953125,-0.3125 6.34375,-0.3125 6.34375,-0.375 6.3125,-0.671875 l -0.609375,-6.21875 c -0.015625,-0.203125 -0.015625,-0.25 -0.1875,-0.25 -0.15625,0 -0.203125,0.078125 -0.265625,0.171875 z M 2.984375,-2.609375 4.9375,-5.90625 5.265625,-2.609375 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-2"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26707"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-3"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26710"
+               d="m 0.8125,-1.453125 c -0.078125,0.234375 -0.296875,0.734375 -0.296875,0.9375 0,0.265625 0.21875,0.578125 0.6875,0.578125 0.3125,0 0.671875,-0.125 0.953125,-0.34375 C 2.546875,-0.609375 2.609375,-0.984375 2.609375,-1 c 0,-0.09375 -0.09375,-0.09375 -0.109375,-0.09375 -0.09375,0 -0.109375,0.03125 -0.140625,0.140625 -0.171875,0.5 -0.71875,0.828125 -1.140625,0.828125 -0.109375,0 -0.1875,-0.015625 -0.1875,-0.25 0,-0.046875 0,-0.140625 0.078125,-0.359375 0.375,-1 0.625,-2.09375 0.625,-2.109375 0,-0.125 -0.09375,-0.234375 -0.234375,-0.234375 -0.140625,0 -0.25,0.109375 -0.296875,0.1875 -0.046875,0.125 -0.109375,0.46875 -0.15625,0.59375 C 1.015625,-2.1875 0.9375,-1.875 0.90625,-1.765625 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-4"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26713"
+               d="m 2.265625,-4.359375 c 0,-0.109375 -0.09375,-0.265625 -0.28125,-0.265625 -0.1875,0 -0.390625,0.1875 -0.390625,0.390625 0,0.109375 0.078125,0.265625 0.28125,0.265625 0.1875,0 0.390625,-0.203125 0.390625,-0.390625 z M 0.84375,-0.8125 c -0.03125,0.09375 -0.0625,0.171875 -0.0625,0.296875 0,0.328125 0.265625,0.578125 0.65625,0.578125 0.6875,0 1,-0.953125 1,-1.0625 0,-0.09375 -0.09375,-0.09375 -0.109375,-0.09375 -0.09375,0 -0.109375,0.046875 -0.140625,0.125 -0.15625,0.5625 -0.453125,0.84375 -0.734375,0.84375 -0.140625,0 -0.171875,-0.09375 -0.171875,-0.25 0,-0.15625 0.046875,-0.28125 0.109375,-0.4375 C 1.46875,-1 1.546875,-1.1875 1.609375,-1.375 1.671875,-1.546875 1.9375,-2.171875 1.953125,-2.265625 1.984375,-2.328125 2,-2.40625 2,-2.484375 2,-2.8125 1.71875,-3.078125 1.34375,-3.078125 0.640625,-3.078125 0.328125,-2.125 0.328125,-2 c 0,0.078125 0.09375,0.078125 0.125,0.078125 0.09375,0 0.09375,-0.03125 0.125,-0.109375 C 0.75,-2.625 1.0625,-2.875 1.3125,-2.875 c 0.109375,0 0.171875,0.046875 0.171875,0.234375 0,0.171875 -0.03125,0.265625 -0.203125,0.703125 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-5"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26716"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-6"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26719"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-7"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26722"
+               d="M 3.328125,-2 C 3.3125,-2.03125 3.296875,-2.046875 3.296875,-2.0625 c 0,0 0.125,-0.078125 0.1875,-0.125 C 4.328125,-2.71875 4.625,-2.921875 4.84375,-3.03125 5,-3.09375 5.203125,-3.171875 5.40625,-3.1875 c 0.0625,0 0.140625,0 0.140625,-0.125 0,-0.078125 -0.046875,-0.09375 -0.0625,-0.09375 -0.171875,0.015625 -0.328125,0.015625 -0.4375,0.015625 l -0.3125,0 c -0.109375,0 -0.21875,-0.015625 -0.3125,-0.015625 -0.09375,0 -0.125,0.0625 -0.125,0.140625 0,0 0,0.078125 0.09375,0.078125 C 4.5,-3.171875 4.5,-3.140625 4.5,-3.125 4.5,-3.078125 4.453125,-3.046875 4.40625,-3 c -0.0625,0.046875 -0.0625,0.046875 -0.125,0.078125 L 2,-1.453125 2.375,-2.984375 C 2.421875,-3.140625 2.421875,-3.1875 2.8125,-3.1875 c 0.125,0 0.140625,0 0.15625,0 C 3,-3.21875 3.015625,-3.28125 3.015625,-3.3125 3.015625,-3.328125 3,-3.40625 2.921875,-3.40625 c -0.109375,0 -0.21875,0.015625 -0.328125,0.015625 -0.125,0 -0.25,0 -0.375,0 -0.125,0 -0.234375,0 -0.359375,0 -0.125,0 -0.25,-0.015625 -0.359375,-0.015625 -0.03125,0 -0.125,0 -0.125,0.140625 0,0.078125 0.0625,0.078125 0.1875,0.078125 0.046875,0 0.21875,0 0.328125,0.03125 0,0.0625 0,0.078125 -0.015625,0.125 l -0.65625,2.625 c -0.046875,0.140625 -0.046875,0.1875 -0.4375,0.1875 -0.125,0 -0.203125,0 -0.203125,0.140625 C 0.578125,-0.046875 0.625,0 0.671875,0 0.78125,0 0.890625,-0.015625 1,-0.015625 c 0.125,0 0.25,0 0.375,0 0.125,0 0.25,0 0.375,0 C 1.859375,-0.015625 1.984375,0 2.09375,0 c 0.03125,0 0.125,0 0.125,-0.140625 0,-0.078125 -0.078125,-0.078125 -0.171875,-0.078125 0,0 -0.125,0 -0.203125,-0.015625 C 1.71875,-0.25 1.703125,-0.25 1.703125,-0.296875 c 0,-0.015625 0.0625,-0.234375 0.09375,-0.359375 0,-0.046875 0.125,-0.5 0.125,-0.515625 C 1.9375,-1.1875 1.9375,-1.203125 2,-1.234375 L 2.796875,-1.75 c 0,0 0.046875,-0.03125 0.046875,-0.03125 0.015625,0 0.015625,0 0.0625,0.078125 l 0.796875,1.28125 C 3.75,-0.34375 3.75,-0.34375 3.75,-0.3125 c 0,0.09375 -0.1875,0.09375 -0.21875,0.09375 -0.0625,0 -0.140625,0 -0.140625,0.140625 C 3.390625,-0.046875 3.421875,0 3.46875,0 3.578125,0 3.703125,-0.015625 3.8125,-0.015625 c 0.109375,0 0.21875,0 0.34375,0 0.09375,0 0.1875,0 0.28125,0 C 4.5,-0.015625 4.703125,0 4.71875,0 4.796875,0 4.828125,-0.0625 4.828125,-0.140625 4.828125,-0.21875 4.75,-0.21875 4.6875,-0.21875 4.5,-0.21875 4.40625,-0.265625 4.328125,-0.390625 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-8"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26725"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-9"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26728"
+               d="M 2.46875,-5.21875 C 1.15625,-4.296875 0.796875,-2.8125 0.796875,-1.75 c 0,0.984375 0.296875,2.515625 1.671875,3.484375 0.0625,0 0.140625,0 0.140625,-0.078125 0,-0.046875 -0.015625,-0.0625 -0.0625,-0.109375 C 1.609375,0.703125 1.28125,-0.46875 1.28125,-1.734375 1.28125,-3.625 2,-4.546875 2.5625,-5.0625 2.59375,-5.09375 2.609375,-5.109375 2.609375,-5.140625 2.609375,-5.21875 2.53125,-5.21875 2.46875,-5.21875 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-10"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26731"
+               d="m 0.625,-5.21875 c -0.046875,0 -0.125,0 -0.125,0.078125 0,0.03125 0.015625,0.046875 0.0625,0.109375 0.59375,0.546875 1.265625,1.484375 1.265625,3.28125 0,1.453125 -0.453125,2.5625 -1.203125,3.234375 -0.125,0.125 -0.125,0.125 -0.125,0.171875 0,0.03125 0.015625,0.078125 0.078125,0.078125 0.09375,0 0.75,-0.453125 1.21875,-1.328125 0.296875,-0.578125 0.5,-1.328125 0.5,-2.140625 C 2.296875,-2.71875 2,-4.25 0.625,-5.21875 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-11"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26734"
+               d="m 3.21875,-1.578125 2.140625,0 c 0.09375,0 0.25,0 0.25,-0.15625 0,-0.1875 -0.15625,-0.1875 -0.25,-0.1875 l -2.140625,0 0,-2.140625 c 0,-0.078125 0,-0.25 -0.15625,-0.25 -0.171875,0 -0.171875,0.15625 -0.171875,0.25 l 0,2.140625 -2.140625,0 c -0.09375,0 -0.265625,0 -0.265625,0.171875 0,0.171875 0.15625,0.171875 0.265625,0.171875 l 2.140625,0 0,2.140625 c 0,0.09375 0,0.265625 0.15625,0.265625 0.171875,0 0.171875,-0.171875 0.171875,-0.265625 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-12"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26737"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-13"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26740"
+               d="m 6.84375,-3.265625 c 0.15625,0 0.34375,0 0.34375,-0.1875 C 7.1875,-3.65625 7,-3.65625 6.859375,-3.65625 l -5.96875,0 c -0.140625,0 -0.328125,0 -0.328125,0.203125 0,0.1875 0.1875,0.1875 0.328125,0.1875 z m 0.015625,1.9375 c 0.140625,0 0.328125,0 0.328125,-0.203125 0,-0.1875 -0.1875,-0.1875 -0.34375,-0.1875 l -5.953125,0 c -0.140625,0 -0.328125,0 -0.328125,0.1875 0,0.203125 0.1875,0.203125 0.328125,0.203125 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-f6ab3895-14">
+        <g
+           id="g26743"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26745"
+             y="135.763"
+             x="223.43201"
+             xlink:href="#textext-f6ab3895-1"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26747"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26749"
+             y="137.562"
+             x="230.90401"
+             xlink:href="#textext-f6ab3895-3"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26751"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26753"
+             y="138.564"
+             x="233.853"
+             xlink:href="#textext-f6ab3895-7"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26755"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26757"
+             y="137.562"
+             x="240.36301"
+             xlink:href="#textext-f6ab3895-9"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26759"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26761"
+             y="137.562"
+             x="243.476"
+             xlink:href="#textext-f6ab3895-4"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26763"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26765"
+             y="137.562"
+             x="246.295"
+             xlink:href="#textext-f6ab3895-10"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26767"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26769"
+             y="130.11501"
+             x="253.49001"
+             xlink:href="#textext-f6ab3895-11"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26771"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26773"
+             y="135.763"
+             x="252.674"
+             xlink:href="#textext-f6ab3895-13"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26775"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26777"
+             y="135.763"
+             x="263.19"
+             xlink:href="#textext-f6ab3895-1"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26779"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26781"
+             y="132.14799"
+             x="270.66199"
+             xlink:href="#textext-f6ab3895-5"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26783"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26785"
+             y="138.356"
+             x="270.66199"
+             xlink:href="#textext-f6ab3895-4"
+             width="800"
+             height="600" />
+        </g>
+      </g>
+    </g>
+  </g>
+</svg>
diff --git a/_images/csr.svg b/_images/csr.svg
new file mode 100644
index 000000000..b9e736a71
--- /dev/null
+++ b/_images/csr.svg
@@ -0,0 +1,1770 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="600"
+   height="180"
+   id="svg91417"
+   version="1.1"
+   inkscape:version="0.48.4 r9939"
+   sodipodi:docname="csr.svg">
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="2.4825019"
+     inkscape:cx="260.83264"
+     inkscape:cy="126.1378"
+     inkscape:current-layer="layer4"
+     inkscape:document-units="px"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     inkscape:window-width="1920"
+     inkscape:window-height="1043"
+     inkscape:window-x="0"
+     inkscape:window-y="1098"
+     inkscape:window-maximized="0"
+     inkscape:snap-global="false">
+    <inkscape:grid
+       snapvisiblegridlinesonly="true"
+       enabled="true"
+       visible="true"
+       empspacing="5"
+       type="xygrid"
+       id="grid91425" />
+  </sodipodi:namedview>
+  <defs
+     id="defs91419">
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow1Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow1Mend"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12664"
+         d="M 0,0 5,-5 -12.5,0 5,5 0,0 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt"
+         transform="matrix(-0.4,0,0,-0.4,-4,0)" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="DotM"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path21623" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91297"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91299" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91301"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91303" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91305"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91307" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91309"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91311" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91313"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91315" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker6626"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path6628" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91319"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91321" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91323"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91325" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91327"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91329" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91331"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91333" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91335"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91337" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91339"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91341" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91343"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91345" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91347"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91349" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91351"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91353" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91355"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91357" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91359"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91361" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="DotM-8"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path21623-3" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker11181"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path11183" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-3"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-2"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-1"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-5"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-4"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-3"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-6"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-50"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-9"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-6"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-42"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-64"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-92"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-55"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-17"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-0"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-7"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-1"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-90"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-51"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-95"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-4"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-68"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+  </defs>
+  <metadata
+     id="metadata91422">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title></dc:title>
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     transform="translate(0,-420)"
+     id="layer1"
+     inkscape:label="mat"
+     inkscape:groupmode="layer"
+     style="display:inline">
+    <rect
+       style="fill:#fce94f;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10847"
+       width="30"
+       height="30"
+       x="5"
+       y="445" />
+    <rect
+       style="fill:#fce94f;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10849"
+       width="30"
+       height="30"
+       x="35"
+       y="445" />
+    <rect
+       style="fill:#fce94f;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10851"
+       width="30"
+       height="30"
+       x="65"
+       y="445" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10853"
+       width="30"
+       height="30"
+       x="5"
+       y="475" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10855"
+       width="30"
+       height="30"
+       x="65"
+       y="475" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10857"
+       width="30"
+       height="30"
+       x="35"
+       y="475" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10859"
+       width="30"
+       height="30"
+       x="5"
+       y="535" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10861"
+       width="30"
+       height="30"
+       x="5"
+       y="505" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10863"
+       width="30"
+       height="30"
+       x="65"
+       y="535" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10865"
+       width="30"
+       height="30"
+       x="65"
+       y="505" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10869"
+       width="30"
+       height="30"
+       x="35"
+       y="535" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10871"
+       width="30"
+       height="30"
+       x="35"
+       y="505" />
+    <rect
+       style="fill:#fce94f;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10928"
+       width="30"
+       height="30"
+       x="125"
+       y="445" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10930"
+       width="30"
+       height="30"
+       x="125"
+       y="475" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10932"
+       width="30"
+       height="30"
+       x="125"
+       y="505" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10934"
+       width="30"
+       height="30"
+       x="125"
+       y="535" />
+    <rect
+       style="fill:#fce94f;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11079"
+       width="30"
+       height="30"
+       x="95"
+       y="445" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11081"
+       width="30"
+       height="30"
+       x="95"
+       y="475" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11083"
+       width="30"
+       height="30"
+       x="95"
+       y="505" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11085"
+       width="30"
+       height="30"
+       x="95"
+       y="535" />
+    <rect
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11099"
+       width="30"
+       height="30"
+       x="125"
+       y="565" />
+    <rect
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11101"
+       width="30"
+       height="30"
+       x="65"
+       y="565" />
+    <rect
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11103"
+       width="30"
+       height="30"
+       x="35"
+       y="565" />
+    <rect
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11105"
+       width="30"
+       height="30"
+       x="5"
+       y="565" />
+    <rect
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11118"
+       width="30"
+       height="30"
+       x="95"
+       y="565" />
+  </g>
+  <g
+     inkscape:label="mat values"
+     id="layer4"
+     inkscape:groupmode="layer"
+     style="display:inline"
+     transform="translate(0,-300)">
+    <text
+       xml:space="preserve"
+       style="font-size:144px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Californian FB;-inkscape-font-specification:Californian FB"
+       x="405.60696"
+       y="141.67172"
+       id="text29583"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29585"
+         x="141.67172"
+         y="405.60696" /></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="44.924"
+       y="346.246"
+       id="text3838"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840"
+         x="44.924"
+         y="346.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="74.924004"
+       y="346.246"
+       id="text3838-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-1"
+         x="74.924004"
+         y="346.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="104.924"
+       y="346.246"
+       id="text3838-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-0"
+         x="104.924"
+         y="346.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="134.924"
+       y="376.246"
+       id="text3838-96"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-5"
+         x="134.924"
+         y="376.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="134.924"
+       y="406.246"
+       id="text3838-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-8"
+         x="134.924"
+         y="406.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="104.924"
+       y="376.246"
+       id="text3838-12"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-2"
+         x="104.924"
+         y="376.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="74.924004"
+       y="466.246"
+       id="text3838-23"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-26"
+         x="74.924004"
+         y="466.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="14.924"
+       y="466.246"
+       id="text3838-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-4"
+         x="14.924"
+         y="466.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="14.924"
+       y="406.246"
+       id="text3838-32"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-40"
+         x="14.924"
+         y="406.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="44.924"
+       y="436.246"
+       id="text3838-35"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-92"
+         x="44.924"
+         y="436.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="9.4569216"
+       y="346.246"
+       id="text3838-26"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-62"
+         x="9.4569216"
+         y="346.246"
+         style="font-size:18px">10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="15.104"
+       y="376.246"
+       id="text3838-98"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52"
+         x="15.104"
+         y="376.246"
+         style="font-size:18px">3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="15.104"
+       y="436.246"
+       id="text3838-98-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-6"
+         x="15.104"
+         y="436.246"
+         style="font-size:18px">3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="44.924"
+       y="466.246"
+       id="text3838-98-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-68"
+         x="44.924"
+         y="466.246"
+         style="font-size:18px">8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="45.032001"
+       y="376.36301"
+       id="text3838-98-34"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-2"
+         x="45.032001"
+         y="376.36301"
+         style="font-size:18px">9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="44.951"
+       y="406.237"
+       id="text3838-98-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-8"
+         x="44.951"
+         y="406.237"
+         style="font-size:18px">7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="74.924004"
+       y="406.246"
+       id="text3838-98-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-25"
+         x="74.924004"
+         y="406.246"
+         style="font-size:18px">8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="104.951"
+       y="406.237"
+       id="text3838-98-77"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-82"
+         x="104.951"
+         y="406.237"
+         style="font-size:18px">7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="74.924004"
+       y="376.246"
+       id="text3838-98-31"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-5"
+         x="74.924004"
+         y="376.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="132.66655"
+       y="346.38101"
+       id="text3838-98-82"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-7"
+         x="132.66655"
+         y="346.38101"
+         style="font-size:18px">-2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="74.924004"
+       y="436.246"
+       id="text3838-98-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-0"
+         x="74.924004"
+         y="436.246"
+         style="font-size:18px">8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="104.951"
+       y="436.237"
+       id="text3838-98-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-59"
+         x="104.951"
+         y="436.237"
+         style="font-size:18px">7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="134.996"
+       y="436.10199"
+       id="text3838-98-62"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-1"
+         x="134.996"
+         y="436.10199"
+         style="font-size:18px">5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="105.032"
+       y="466.36301"
+       id="text3838-98-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-09"
+         x="105.032"
+         y="466.36301"
+         style="font-size:18px">9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="129.68192"
+       y="466.246"
+       id="text3838-98-78"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-21"
+         x="129.68192"
+         y="466.246"
+         style="font-size:18px">13</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="8.0563879"
+       y="315.01019"
+       id="text4691"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4693"
+         x="8.0563879"
+         y="315.01019"
+         style="font-weight:500;writing-mode:lr-tb;-inkscape-font-specification:Ubuntu Medium">Sparse Matrix</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer2"
+     inkscape:label="val"
+     transform="translate(0,-300)">
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11099-2"
+       width="30"
+       height="30"
+       x="295"
+       y="445" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11101-9"
+       width="30"
+       height="30"
+       x="235"
+       y="445" />
+    <rect
+       style="fill:#fce94f;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11103-0"
+       width="30"
+       height="30"
+       x="205"
+       y="445" />
+    <rect
+       style="fill:#fce94f;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11105-3"
+       width="30"
+       height="30"
+       x="175"
+       y="445" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11118-2"
+       width="30"
+       height="30"
+       x="265"
+       y="445" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11099-5"
+       width="30"
+       height="30"
+       x="445"
+       y="445" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11101-2"
+       width="30"
+       height="30"
+       x="385"
+       y="445" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11103-1"
+       width="30"
+       height="30"
+       x="355"
+       y="445" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11105-6"
+       width="30"
+       height="30"
+       x="325"
+       y="445" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11118-6"
+       width="30"
+       height="30"
+       x="415"
+       y="445" />
+    <rect
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11101-91"
+       width="30"
+       height="30"
+       x="535"
+       y="445" />
+    <rect
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11103-2"
+       width="30"
+       height="30"
+       x="505"
+       y="445" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11105-1"
+       width="30"
+       height="30"
+       x="475"
+       y="445" />
+    <rect
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11118-0"
+       width="30"
+       height="30"
+       x="565"
+       y="445" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer3"
+     inkscape:label="val numbers"
+     style="display:inline"
+     transform="translate(0,-300)">
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="179.45692"
+       y="466.246"
+       id="text3838-26-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-62-1"
+         x="179.45692"
+         y="466.246"
+         style="font-size:18px">10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="212.66655"
+       y="466.38101"
+       id="text3838-98-82-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-7-2"
+         x="212.66655"
+         y="466.38101"
+         style="font-size:18px">-2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="245.10399"
+       y="466.246"
+       id="text3838-98-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-4"
+         x="245.10399"
+         y="466.246"
+         style="font-size:18px">3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="275.03201"
+       y="466.36301"
+       id="text3838-98-34-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-2-3"
+         x="275.03201"
+         y="466.36301"
+         style="font-size:18px">9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="304.95099"
+       y="466.237"
+       id="text3838-98-7-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-8-6"
+         x="304.95099"
+         y="466.237"
+         style="font-size:18px">7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="334.92401"
+       y="466.246"
+       id="text3838-98-8-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-25-2"
+         x="334.92401"
+         y="466.246"
+         style="font-size:18px">8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="364.95099"
+       y="466.237"
+       id="text3838-98-77-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-82-7"
+         x="364.95099"
+         y="466.237"
+         style="font-size:18px">7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="395.104"
+       y="466.246"
+       id="text3838-98-3-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-6-9"
+         x="395.104"
+         y="466.246"
+         style="font-size:18px">3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="424.92401"
+       y="466.246"
+       id="text3838-98-2-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-0-6"
+         x="424.92401"
+         y="466.246"
+         style="font-size:18px">8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="454.95099"
+       y="466.237"
+       id="text3838-98-5-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-59-0"
+         x="454.95099"
+         y="466.237"
+         style="font-size:18px">7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="484.996"
+       y="466.10199"
+       id="text3838-98-62-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-1-6"
+         x="484.996"
+         y="466.10199"
+         style="font-size:18px">5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="514.92401"
+       y="466.246"
+       id="text3838-98-6-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-68-1"
+         x="514.92401"
+         y="466.246"
+         style="font-size:18px">8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="545.03198"
+       y="466.36301"
+       id="text3838-98-9-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-09-7"
+         x="545.03198"
+         y="466.36301"
+         style="font-size:18px">9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="569.68195"
+       y="466.246"
+       id="text3838-98-78-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-21-6"
+         x="569.68195"
+         y="466.246"
+         style="font-size:18px">13</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="180.045"
+       y="435.62366"
+       id="text4691-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4693-8"
+         x="180.045"
+         y="435.62366"
+         style="font-weight:500;writing-mode:lr-tb;-inkscape-font-specification:Ubuntu Medium">Values array</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer5"
+     inkscape:label="colidx"
+     transform="translate(0,-300)">
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11099-2-2"
+       width="30"
+       height="30"
+       x="295"
+       y="385" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11101-9-3"
+       width="30"
+       height="30"
+       x="235"
+       y="385" />
+    <rect
+       style="fill:#fce94f;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11103-0-9"
+       width="30"
+       height="30"
+       x="205"
+       y="385" />
+    <rect
+       style="fill:#fce94f;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11105-3-9"
+       width="30"
+       height="30"
+       x="175"
+       y="385" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11118-2-4"
+       width="30"
+       height="30"
+       x="265"
+       y="385" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11099-5-9"
+       width="30"
+       height="30"
+       x="445"
+       y="385" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11101-2-3"
+       width="30"
+       height="30"
+       x="385"
+       y="385" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11103-1-6"
+       width="30"
+       height="30"
+       x="355"
+       y="385" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11105-6-3"
+       width="30"
+       height="30"
+       x="325"
+       y="385" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11118-6-9"
+       width="30"
+       height="30"
+       x="415"
+       y="385" />
+    <rect
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11101-91-9"
+       width="30"
+       height="30"
+       x="535"
+       y="385" />
+    <rect
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11103-2-0"
+       width="30"
+       height="30"
+       x="505"
+       y="385" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11105-1-7"
+       width="30"
+       height="30"
+       x="475"
+       y="385" />
+    <rect
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11118-0-4"
+       width="30"
+       height="30"
+       x="565"
+       y="385" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer7"
+     inkscape:label="colidx numbers"
+     transform="translate(0,-300)">
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="184.924"
+       y="406.246"
+       id="text3838-26-7-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-62-1-0"
+         x="184.924"
+         y="406.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="214.942"
+       y="406.237"
+       id="text3838-98-82-8-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-7-2-1"
+         x="214.942"
+         y="406.237"
+         style="font-size:18px">4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="244.92401"
+       y="406.246"
+       id="text3838-98-0-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-4-8"
+         x="244.92401"
+         y="406.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="275.84201"
+       y="406.237"
+       id="text3838-98-34-6-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-2-3-0"
+         x="275.84201"
+         y="406.237"
+         style="font-size:18px">1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="305.84201"
+       y="406.237"
+       id="text3838-98-7-5-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-8-6-4"
+         x="305.84201"
+         y="406.237"
+         style="font-size:18px">1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="335.086"
+       y="406.38101"
+       id="text3838-98-8-2-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-25-2-4"
+         x="335.086"
+         y="406.38101"
+         style="font-size:18px">2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="365.104"
+       y="406.246"
+       id="text3838-98-77-6-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-82-7-5"
+         x="365.104"
+         y="406.246"
+         style="font-size:18px">3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="394.92401"
+       y="406.246"
+       id="text3838-98-3-6-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-6-9-0"
+         x="394.92401"
+         y="406.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="425.086"
+       y="406.38101"
+       id="text3838-98-2-8-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-0-6-6"
+         x="425.086"
+         y="406.38101"
+         style="font-size:18px">2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="455.104"
+       y="406.246"
+       id="text3838-98-5-4-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-59-0-0"
+         x="455.104"
+         y="406.246"
+         style="font-size:18px">3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="484.94199"
+       y="406.237"
+       id="text3838-98-62-3-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-1-6-4"
+         x="484.94199"
+         y="406.237"
+         style="font-size:18px">4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="515.84198"
+       y="406.237"
+       id="text3838-98-6-3-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-68-1-1"
+         x="515.84198"
+         y="406.237"
+         style="font-size:18px">1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="545.104"
+       y="406.246"
+       id="text3838-98-9-5-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-09-7-3"
+         x="545.104"
+         y="406.246"
+         style="font-size:18px">3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="574.94202"
+       y="406.237"
+       id="text3838-98-78-0-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-21-6-4"
+         x="574.94202"
+         y="406.237"
+         style="font-size:18px">4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="179.64217"
+       y="375.60358"
+       id="text4691-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4693-6"
+         x="179.64217"
+         y="375.60358"
+         style="font-weight:500;writing-mode:lr-tb;-inkscape-font-specification:Ubuntu Medium">Column indices array</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer6"
+     inkscape:label="rowptr"
+     transform="translate(0,-300)">
+    <rect
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11099-2-23"
+       width="30"
+       height="30"
+       x="295"
+       y="325" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11101-9-1"
+       width="30"
+       height="30"
+       x="235"
+       y="325" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11103-0-0"
+       width="30"
+       height="30"
+       x="205"
+       y="325" />
+    <rect
+       style="fill:#fce94f;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11105-3-4"
+       width="30"
+       height="30"
+       x="175"
+       y="325" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11118-2-9"
+       width="30"
+       height="30"
+       x="265"
+       y="325" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11105-6-2"
+       width="30"
+       height="30"
+       x="325"
+       y="325" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer8"
+     inkscape:label="rowptr numbers"
+     transform="translate(0,-300)"
+     style="display:inline">
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="184.924"
+       y="346.246"
+       id="text3838-26-7-8-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-62-1-0-4"
+         x="184.924"
+         y="346.246"
+         style="font-size:18px">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="215.086"
+       y="346.38101"
+       id="text3838-98-82-8-9-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-7-2-1-6"
+         x="215.086"
+         y="346.38101"
+         style="font-size:18px">2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="244.942"
+       y="346.237"
+       id="text3838-98-0-1-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-4-8-8"
+         x="244.942"
+         y="346.237"
+         style="font-size:18px">4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="274.95099"
+       y="346.237"
+       id="text3838-98-34-6-6-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-2-3-0-0"
+         x="274.95099"
+         y="346.237"
+         style="font-size:18px">7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="300.76193"
+       y="346.237"
+       id="text3838-98-7-5-3-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-8-6-4-6"
+         x="300.76193"
+         y="346.237"
+         style="font-size:18px">11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="329.38492"
+       y="346.237"
+       id="text3838-98-8-2-5-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3840-52-25-2-4-3"
+         x="329.38492"
+         y="346.237"
+         style="font-size:18px">14</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="179.64218"
+       y="316.3891"
+       id="text4691-81"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4693-81"
+         x="179.64218"
+         y="316.3891"
+         style="font-weight:500;writing-mode:lr-tb;-inkscape-font-specification:Ubuntu Medium">Row pointer array</tspan></text>
+  </g>
+</svg>
diff --git a/_images/direct_arg.svg b/_images/direct_arg.svg
new file mode 100644
index 000000000..7817f3228
--- /dev/null
+++ b/_images/direct_arg.svg
@@ -0,0 +1,330 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="333.64215"
+   height="101.00002"
+   id="svg2"
+   version="1.1"
+   inkscape:version="0.48.4 r9939"
+   sodipodi:docname="direct_arg.svg">
+  <defs
+     id="defs4">
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend"
+       style="overflow:visible">
+      <path
+         id="path4040"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-2"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4040-7"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-8"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4040-6"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+  </defs>
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="2.8"
+     inkscape:cx="122.15817"
+     inkscape:cy="66.114143"
+     inkscape:document-units="px"
+     inkscape:current-layer="layer2"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     fit-margin-top="0"
+     fit-margin-left="0"
+     fit-margin-right="0"
+     fit-margin-bottom="0"
+     inkscape:window-width="958"
+     inkscape:window-height="1043"
+     inkscape:window-x="960"
+     inkscape:window-y="18"
+     inkscape:window-maximized="0"
+     inkscape:snap-global="false">
+    <inkscape:grid
+       type="xygrid"
+       id="grid2985"
+       empspacing="5"
+       visible="true"
+       enabled="true"
+       snapvisiblegridlinesonly="true"
+       originx="-27.214978px"
+       originy="-29.499986px" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="52.785022,0.50001449"
+       id="guide2987" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="-27.214978,30.500014"
+       id="guide2989" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="-27.214978,70.500014"
+       id="guide2991" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="-27.214978,100.50002"
+       id="guide2993" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="132.78502,360.50002"
+       id="guide3020" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="172.78502,370.50002"
+       id="guide3022" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="202.78502,310.50002"
+       id="guide3024" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="232.78502,340.50002"
+       id="guide3026" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="262.78502,320.50002"
+       id="guide3028" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="332.78502,460.50002"
+       id="guide3032" />
+  </sodipodi:namedview>
+  <metadata
+     id="metadata7">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:groupmode="layer"
+     id="layer2"
+     inkscape:label="boxes"
+     transform="translate(-27.214978,-921.86218)">
+    <rect
+       style="fill:#c8c8c8;fill-opacity:1;stroke:none"
+       id="rect7400-1"
+       width="200"
+       height="30.000004"
+       x="160"
+       y="992.00507" />
+    <rect
+       style="fill:#c8c8c8;fill-opacity:1;stroke:none"
+       id="rect7400"
+       width="200"
+       height="30.000004"
+       x="148.79883"
+       y="0.50000286"
+       transform="translate(11.201172,921.86218)" />
+    <rect
+       id="rect3035"
+       width="60"
+       height="30"
+       x="200"
+       y="922.36218"
+       style="fill:#4e9a06;fill-opacity:1;stroke:#000000;stroke-opacity:1" />
+    <rect
+       id="rect3035-1"
+       width="60"
+       height="30"
+       x="260.35715"
+       y="922.36218"
+       style="fill:#4e9a06;fill-opacity:1;stroke:#000000;stroke-opacity:1" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160,922.36218 200,0"
+       id="path3823"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160.35714,952.36218 200,0"
+       id="path3823-6"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160.35714,992.36218 200,0"
+       id="path3823-5"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160,1022.3622 200,0"
+       id="path3823-59"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:1, 1;stroke-dashoffset:0"
+       d="m 230,922.36218 0,30"
+       id="path3857"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:1, 1;stroke-dashoffset:0"
+       d="m 290,923.43361 0,30"
+       id="path3857-4"
+       inkscape:connector-curvature="0" />
+    <rect
+       style="fill:#204a87;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
+       id="rect3877"
+       width="30"
+       height="30"
+       x="230"
+       y="992.36218" />
+    <rect
+       style="fill:#204a87;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
+       id="rect3877-2"
+       width="30"
+       height="30"
+       x="260.35715"
+       y="992.36218" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 245,992.36218 -30,-40"
+       id="path4007"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 275,992.36218 0,-40"
+       id="path4007-1"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Bitstream Vera Sans"
+       x="94.64286"
+       y="969.14789"
+       id="text2995-3-9-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-9-9-0"
+         x="94.64286"
+         y="969.14789"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:300;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Light">(dim 2)</tspan></text>
+  </g>
+  <g
+     inkscape:label="labels"
+     inkscape:groupmode="layer"
+     id="layer1"
+     transform="translate(-27.214978,-921.86218)">
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="26.414978"
+       y="944.34186"
+       id="text2995"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997"
+         x="26.414978"
+         y="944.34186"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">argument Dat</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="38.484772"
+       y="1014.5843"
+       id="text2995-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-0"
+         x="38.484772"
+         y="1014.5843"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">iteration Set</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="244"
+       y="1012.3622"
+       id="text3940"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942"
+         x="244"
+         y="1012.3622"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">i</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="265"
+       y="1012.3622"
+       id="text3940-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-7"
+         x="265"
+         y="1012.3622"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">i+1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="209"
+       y="942.36218"
+       id="text3940-82"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-6"
+         x="209"
+         y="942.36218"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2i</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="261.96954"
+       y="942.36218"
+       id="text3940-82-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-6-3"
+         x="261.96954"
+         y="942.36218"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2i+1</tspan></text>
+  </g>
+</svg>
diff --git a/_images/indirect_arg.svg b/_images/indirect_arg.svg
new file mode 100644
index 000000000..ff737c2e9
--- /dev/null
+++ b/_images/indirect_arg.svg
@@ -0,0 +1,833 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:osb="http://www.openswatchbook.org/uri/2009/osb"
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="520.10565"
+   height="241.04617"
+   id="svg2"
+   version="1.1"
+   inkscape:version="0.48.4 r9939"
+   sodipodi:docname="indirect_arg.svg">
+  <defs
+     id="defs4">
+    <linearGradient
+       id="linearGradient7037">
+      <stop
+         style="stop-color:#ffffff;stop-opacity:1;"
+         offset="0"
+         id="stop7039" />
+      <stop
+         style="stop-color:#ffffff;stop-opacity:0;"
+         offset="1"
+         id="stop7041" />
+    </linearGradient>
+    <linearGradient
+       id="linearGradient7031"
+       osb:paint="solid">
+      <stop
+         style="stop-color:#a40000;stop-opacity:1;"
+         offset="0"
+         id="stop7033" />
+    </linearGradient>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend"
+       style="overflow:visible">
+      <path
+         id="path4040"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-2"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4040-7"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-8"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4040-6"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-1"
+       style="overflow:visible">
+      <path
+         id="path4040-3"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-9"
+       style="overflow:visible">
+      <path
+         id="path4040-1"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-4"
+       style="overflow:visible">
+      <path
+         id="path4040-8"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-3"
+       style="overflow:visible">
+      <path
+         id="path4040-63"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-22"
+       style="overflow:visible">
+      <path
+         id="path4040-60"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7"
+       style="overflow:visible">
+      <path
+         id="path4040-9"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7-7"
+       style="overflow:visible">
+      <path
+         id="path4040-9-2"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7-9"
+       style="overflow:visible">
+      <path
+         id="path4040-9-27"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7-2"
+       style="overflow:visible">
+      <path
+         id="path4040-9-24"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7-27"
+       style="overflow:visible">
+      <path
+         id="path4040-9-7"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7-1"
+       style="overflow:visible">
+      <path
+         id="path4040-9-6"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+  </defs>
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="3.4686902"
+     inkscape:cx="209.72006"
+     inkscape:cy="104.69658"
+     inkscape:document-units="px"
+     inkscape:current-layer="layer1"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     fit-margin-top="0"
+     fit-margin-left="0"
+     fit-margin-right="0"
+     fit-margin-bottom="0"
+     inkscape:window-width="1920"
+     inkscape:window-height="1043"
+     inkscape:window-x="0"
+     inkscape:window-y="1098"
+     inkscape:window-maximized="0"
+     inkscape:snap-global="true">
+    <inkscape:grid
+       type="xygrid"
+       id="grid2985"
+       empspacing="5"
+       visible="true"
+       enabled="true"
+       snapvisiblegridlinesonly="true"
+       originx="-20.848666px"
+       originy="-29.310951px" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="59.151334,0.68904931"
+       id="guide2987" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="-20.848666,30.689049"
+       id="guide2989" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="-20.848666,70.689049"
+       id="guide2991" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="-20.848666,100.68905"
+       id="guide2993" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="139.15134,360.68905"
+       id="guide3020" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="179.15134,370.68905"
+       id="guide3022" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="209.15134,310.68905"
+       id="guide3024" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="239.15134,340.68905"
+       id="guide3026" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="269.15134,320.68905"
+       id="guide3028" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="299.15134,360.68905"
+       id="guide3030" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="329.15134,215.68905"
+       id="guide3032" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="139.15134,140.68905"
+       id="guide4539" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="139.15134,170.68905"
+       id="guide4541" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="139.15134,210.68905"
+       id="guide4543" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="139.15134,240.68905"
+       id="guide4545" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="359.15134,210.68905"
+       id="guide4589" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="389.15134,210.68905"
+       id="guide4591" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="419.15134,240.68905"
+       id="guide4593" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="449.15134,280.68905"
+       id="guide4595" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="479.15134,270.68905"
+       id="guide4597" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="519.15134,250.68905"
+       id="guide4599" />
+  </sodipodi:namedview>
+  <metadata
+     id="metadata7">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:groupmode="layer"
+     id="layer2"
+     inkscape:label="boxes"
+     transform="translate(-20.848666,-782.00507)">
+    <rect
+       style="fill:#c8c8c8;fill-opacity:1;stroke:none"
+       id="rect5435-9"
+       width="380.35715"
+       height="29.999998"
+       x="160"
+       y="992.7193" />
+    <rect
+       style="fill:#c8c8c8;fill-opacity:1;stroke:none"
+       id="rect5435-8"
+       width="380.35715"
+       height="29.999998"
+       x="160"
+       y="922.00507" />
+    <rect
+       style="fill:#c8c8c8;fill-opacity:1;stroke:none"
+       id="rect5435"
+       width="380.35715"
+       height="29.999998"
+       x="160"
+       y="852.36218" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1.37742484px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160.44865,922.36218 379.45984,0"
+       id="path3823"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1.37742484px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160.80579,952.36218 379.45984,0"
+       id="path3823-6"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1.37742484px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160.80579,992.36218 379.45984,0"
+       id="path3823-5"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1.37806964px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160.44954,1022.3622 379.81521,0"
+       id="path3823-59"
+       inkscape:connector-curvature="0" />
+    <g
+       id="g4572">
+      <rect
+         style="fill:#4e9a06;fill-opacity:1;stroke:#000000;stroke-opacity:1"
+         y="852.36218"
+         x="200.35715"
+         height="30"
+         width="60"
+         id="rect3035" />
+      <path
+         inkscape:connector-curvature="0"
+         id="path3857"
+         d="m 230.35714,852.71932 0,30"
+         style="fill:none;stroke:#000000;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:1, 1;stroke-dashoffset:0" />
+    </g>
+    <rect
+       style="fill:#204a87;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
+       id="rect3877"
+       width="30"
+       height="30"
+       x="290.10406"
+       y="992.36218" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 305,992.36219 -30,-40"
+       id="path4007"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1.37677968px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160.44776,882.36218 379.10448,0"
+       id="path3823-3"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1.37548852px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 161.16027,852.36218 378.39375,0"
+       id="path3823-7"
+       inkscape:connector-curvature="0" />
+    <g
+       transform="translate(120.00001,2.7099611e-7)"
+       id="g4572-6">
+      <rect
+         style="fill:#4e9a06;fill-opacity:1;stroke:#000000;stroke-opacity:1"
+         y="852.36218"
+         x="200.35715"
+         height="30"
+         width="60"
+         id="rect3035-6" />
+      <path
+         inkscape:connector-curvature="0"
+         id="path3857-8"
+         d="m 230.35714,852.71932 0,30"
+         style="fill:none;stroke:#000000;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:1, 1;stroke-dashoffset:0" />
+    </g>
+    <g
+       transform="translate(239.64285,2.8458362e-7)"
+       id="g4572-2">
+      <rect
+         style="fill:#4e9a06;fill-opacity:1;stroke:#000000;stroke-opacity:1"
+         y="852.36218"
+         x="200.35715"
+         height="30"
+         width="60"
+         id="rect3035-3" />
+      <path
+         inkscape:connector-curvature="0"
+         id="path3857-4"
+         d="m 230.35714,852.71932 0,30"
+         style="fill:none;stroke:#000000;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:1, 1;stroke-dashoffset:0" />
+    </g>
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
+       id="rect3877-9-7"
+       width="30"
+       height="30"
+       x="290.35715"
+       y="922.36218" />
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
+       id="rect3877-9-7-6"
+       width="30"
+       height="30"
+       x="320.35715"
+       y="922.36218" />
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
+       id="rect3877-9-7-5"
+       width="30"
+       height="30"
+       x="260.35715"
+       y="922.36218" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 275,922.36218 60,-39.99999"
+       id="path4007-0"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 305,922.36219 -90,-40"
+       id="path4007-1"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 335,922.36218 120,-40"
+       id="path4007-9"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+  </g>
+  <g
+     inkscape:label="labels"
+     inkscape:groupmode="layer"
+     id="layer1"
+     transform="translate(-20.848666,-782.00507)"
+     style="display:inline">
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="26.162441"
+       y="874.89392"
+       id="text2995"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997"
+         x="26.162441"
+         y="874.89392"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">argument Dat</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="38.374371"
+       y="1014.8469"
+       id="text2995-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-0"
+         x="38.374371"
+         y="1014.8469"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">iteration Set</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="303.09393"
+       y="1012.8672"
+       id="text3940"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942"
+         x="303.09393"
+         y="1012.8672"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">i</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="268.68655"
+       y="942.43842"
+       id="text3940-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-9"
+         x="268.68655"
+         y="942.43842"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3i</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="292.05823"
+       y="942.43842"
+       id="text3940-3-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-9-2"
+         x="292.05823"
+         y="942.43842"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3i+1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="321.76324"
+       y="942.43842"
+       id="text3940-3-8-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-9-2-8"
+         x="321.76324"
+         y="942.43842"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3i+2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="329.91415"
+       y="872.15393"
+       id="text3940-3-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-9-3"
+         x="329.91415"
+         y="872.15393"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2m[i,0]</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="210"
+       y="872.15393"
+       id="text3940-3-5-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-9-3-1"
+         x="210"
+         y="872.15393"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2m[i,1]</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="450"
+       y="872.15393"
+       id="text3940-3-5-0-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-9-3-1-7"
+         x="450"
+         y="872.15393"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2m[i,2]</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="20.048666"
+       y="945.14972"
+       id="text2995-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-9"
+         x="20.048666"
+         y="945.14972"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">argument Map</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="88.333755"
+       y="968.82666"
+       id="text2995-3-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-9-9"
+         x="88.333755"
+         y="968.82666"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:300;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Light">(arity 3)</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="94.34391"
+       y="899.07922"
+       id="text2995-3-9-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-9-9-0"
+         x="94.34391"
+         y="899.07922"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:300;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Light">(dim 2)</tspan></text>
+    <text
+       xml:space="preserve"
+       style="display:inline;font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="58.687004"
+       y="804.99103"
+       id="text2995-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-6"
+         x="58.687004"
+         y="804.99103"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">kernel Arg</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer3"
+     inkscape:label="non-flattened"
+     style="display:inline">
+    <rect
+       transform="translate(-20.848666,-782.00507)"
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-67"
+       width="30"
+       height="30"
+       x="290.48691"
+       y="782.50507" />
+    <rect
+       transform="translate(-20.848666,-782.00507)"
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-6-3"
+       width="30"
+       height="30"
+       x="320.48691"
+       y="782.50507" />
+    <rect
+       transform="translate(-20.848666,-782.00507)"
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-5-0"
+       width="30"
+       height="30"
+       x="260.48691"
+       y="782.50507" />
+    <path
+       transform="translate(-20.848666,-782.00507)"
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend);display:inline"
+       d="m 335,812.36219 120,39.99999"
+       id="path4007-6"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       transform="translate(-20.848666,-782.00507)"
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend);display:inline"
+       d="m 305,812.36218 -90,40"
+       id="path4007-7"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       transform="translate(-20.848666,-782.00507)"
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend);display:inline"
+       d="m 275,812.36218 60,40"
+       id="path4007-63"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer4"
+     inkscape:label="flattened"
+     style="display:none">
+    <rect
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-67-8"
+       width="30"
+       height="30"
+       x="239.55844"
+       y="0.52961689" />
+    <rect
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-6-3-0"
+       width="30"
+       height="30"
+       x="269.55844"
+       y="0.52961689" />
+    <rect
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-5-0-0"
+       width="30"
+       height="30"
+       x="209.55844"
+       y="0.52961689" />
+    <rect
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-67-84"
+       width="30"
+       height="30"
+       x="329.9671"
+       y="0.52961707" />
+    <rect
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-6-3-1"
+       width="30"
+       height="30"
+       x="359.9671"
+       y="0.52961707" />
+    <rect
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-5-0-01"
+       width="30"
+       height="30"
+       x="299.9671"
+       y="0.52961707" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-7)"
+       d="m 224.15133,30.357124 90,39.999999"
+       id="path5127"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-7)"
+       d="m 254.15133,30.357124 -60,39.999999"
+       id="path5127-8"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-7)"
+       d="m 284.15133,30.357124 150,39.999999"
+       id="path5127-9"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-7)"
+       d="m 314.15133,30.357123 30,40"
+       id="path5127-7"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-7)"
+       d="m 344.15133,30.357123 -120,40"
+       id="path5127-1"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-7)"
+       d="m 374.15133,30.357123 90,40.000001"
+       id="path5127-79"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Bitstream Vera Sans"
+       x="40.311226"
+       y="46.872353"
+       id="text2995-3-9-9-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-9-9-0-9"
+         x="40.311226"
+         y="46.872353"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:300;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Light">(flattened)</tspan></text>
+  </g>
+</svg>
diff --git a/_images/indirect_arg_flattened.svg b/_images/indirect_arg_flattened.svg
new file mode 100644
index 000000000..2da6cbe8f
--- /dev/null
+++ b/_images/indirect_arg_flattened.svg
@@ -0,0 +1,832 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:osb="http://www.openswatchbook.org/uri/2009/osb"
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="520.10565"
+   height="241.04617"
+   id="svg2"
+   version="1.1"
+   inkscape:version="0.48.4 r9939"
+   sodipodi:docname="indirect_arg_flattened.svg">
+  <defs
+     id="defs4">
+    <linearGradient
+       id="linearGradient7037">
+      <stop
+         style="stop-color:#ffffff;stop-opacity:1;"
+         offset="0"
+         id="stop7039" />
+      <stop
+         style="stop-color:#ffffff;stop-opacity:0;"
+         offset="1"
+         id="stop7041" />
+    </linearGradient>
+    <linearGradient
+       id="linearGradient7031"
+       osb:paint="solid">
+      <stop
+         style="stop-color:#a40000;stop-opacity:1;"
+         offset="0"
+         id="stop7033" />
+    </linearGradient>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend"
+       style="overflow:visible">
+      <path
+         id="path4040"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-2"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4040-7"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-8"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4040-6"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-1"
+       style="overflow:visible">
+      <path
+         id="path4040-3"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-9"
+       style="overflow:visible">
+      <path
+         id="path4040-1"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-4"
+       style="overflow:visible">
+      <path
+         id="path4040-8"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-3"
+       style="overflow:visible">
+      <path
+         id="path4040-63"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-22"
+       style="overflow:visible">
+      <path
+         id="path4040-60"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7"
+       style="overflow:visible">
+      <path
+         id="path4040-9"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7-7"
+       style="overflow:visible">
+      <path
+         id="path4040-9-2"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7-9"
+       style="overflow:visible">
+      <path
+         id="path4040-9-27"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7-2"
+       style="overflow:visible">
+      <path
+         id="path4040-9-24"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7-27"
+       style="overflow:visible">
+      <path
+         id="path4040-9-7"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7-1"
+       style="overflow:visible">
+      <path
+         id="path4040-9-6"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+  </defs>
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="3.4686902"
+     inkscape:cx="288.96739"
+     inkscape:cy="123.62423"
+     inkscape:document-units="px"
+     inkscape:current-layer="layer1"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     fit-margin-top="0"
+     fit-margin-left="0"
+     fit-margin-right="0"
+     fit-margin-bottom="0"
+     inkscape:window-width="1920"
+     inkscape:window-height="1043"
+     inkscape:window-x="0"
+     inkscape:window-y="1098"
+     inkscape:window-maximized="0"
+     inkscape:snap-global="true">
+    <inkscape:grid
+       type="xygrid"
+       id="grid2985"
+       empspacing="5"
+       visible="true"
+       enabled="true"
+       snapvisiblegridlinesonly="true"
+       originx="-20.848666px"
+       originy="-29.310951px" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="59.151334,0.68904931"
+       id="guide2987" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="-20.848666,30.689049"
+       id="guide2989" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="-20.848666,70.689049"
+       id="guide2991" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="-20.848666,100.68905"
+       id="guide2993" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="139.15134,360.68905"
+       id="guide3020" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="179.15134,370.68905"
+       id="guide3022" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="209.15134,310.68905"
+       id="guide3024" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="239.15134,340.68905"
+       id="guide3026" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="269.15134,320.68905"
+       id="guide3028" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="299.15134,360.68905"
+       id="guide3030" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="329.15134,215.68905"
+       id="guide3032" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="139.15134,140.68905"
+       id="guide4539" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="139.15134,170.68905"
+       id="guide4541" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="139.15134,210.68905"
+       id="guide4543" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="139.15134,240.68905"
+       id="guide4545" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="359.15134,210.68905"
+       id="guide4589" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="389.15134,210.68905"
+       id="guide4591" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="419.15134,240.68905"
+       id="guide4593" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="449.15134,280.68905"
+       id="guide4595" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="479.15134,270.68905"
+       id="guide4597" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="519.15134,250.68905"
+       id="guide4599" />
+  </sodipodi:namedview>
+  <metadata
+     id="metadata7">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:groupmode="layer"
+     id="layer2"
+     inkscape:label="boxes"
+     transform="translate(-20.848666,-782.00507)">
+    <rect
+       style="fill:#c8c8c8;fill-opacity:1;stroke:none"
+       id="rect5435-9"
+       width="380.35715"
+       height="29.999998"
+       x="160"
+       y="992.7193" />
+    <rect
+       style="fill:#c8c8c8;fill-opacity:1;stroke:none"
+       id="rect5435-8"
+       width="380.35715"
+       height="29.999998"
+       x="160"
+       y="922.00507" />
+    <rect
+       style="fill:#c8c8c8;fill-opacity:1;stroke:none"
+       id="rect5435"
+       width="380.35715"
+       height="29.999998"
+       x="160"
+       y="852.36218" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1.37742484px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160.44865,922.36218 379.45984,0"
+       id="path3823"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1.37742484px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160.80579,952.36218 379.45984,0"
+       id="path3823-6"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1.37742484px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160.80579,992.36218 379.45984,0"
+       id="path3823-5"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1.37806964px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160.44954,1022.3622 379.81521,0"
+       id="path3823-59"
+       inkscape:connector-curvature="0" />
+    <g
+       id="g4572">
+      <rect
+         style="fill:#4e9a06;fill-opacity:1;stroke:#000000;stroke-opacity:1"
+         y="852.36218"
+         x="200.35715"
+         height="30"
+         width="60"
+         id="rect3035" />
+      <path
+         inkscape:connector-curvature="0"
+         id="path3857"
+         d="m 230.35714,852.71932 0,30"
+         style="fill:none;stroke:#000000;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:1, 1;stroke-dashoffset:0" />
+    </g>
+    <rect
+       style="fill:#204a87;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
+       id="rect3877"
+       width="30"
+       height="30"
+       x="290.10406"
+       y="992.36218" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 305,992.36219 -30,-40"
+       id="path4007"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1.37677968px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 160.44776,882.36218 379.10448,0"
+       id="path3823-3"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1.37548852px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 161.16027,852.36218 378.39375,0"
+       id="path3823-7"
+       inkscape:connector-curvature="0" />
+    <g
+       transform="translate(120.00001,2.7099611e-7)"
+       id="g4572-6">
+      <rect
+         style="fill:#4e9a06;fill-opacity:1;stroke:#000000;stroke-opacity:1"
+         y="852.36218"
+         x="200.35715"
+         height="30"
+         width="60"
+         id="rect3035-6" />
+      <path
+         inkscape:connector-curvature="0"
+         id="path3857-8"
+         d="m 230.35714,852.71932 0,30"
+         style="fill:none;stroke:#000000;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:1, 1;stroke-dashoffset:0" />
+    </g>
+    <g
+       transform="translate(239.64285,2.8458362e-7)"
+       id="g4572-2">
+      <rect
+         style="fill:#4e9a06;fill-opacity:1;stroke:#000000;stroke-opacity:1"
+         y="852.36218"
+         x="200.35715"
+         height="30"
+         width="60"
+         id="rect3035-3" />
+      <path
+         inkscape:connector-curvature="0"
+         id="path3857-4"
+         d="m 230.35714,852.71932 0,30"
+         style="fill:none;stroke:#000000;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:1, 1;stroke-dashoffset:0" />
+    </g>
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
+       id="rect3877-9-7"
+       width="30"
+       height="30"
+       x="290.35715"
+       y="922.36218" />
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
+       id="rect3877-9-7-6"
+       width="30"
+       height="30"
+       x="320.35715"
+       y="922.36218" />
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
+       id="rect3877-9-7-5"
+       width="30"
+       height="30"
+       x="260.35715"
+       y="922.36218" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 275,922.36218 60,-39.99999"
+       id="path4007-0"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 305,922.36219 -90,-40"
+       id="path4007-1"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 335,922.36218 120,-40"
+       id="path4007-9"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+  </g>
+  <g
+     inkscape:label="labels"
+     inkscape:groupmode="layer"
+     id="layer1"
+     transform="translate(-20.848666,-782.00507)"
+     style="display:inline">
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="26.162441"
+       y="874.89392"
+       id="text2995"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997"
+         x="26.162441"
+         y="874.89392"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">argument Dat</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="38.374371"
+       y="1014.8469"
+       id="text2995-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-0"
+         x="38.374371"
+         y="1014.8469"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">iteration Set</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="303.09393"
+       y="1012.8672"
+       id="text3940"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942"
+         x="303.09393"
+         y="1012.8672"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">i</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="268.68655"
+       y="942.43842"
+       id="text3940-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-9"
+         x="268.68655"
+         y="942.43842"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3i</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="292.05823"
+       y="942.43842"
+       id="text3940-3-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-9-2"
+         x="292.05823"
+         y="942.43842"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3i+1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="321.76324"
+       y="942.43842"
+       id="text3940-3-8-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-9-2-8"
+         x="321.76324"
+         y="942.43842"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3i+2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="329.91415"
+       y="872.15393"
+       id="text3940-3-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-9-3"
+         x="329.91415"
+         y="872.15393"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2m[i,0]</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="210"
+       y="872.15393"
+       id="text3940-3-5-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-9-3-1"
+         x="210"
+         y="872.15393"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2m[i,1]</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="450"
+       y="872.15393"
+       id="text3940-3-5-0-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan3942-9-3-1-7"
+         x="450"
+         y="872.15393"
+         style="font-size:14px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#ffffff;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2m[i,2]</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="20.048666"
+       y="945.14972"
+       id="text2995-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-9"
+         x="20.048666"
+         y="945.14972"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">argument Map</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="88.333755"
+       y="968.82666"
+       id="text2995-3-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-9-9"
+         x="88.333755"
+         y="968.82666"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:300;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Light">(arity 3)</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="94.34391"
+       y="899.07922"
+       id="text2995-3-9-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-9-9-0"
+         x="94.34391"
+         y="899.07922"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:300;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Light">(dim 2)</tspan></text>
+    <text
+       xml:space="preserve"
+       style="display:inline;font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:Bitstream Vera Sans"
+       x="58.687004"
+       y="804.99103"
+       id="text2995-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-6"
+         x="58.687004"
+         y="804.99103"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">kernel Arg</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer3"
+     inkscape:label="non-flattened"
+     style="display:none">
+    <rect
+       transform="translate(-20.848666,-782.00507)"
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-67"
+       width="30"
+       height="30"
+       x="290.48691"
+       y="782.50507" />
+    <rect
+       transform="translate(-20.848666,-782.00507)"
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-6-3"
+       width="30"
+       height="30"
+       x="320.48691"
+       y="782.50507" />
+    <rect
+       transform="translate(-20.848666,-782.00507)"
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-5-0"
+       width="30"
+       height="30"
+       x="260.48691"
+       y="782.50507" />
+    <path
+       transform="translate(-20.848666,-782.00507)"
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend);display:inline"
+       d="m 335,812.36219 120,39.99999"
+       id="path4007-6"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       transform="translate(-20.848666,-782.00507)"
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend);display:inline"
+       d="m 305,812.36218 -90,40"
+       id="path4007-7"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       transform="translate(-20.848666,-782.00507)"
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend);display:inline"
+       d="m 275,812.36218 60,40"
+       id="path4007-63"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer4"
+     inkscape:label="flattened">
+    <rect
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-67-8"
+       width="30"
+       height="30"
+       x="239.55844"
+       y="0.52961689" />
+    <rect
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-6-3-0"
+       width="30"
+       height="30"
+       x="269.55844"
+       y="0.52961689" />
+    <rect
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-5-0-0"
+       width="30"
+       height="30"
+       x="209.55844"
+       y="0.52961689" />
+    <rect
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-67-84"
+       width="30"
+       height="30"
+       x="329.9671"
+       y="0.52961707" />
+    <rect
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-6-3-1"
+       width="30"
+       height="30"
+       x="359.9671"
+       y="0.52961707" />
+    <rect
+       style="fill:#a40000;fill-opacity:1;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
+       id="rect3877-9-7-5-0-01"
+       width="30"
+       height="30"
+       x="299.9671"
+       y="0.52961707" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-7)"
+       d="m 224.15133,30.357124 90,39.999999"
+       id="path5127"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-7)"
+       d="m 254.15133,30.357124 -60,39.999999"
+       id="path5127-8"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-7)"
+       d="m 284.15133,30.357124 150,39.999999"
+       id="path5127-9"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-7)"
+       d="m 314.15133,30.357123 30,40"
+       id="path5127-7"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-7)"
+       d="m 344.15133,30.357123 -120,40"
+       id="path5127-1"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-7)"
+       d="m 374.15133,30.357123 90,40.000001"
+       id="path5127-79"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <text
+       xml:space="preserve"
+       style="font-size:40px;font-style:normal;font-weight:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Bitstream Vera Sans"
+       x="40.311226"
+       y="46.872353"
+       id="text2995-3-9-9-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan2997-9-9-0-9"
+         x="40.311226"
+         y="46.872353"
+         style="font-size:20px;font-style:normal;font-variant:normal;font-weight:300;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Light">(flattened)</tspan></text>
+  </g>
+</svg>
diff --git a/_images/iteration_spaces.svg b/_images/iteration_spaces.svg
new file mode 100644
index 000000000..9029c95cd
--- /dev/null
+++ b/_images/iteration_spaces.svg
@@ -0,0 +1,5040 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="800"
+   height="480"
+   id="svg91417"
+   version="1.1"
+   inkscape:version="0.48.4 r9939"
+   sodipodi:docname="iteration_spaces.svg">
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="1.7553939"
+     inkscape:cx="500.30139"
+     inkscape:cy="225.53452"
+     inkscape:current-layer="layer4"
+     inkscape:document-units="px"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     inkscape:window-width="1920"
+     inkscape:window-height="1043"
+     inkscape:window-x="0"
+     inkscape:window-y="1098"
+     inkscape:window-maximized="0"
+     inkscape:snap-global="false">
+    <inkscape:grid
+       snapvisiblegridlinesonly="true"
+       enabled="true"
+       visible="true"
+       empspacing="5"
+       type="xygrid"
+       id="grid91425" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="85,400"
+       id="guide91596" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="135,40"
+       id="guide91600" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="305,480"
+       id="guide91602" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="5,455"
+       id="guide10739" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="35,455"
+       id="guide10741" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="65,480"
+       id="guide10743" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="95,480"
+       id="guide10745" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="125,480"
+       id="guide10749" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="155,480"
+       id="guide10751" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="185,480"
+       id="guide10753" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="215,480"
+       id="guide10755" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="245,480"
+       id="guide10757" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="275,480"
+       id="guide10759" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="35,370"
+       id="guide10761" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="35,340"
+       id="guide10763" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="105,70"
+       id="guide10765" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="65,100"
+       id="guide10767" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="100,130"
+       id="guide10769" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="60,160"
+       id="guide10771" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="70,220"
+       id="guide10775" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="75,250"
+       id="guide10777" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="100,280"
+       id="guide10779" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="90,310"
+       id="guide10781" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="365,480"
+       id="guide11285" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="335,480"
+       id="guide11287" />
+  </sodipodi:namedview>
+  <defs
+     id="defs91419">
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow1Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow1Mend"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12664"
+         d="M 0,0 5,-5 -12.5,0 5,5 0,0 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt"
+         transform="matrix(-0.4,0,0,-0.4,-4,0)" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="DotM"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path21623" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91297"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91299" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91301"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91303" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91305"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91307" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91309"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91311" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91313"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91315" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker6626"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path6628" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91319"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91321" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91323"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91325" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91327"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91329" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91331"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91333" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91335"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91337" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91339"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91341" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91343"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91345" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91347"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91349" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91351"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91353" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91355"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91357" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker91359"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path91361" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="DotM-8"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path21623-3" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="marker11181"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DotM">
+      <path
+         inkscape:connector-curvature="0"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         id="path11183" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-3"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-2"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-1"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-5"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-4"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-3"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-6"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-50"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-9"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-6"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-42"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-64"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-92"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-55"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-17"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-0"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-7"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-1"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-90"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-51"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-95"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-4"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-68"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+  </defs>
+  <metadata
+     id="metadata91422">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     transform="translate(0,-120)"
+     id="layer1"
+     inkscape:label="unified threads"
+     inkscape:groupmode="layer"
+     style="display:inline">
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10783"
+       width="30"
+       height="30"
+       x="5"
+       y="200" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10785"
+       width="30"
+       height="30"
+       x="5"
+       y="230" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10787"
+       width="30"
+       height="30"
+       x="5"
+       y="260" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10789"
+       width="30"
+       height="30"
+       x="35"
+       y="200" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10791"
+       width="30"
+       height="30"
+       x="35"
+       y="230" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10793"
+       width="30"
+       height="30"
+       x="35"
+       y="260" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10795"
+       width="30"
+       height="30"
+       x="65"
+       y="200" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10797"
+       width="30"
+       height="30"
+       x="65"
+       y="230" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10799"
+       width="30"
+       height="30"
+       x="65"
+       y="260" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10801"
+       width="30"
+       height="30"
+       x="125"
+       y="200" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10803"
+       width="30"
+       height="30"
+       x="125"
+       y="230" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10805"
+       width="30"
+       height="30"
+       x="125"
+       y="260" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10807"
+       width="30"
+       height="30"
+       x="185"
+       y="200" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10809"
+       width="30"
+       height="30"
+       x="185"
+       y="230" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10811"
+       width="30"
+       height="30"
+       x="185"
+       y="260" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10813"
+       width="30"
+       height="30"
+       x="215"
+       y="200" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10815"
+       width="30"
+       height="30"
+       x="215"
+       y="230" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10817"
+       width="30"
+       height="30"
+       x="215"
+       y="260" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10819"
+       width="30"
+       height="30"
+       x="245"
+       y="200" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10821"
+       width="30"
+       height="30"
+       x="245"
+       y="230" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10823"
+       width="30"
+       height="30"
+       x="245"
+       y="260" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10825"
+       width="30"
+       height="30"
+       x="275"
+       y="200" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10827"
+       width="30"
+       height="30"
+       x="275"
+       y="230" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10829"
+       width="30"
+       height="30"
+       x="275"
+       y="260" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10831"
+       width="30"
+       height="30"
+       x="335"
+       y="200" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10833"
+       width="30"
+       height="30"
+       x="335"
+       y="230" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10835"
+       width="30"
+       height="30"
+       x="335"
+       y="260" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10837"
+       width="30"
+       height="30"
+       x="5"
+       y="320" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10843"
+       width="30"
+       height="30"
+       x="35"
+       y="320" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10845"
+       width="30"
+       height="30"
+       x="65"
+       y="320" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10847"
+       width="30"
+       height="30"
+       x="5"
+       y="380" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10849"
+       width="30"
+       height="30"
+       x="35"
+       y="380" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10851"
+       width="30"
+       height="30"
+       x="65"
+       y="380" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10853"
+       width="30"
+       height="30"
+       x="5"
+       y="410" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10855"
+       width="30"
+       height="30"
+       x="65"
+       y="410" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10857"
+       width="30"
+       height="30"
+       x="35"
+       y="410" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10859"
+       width="30"
+       height="30"
+       x="5"
+       y="470" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10861"
+       width="30"
+       height="30"
+       x="5"
+       y="440" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10863"
+       width="30"
+       height="30"
+       x="65"
+       y="470" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10865"
+       width="30"
+       height="30"
+       x="65"
+       y="440" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10869"
+       width="30"
+       height="30"
+       x="35"
+       y="470" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10871"
+       width="30"
+       height="30"
+       x="35"
+       y="440" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10920"
+       width="30"
+       height="30"
+       x="5"
+       y="530" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10922"
+       width="30"
+       height="30"
+       x="35"
+       y="530" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10924"
+       width="30"
+       height="30"
+       x="65"
+       y="530" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10926"
+       width="30"
+       height="30"
+       x="125"
+       y="320" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10928"
+       width="30"
+       height="30"
+       x="125"
+       y="380" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10930"
+       width="30"
+       height="30"
+       x="125"
+       y="410" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10932"
+       width="30"
+       height="30"
+       x="125"
+       y="440" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10934"
+       width="30"
+       height="30"
+       x="125"
+       y="470" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10936"
+       width="30"
+       height="30"
+       x="125"
+       y="530" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10938"
+       width="30"
+       height="30"
+       x="335"
+       y="320" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10940"
+       width="30"
+       height="30"
+       x="335"
+       y="530" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10942"
+       width="30"
+       height="30"
+       x="275"
+       y="320" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10944"
+       width="30"
+       height="30"
+       x="245"
+       y="320" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10946"
+       width="30"
+       height="30"
+       x="215"
+       y="320" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10948"
+       width="30"
+       height="30"
+       x="185"
+       y="320" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10950"
+       width="30"
+       height="30"
+       x="335"
+       y="380" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10952"
+       width="30"
+       height="30"
+       x="335"
+       y="410" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10954"
+       width="30"
+       height="30"
+       x="335"
+       y="440" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10956"
+       width="30"
+       height="30"
+       x="335"
+       y="470" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10958"
+       width="30"
+       height="30"
+       x="275"
+       y="530" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10960"
+       width="30"
+       height="30"
+       x="245"
+       y="530" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10962"
+       width="30"
+       height="30"
+       x="215"
+       y="530" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10964"
+       width="30"
+       height="30"
+       x="185"
+       y="530" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10966"
+       width="30"
+       height="30"
+       x="275"
+       y="470" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10968"
+       width="30"
+       height="30"
+       x="245"
+       y="470" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10970"
+       width="30"
+       height="30"
+       x="215"
+       y="470" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10972"
+       width="30"
+       height="30"
+       x="185"
+       y="470" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10974"
+       width="30"
+       height="30"
+       x="275"
+       y="440" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10976"
+       width="30"
+       height="30"
+       x="245"
+       y="440" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10978"
+       width="30"
+       height="30"
+       x="215"
+       y="440" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10980"
+       width="30"
+       height="30"
+       x="185"
+       y="440" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10982"
+       width="30"
+       height="30"
+       x="275"
+       y="410" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10984"
+       width="30"
+       height="30"
+       x="245"
+       y="410" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10986"
+       width="30"
+       height="30"
+       x="215"
+       y="410" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10988"
+       width="30"
+       height="30"
+       x="185"
+       y="410" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10990"
+       width="30"
+       height="30"
+       x="275"
+       y="380" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10992"
+       width="30"
+       height="30"
+       x="245"
+       y="380" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10994"
+       width="30"
+       height="30"
+       x="215"
+       y="380" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect10996"
+       width="30"
+       height="30"
+       x="185"
+       y="380" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10999"
+       width="30"
+       height="30"
+       x="95"
+       y="200" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11001"
+       width="30"
+       height="30"
+       x="95"
+       y="230" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11003"
+       width="30"
+       height="30"
+       x="95"
+       y="260" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11005"
+       width="30"
+       height="30"
+       x="65"
+       y="290" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11007"
+       width="30"
+       height="30"
+       x="35"
+       y="290" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11009"
+       width="30"
+       height="30"
+       x="5"
+       y="290" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11011"
+       width="30"
+       height="30"
+       x="95"
+       y="320" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11013"
+       width="30"
+       height="30"
+       x="155"
+       y="320" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11015"
+       width="30"
+       height="30"
+       x="155"
+       y="200" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11017"
+       width="30"
+       height="30"
+       x="155"
+       y="230" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11019"
+       width="30"
+       height="30"
+       x="155"
+       y="260" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11021"
+       width="30"
+       height="30"
+       x="125"
+       y="290" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11023"
+       width="30"
+       height="30"
+       x="185"
+       y="290" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11025"
+       width="30"
+       height="30"
+       x="215"
+       y="290" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11027"
+       width="30"
+       height="30"
+       x="245"
+       y="290" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11029"
+       width="30"
+       height="30"
+       x="275"
+       y="290" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11031"
+       width="30"
+       height="30"
+       x="305"
+       y="200" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11033"
+       width="30"
+       height="30"
+       x="305"
+       y="230" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11035"
+       width="30"
+       height="30"
+       x="305"
+       y="260" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11037"
+       width="30"
+       height="30"
+       x="335"
+       y="290" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11039"
+       width="30"
+       height="30"
+       x="305"
+       y="320" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11041"
+       width="30"
+       height="30"
+       x="335"
+       y="350" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11043"
+       width="30"
+       height="30"
+       x="5"
+       y="350" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11045"
+       width="30"
+       height="30"
+       x="35"
+       y="350" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11047"
+       width="30"
+       height="30"
+       x="65"
+       y="350" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11049"
+       width="30"
+       height="30"
+       x="125"
+       y="350" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11051"
+       width="30"
+       height="30"
+       x="185"
+       y="350" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11053"
+       width="30"
+       height="30"
+       x="215"
+       y="350" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11055"
+       width="30"
+       height="30"
+       x="245"
+       y="350" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11057"
+       width="30"
+       height="30"
+       x="275"
+       y="350" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11059"
+       width="30"
+       height="30"
+       x="305"
+       y="380" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11061"
+       width="30"
+       height="30"
+       x="305"
+       y="410" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11063"
+       width="30"
+       height="30"
+       x="305"
+       y="440" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11065"
+       width="30"
+       height="30"
+       x="305"
+       y="470" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11067"
+       width="30"
+       height="30"
+       x="305"
+       y="530" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11069"
+       width="30"
+       height="30"
+       x="335"
+       y="500" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11071"
+       width="30"
+       height="30"
+       x="275"
+       y="500" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11073"
+       width="30"
+       height="30"
+       x="245"
+       y="500" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11075"
+       width="30"
+       height="30"
+       x="215"
+       y="500" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11077"
+       width="30"
+       height="30"
+       x="185"
+       y="500" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11079"
+       width="30"
+       height="30"
+       x="95"
+       y="380" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11081"
+       width="30"
+       height="30"
+       x="95"
+       y="410" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11083"
+       width="30"
+       height="30"
+       x="95"
+       y="440" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11085"
+       width="30"
+       height="30"
+       x="95"
+       y="470" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11087"
+       width="30"
+       height="30"
+       x="155"
+       y="380" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11089"
+       width="30"
+       height="30"
+       x="155"
+       y="410" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11091"
+       width="30"
+       height="30"
+       x="155"
+       y="440" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11093"
+       width="30"
+       height="30"
+       x="155"
+       y="470" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11095"
+       width="30"
+       height="30"
+       x="95"
+       y="530" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11097"
+       width="30"
+       height="30"
+       x="155"
+       y="530" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11099"
+       width="30"
+       height="30"
+       x="125"
+       y="500" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11101"
+       width="30"
+       height="30"
+       x="65"
+       y="500" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11103"
+       width="30"
+       height="30"
+       x="35"
+       y="500" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11105"
+       width="30"
+       height="30"
+       x="5"
+       y="500" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11108"
+       width="30"
+       height="30"
+       x="95"
+       y="290" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11110"
+       width="30"
+       height="30"
+       x="155"
+       y="290" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11114"
+       width="30"
+       height="30"
+       x="95"
+       y="350" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11116"
+       width="30"
+       height="30"
+       x="155"
+       y="350" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11118"
+       width="30"
+       height="30"
+       x="95"
+       y="500" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11120"
+       width="30"
+       height="30"
+       x="155"
+       y="500" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11122"
+       width="30"
+       height="30"
+       x="305"
+       y="290" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11124"
+       width="30"
+       height="30"
+       x="305"
+       y="350" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11126"
+       width="30"
+       height="30"
+       x="305"
+       y="500" />
+  </g>
+  <g
+     transform="translate(0,40)"
+     inkscape:label="unified iteration space"
+     id="layer3"
+     inkscape:groupmode="layer">
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu Condensed;-inkscape-font-specification:'Ubuntu Condensed,'"
+       x="10.877198"
+       y="-37.303692"
+       id="text29587-3-4-2-3-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-9-0"
+         x="10.877198"
+         y="-37.303692" /><tspan
+         sodipodi:role="line"
+         x="10.877198"
+         y="-18.35243"
+         style="font-size:18px;font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;letter-spacing:0px;font-family:Ubuntu Condensed;-inkscape-font-specification:'Ubuntu Condensed, Bold';text-anchor:start;text-align:start;writing-mode:lr;line-height:125%"
+         id="tspan29724-8">Unified iteration space:</tspan><tspan
+         sodipodi:role="line"
+         x="10.877198"
+         y="-0.2274299"
+         style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;letter-spacing:0px;font-family:Ubuntu Condensed;-inkscape-font-specification:'Ubuntu Condensed,';text-anchor:start;text-align:start;writing-mode:lr;line-height:125%"
+         id="tspan29757">144 kernel output values computed by single thread</tspan></text>
+  </g>
+  <g
+     transform="translate(0,40)"
+     inkscape:label="local threads"
+     id="layer2"
+     inkscape:groupmode="layer">
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10783-3"
+       width="30"
+       height="30"
+       x="391"
+       y="21" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;"
+       id="rect10785-3"
+       width="30"
+       height="30"
+       x="391"
+       y="55" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10787-2"
+       width="30"
+       height="30"
+       x="391"
+       y="89" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10789-9"
+       width="30"
+       height="30"
+       x="425"
+       y="21" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;"
+       id="rect10791-0"
+       width="30"
+       height="30"
+       x="425"
+       y="55" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10793-1"
+       width="30"
+       height="30"
+       x="425"
+       y="89" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10795-8"
+       width="30"
+       height="30"
+       x="459"
+       y="21" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;"
+       id="rect10797-9"
+       width="30"
+       height="30"
+       x="459"
+       y="55" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10799-4"
+       width="30"
+       height="30"
+       x="459"
+       y="89" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10801-6"
+       width="30"
+       height="30"
+       x="527"
+       y="21" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;"
+       id="rect10803-6"
+       width="30"
+       height="30"
+       x="527"
+       y="55" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10805-1"
+       width="30"
+       height="30"
+       x="527"
+       y="89" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10807-8"
+       width="30"
+       height="30"
+       x="595"
+       y="21" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;"
+       id="rect10809-8"
+       width="30"
+       height="30"
+       x="595"
+       y="55" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10811-5"
+       width="30"
+       height="30"
+       x="595"
+       y="89" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10813-5"
+       width="30"
+       height="30"
+       x="629"
+       y="21" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;"
+       id="rect10815-1"
+       width="30"
+       height="30"
+       x="629"
+       y="55" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10817-7"
+       width="30"
+       height="30"
+       x="629"
+       y="89" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10819-4"
+       width="30"
+       height="30"
+       x="663"
+       y="21" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;"
+       id="rect10821-6"
+       width="30"
+       height="30"
+       x="663"
+       y="55" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10823-8"
+       width="30"
+       height="30"
+       x="663"
+       y="89" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10825-6"
+       width="30"
+       height="30"
+       x="697"
+       y="21" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;"
+       id="rect10827-1"
+       width="30"
+       height="30"
+       x="697"
+       y="55" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10829-6"
+       width="30"
+       height="30"
+       x="697"
+       y="89" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10831-1"
+       width="30"
+       height="30"
+       x="765"
+       y="21" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;"
+       id="rect10833-0"
+       width="30"
+       height="30"
+       x="765"
+       y="55" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10835-1"
+       width="30"
+       height="30"
+       x="765"
+       y="89" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10837-5"
+       width="30"
+       height="30"
+       x="391"
+       y="157" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10843-2"
+       width="30"
+       height="30"
+       x="425"
+       y="157" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10845-1"
+       width="30"
+       height="30"
+       x="459"
+       y="157" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10847-4"
+       width="30"
+       height="30"
+       x="391"
+       y="225" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10849-7"
+       width="30"
+       height="30"
+       x="425"
+       y="225" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10851-6"
+       width="30"
+       height="30"
+       x="459"
+       y="225" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10853-8"
+       width="30"
+       height="30"
+       x="391"
+       y="259" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10855-7"
+       width="30"
+       height="30"
+       x="459"
+       y="259" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10857-7"
+       width="30"
+       height="30"
+       x="425"
+       y="259" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10859-2"
+       width="30"
+       height="30"
+       x="391"
+       y="327" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10861-7"
+       width="30"
+       height="30"
+       x="391"
+       y="293" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10863-8"
+       width="30"
+       height="30"
+       x="459"
+       y="327" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10865-6"
+       width="30"
+       height="30"
+       x="459"
+       y="293" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10869-3"
+       width="30"
+       height="30"
+       x="425"
+       y="327" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10871-5"
+       width="30"
+       height="30"
+       x="425"
+       y="293" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10920-9"
+       width="30"
+       height="30"
+       x="391"
+       y="395" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10922-4"
+       width="30"
+       height="30"
+       x="425"
+       y="395" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10924-3"
+       width="30"
+       height="30"
+       x="459"
+       y="395" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10926-4"
+       width="30"
+       height="30"
+       x="527"
+       y="157" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10928-9"
+       width="30"
+       height="30"
+       x="527"
+       y="225" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10930-6"
+       width="30"
+       height="30"
+       x="527"
+       y="259" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10932-4"
+       width="30"
+       height="30"
+       x="527"
+       y="293" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10934-5"
+       width="30"
+       height="30"
+       x="527"
+       y="327" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10936-5"
+       width="30"
+       height="30"
+       x="527"
+       y="395" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10938-2"
+       width="30"
+       height="30"
+       x="765"
+       y="157" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10940-2"
+       width="30"
+       height="30"
+       x="765"
+       y="395" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10942-8"
+       width="30"
+       height="30"
+       x="697"
+       y="157" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10944-8"
+       width="30"
+       height="30"
+       x="663"
+       y="157" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10946-3"
+       width="30"
+       height="30"
+       x="629"
+       y="157" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10948-8"
+       width="30"
+       height="30"
+       x="595"
+       y="157" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10950-2"
+       width="30"
+       height="30"
+       x="765"
+       y="225" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10952-0"
+       width="30"
+       height="30"
+       x="765"
+       y="259" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10954-3"
+       width="30"
+       height="30"
+       x="765"
+       y="293" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10956-3"
+       width="30"
+       height="30"
+       x="765"
+       y="327" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10958-6"
+       width="30"
+       height="30"
+       x="697"
+       y="395" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10960-0"
+       width="30"
+       height="30"
+       x="663"
+       y="395" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10962-2"
+       width="30"
+       height="30"
+       x="629"
+       y="395" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10964-4"
+       width="30"
+       height="30"
+       x="595"
+       y="395" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10966-9"
+       width="30"
+       height="30"
+       x="697"
+       y="327" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10968-9"
+       width="30"
+       height="30"
+       x="663"
+       y="327" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10970-6"
+       width="30"
+       height="30"
+       x="629"
+       y="327" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10972-6"
+       width="30"
+       height="30"
+       x="595"
+       y="327" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10974-7"
+       width="30"
+       height="30"
+       x="697"
+       y="293" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10976-5"
+       width="30"
+       height="30"
+       x="663"
+       y="293" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10978-2"
+       width="30"
+       height="30"
+       x="629"
+       y="293" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10980-4"
+       width="30"
+       height="30"
+       x="595"
+       y="293" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10982-4"
+       width="30"
+       height="30"
+       x="697"
+       y="259" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10984-6"
+       width="30"
+       height="30"
+       x="663"
+       y="259" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10986-8"
+       width="30"
+       height="30"
+       x="629"
+       y="259" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10988-9"
+       width="30"
+       height="30"
+       x="595"
+       y="259" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10990-5"
+       width="30"
+       height="30"
+       x="697"
+       y="225" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10992-6"
+       width="30"
+       height="30"
+       x="663"
+       y="225" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10994-3"
+       width="30"
+       height="30"
+       x="629"
+       y="225" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10996-3"
+       width="30"
+       height="30"
+       x="595"
+       y="225" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect10999-1"
+       width="30"
+       height="30"
+       x="493"
+       y="21" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;"
+       id="rect11001-7"
+       width="30"
+       height="30"
+       x="493"
+       y="55" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11003-7"
+       width="30"
+       height="30"
+       x="493"
+       y="89" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11005-1"
+       width="30"
+       height="30"
+       x="459"
+       y="123" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11007-6"
+       width="30"
+       height="30"
+       x="425"
+       y="123" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11009-2"
+       width="30"
+       height="30"
+       x="391"
+       y="123" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11011-0"
+       width="30"
+       height="30"
+       x="493"
+       y="157" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11013-8"
+       width="30"
+       height="30"
+       x="561"
+       y="157" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11015-4"
+       width="30"
+       height="30"
+       x="561"
+       y="21" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;"
+       id="rect11017-3"
+       width="30"
+       height="30"
+       x="561"
+       y="55" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11019-3"
+       width="30"
+       height="30"
+       x="561"
+       y="89" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11021-0"
+       width="30"
+       height="30"
+       x="527"
+       y="123" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11023-5"
+       width="30"
+       height="30"
+       x="595"
+       y="123" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11025-5"
+       width="30"
+       height="30"
+       x="629"
+       y="123" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11027-6"
+       width="30"
+       height="30"
+       x="663"
+       y="123" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11029-7"
+       width="30"
+       height="30"
+       x="697"
+       y="123" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11031-6"
+       width="30"
+       height="30"
+       x="731"
+       y="21" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;"
+       id="rect11033-5"
+       width="30"
+       height="30"
+       x="731"
+       y="55" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11035-5"
+       width="30"
+       height="30"
+       x="731"
+       y="89" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11037-6"
+       width="30"
+       height="30"
+       x="765"
+       y="123" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11039-0"
+       width="30"
+       height="30"
+       x="731"
+       y="157" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11041-7"
+       width="30"
+       height="30"
+       x="765"
+       y="191" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11043-0"
+       width="30"
+       height="30"
+       x="391"
+       y="191" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11045-4"
+       width="30"
+       height="30"
+       x="425"
+       y="191" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11047-3"
+       width="30"
+       height="30"
+       x="459"
+       y="191" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11049-0"
+       width="30"
+       height="30"
+       x="527"
+       y="191" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11051-5"
+       width="30"
+       height="30"
+       x="595"
+       y="191" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11053-1"
+       width="30"
+       height="30"
+       x="629"
+       y="191" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11055-7"
+       width="30"
+       height="30"
+       x="663"
+       y="191" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11057-0"
+       width="30"
+       height="30"
+       x="697"
+       y="191" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11059-6"
+       width="30"
+       height="30"
+       x="731"
+       y="225" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11061-8"
+       width="30"
+       height="30"
+       x="731"
+       y="259" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11063-8"
+       width="30"
+       height="30"
+       x="731"
+       y="293" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11065-3"
+       width="30"
+       height="30"
+       x="731"
+       y="327" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11067-0"
+       width="30"
+       height="30"
+       x="731"
+       y="395" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11069-6"
+       width="30"
+       height="30"
+       x="765"
+       y="361" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11071-5"
+       width="30"
+       height="30"
+       x="697"
+       y="361" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11073-2"
+       width="30"
+       height="30"
+       x="663"
+       y="361" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11075-4"
+       width="30"
+       height="30"
+       x="629"
+       y="361" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11077-9"
+       width="30"
+       height="30"
+       x="595"
+       y="361" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11079-7"
+       width="30"
+       height="30"
+       x="493"
+       y="225" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11081-9"
+       width="30"
+       height="30"
+       x="493"
+       y="259" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11083-1"
+       width="30"
+       height="30"
+       x="493"
+       y="293" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11085-2"
+       width="30"
+       height="30"
+       x="493"
+       y="327" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11087-7"
+       width="30"
+       height="30"
+       x="561"
+       y="225" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11089-7"
+       width="30"
+       height="30"
+       x="561"
+       y="259" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11091-9"
+       width="30"
+       height="30"
+       x="561"
+       y="293" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11093-3"
+       width="30"
+       height="30"
+       x="561"
+       y="327" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11095-2"
+       width="30"
+       height="30"
+       x="493"
+       y="395" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11097-7"
+       width="30"
+       height="30"
+       x="561"
+       y="395" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11099-9"
+       width="30"
+       height="30"
+       x="527"
+       y="361" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11101-4"
+       width="30"
+       height="30"
+       x="459"
+       y="361" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11103-4"
+       width="30"
+       height="30"
+       x="425"
+       y="361" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11105-0"
+       width="30"
+       height="30"
+       x="391"
+       y="361" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11108-9"
+       width="30"
+       height="30"
+       x="493"
+       y="123" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11110-0"
+       width="30"
+       height="30"
+       x="561"
+       y="123" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11114-0"
+       width="30"
+       height="30"
+       x="493"
+       y="191" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11116-6"
+       width="30"
+       height="30"
+       x="561"
+       y="191" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11118-3"
+       width="30"
+       height="30"
+       x="493"
+       y="361" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11120-7"
+       width="30"
+       height="30"
+       x="561"
+       y="361" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11122-7"
+       width="30"
+       height="30"
+       x="731"
+       y="123" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11124-9"
+       width="30"
+       height="30"
+       x="731"
+       y="191" />
+    <rect
+       style="fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect11126-8"
+       width="30"
+       height="30"
+       x="731"
+       y="361" />
+  </g>
+  <g
+     inkscape:label="local iteration space"
+     id="layer4"
+     inkscape:groupmode="layer"
+     style="display:inline">
+    <text
+       xml:space="preserve"
+       style="font-size:144px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Californian FB;-inkscape-font-specification:Californian FB"
+       x="405.60696"
+       y="76.671722"
+       id="text29583"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29585"
+         x="76.671722"
+         y="405.60696"></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="398.57639"
+       y="62.871552"
+       id="text29587-3-4-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4"
+         x="398.57639"
+         y="62.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3"
+         x="398.57639"
+         y="79.288002"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">0,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="770.44623"
+       y="62.871552"
+       id="text29587-3-4-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-8"
+         x="770.44623"
+         y="62.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-5"
+         x="770.44623"
+         y="79.288002"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">0,11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="393.78455"
+       y="1.2122821"
+       id="text29587-3-4-2-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-9"
+         x="393.78455"
+         y="1.2122821" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-6"
+         x="393.78455"
+         y="23.712282"
+         style="font-size:18px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:0px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium"><tspan
+           style="font-size:18px;font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu Condensed;-inkscape-font-specification:'Ubuntu Condensed, Bold'"
+           id="tspan29769">Local iteration space:</tspan><tspan
+           style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu Condensed;-inkscape-font-specification:'Ubuntu Condensed,'"
+           id="tspan29767"> 144 kernel output values computed</tspan></tspan><tspan
+         sodipodi:role="line"
+         x="393.78455"
+         y="46.21228"
+         style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;writing-mode:lr-tb;text-anchor:start;font-family:Ubuntu Condensed;-inkscape-font-specification:'Ubuntu Condensed,'"
+         id="tspan29724">by 144 threads (0,0) ... (0,11) (1,0) ... (1,11) ... (11,0) ... (11,11)</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="433.35638"
+       y="62.871552"
+       id="text29587-3-4-2-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5"
+         x="433.35638"
+         y="62.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0"
+         x="433.35638"
+         y="79.288002"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">0,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="466.70837"
+       y="62.871552"
+       id="text29587-3-4-2-6-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7"
+         x="466.70837"
+         y="62.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8"
+         x="466.70837"
+         y="79.288002"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">0,2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="500.69638"
+       y="62.871552"
+       id="text29587-3-4-2-6-9-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-0"
+         x="500.69638"
+         y="62.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-6"
+         x="500.69638"
+         y="79.288002"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">0,3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="534.52838"
+       y="62.871552"
+       id="text29587-3-4-2-6-9-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-6"
+         x="534.52838"
+         y="62.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-62"
+         x="534.52838"
+         y="79.288002"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">0,4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="568.69037"
+       y="62.871552"
+       id="text29587-3-4-2-6-9-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-4"
+         x="568.69037"
+         y="62.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-67"
+         x="568.69037"
+         y="79.288002"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">0,5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="602.57635"
+       y="62.871552"
+       id="text29587-3-4-2-6-9-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-8"
+         x="602.57635"
+         y="62.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-8"
+         x="602.57635"
+         y="79.288002"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">0,6</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="636.63037"
+       y="62.871552"
+       id="text29587-3-4-2-6-9-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-46"
+         x="636.63037"
+         y="62.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-4"
+         x="636.63037"
+         y="79.288002"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">0,7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="670.60638"
+       y="62.871552"
+       id="text29587-3-4-2-6-9-75"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-2"
+         x="670.60638"
+         y="62.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-68"
+         x="670.60638"
+         y="79.288002"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">0,8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="704.62439"
+       y="62.871552"
+       id="text29587-3-4-2-6-9-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-460"
+         x="704.62439"
+         y="62.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-7"
+         x="704.62439"
+         y="79.288002"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">0,9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="735.6662"
+       y="62.871552"
+       id="text29587-3-4-2-6-9-79"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-5"
+         x="735.6662"
+         y="62.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-0"
+         x="735.6662"
+         y="79.288002"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">0,10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="398.29437"
+       y="96.871552"
+       id="text29587-3-4-2-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-4"
+         x="398.29437"
+         y="96.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-2"
+         x="398.29437"
+         y="113.288"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">1,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="770.16425"
+       y="96.775551"
+       id="text29587-3-4-1-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-8-0"
+         x="770.16425"
+         y="96.775551" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-5-4"
+         x="770.16425"
+         y="113.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">1,11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="433.07437"
+       y="96.775551"
+       id="text29587-3-4-2-6-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-6"
+         x="433.07437"
+         y="96.775551" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-1"
+         x="433.07437"
+         y="113.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">1,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="466.42636"
+       y="96.871552"
+       id="text29587-3-4-2-6-9-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-61"
+         x="466.42636"
+         y="96.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-72"
+         x="466.42636"
+         y="113.288"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">1,2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="500.41437"
+       y="96.871552"
+       id="text29587-3-4-2-6-9-0-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-0-5"
+         x="500.41437"
+         y="96.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-6-9"
+         x="500.41437"
+         y="113.288"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">1,3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="534.2464"
+       y="96.775551"
+       id="text29587-3-4-2-6-9-2-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-6-3"
+         x="534.2464"
+         y="96.775551" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-62-1"
+         x="534.2464"
+         y="113.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">1,4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="568.40839"
+       y="96.775551"
+       id="text29587-3-4-2-6-9-1-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-4-1"
+         x="568.40839"
+         y="96.775551" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-67-7"
+         x="568.40839"
+         y="113.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">1,5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="602.29437"
+       y="96.799553"
+       id="text29587-3-4-2-6-9-7-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-8-9"
+         x="602.29437"
+         y="96.799553" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-8-9"
+         x="602.29437"
+         y="113.216"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">1,6</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="636.34839"
+       y="96.775551"
+       id="text29587-3-4-2-6-9-4-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-46-7"
+         x="636.34839"
+         y="96.775551" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-4-9"
+         x="636.34839"
+         y="113.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">1,7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="670.3244"
+       y="96.871552"
+       id="text29587-3-4-2-6-9-75-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-2-7"
+         x="670.3244"
+         y="96.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-68-1"
+         x="670.3244"
+         y="113.288"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">1,8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="704.34235"
+       y="96.871552"
+       id="text29587-3-4-2-6-9-5-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-460-9"
+         x="704.34235"
+         y="96.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-7-9"
+         x="704.34235"
+         y="113.288"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">1,9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="735.38422"
+       y="96.871552"
+       id="text29587-3-4-2-6-9-79-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-5-4"
+         x="735.38422"
+         y="96.871552" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-0-9"
+         x="735.38422"
+         y="113.288"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">1,10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="398.56436"
+       y="130.87155"
+       id="text29587-3-4-2-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-7"
+         x="398.56436"
+         y="130.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-9"
+         x="398.56436"
+         y="147.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="770.4342"
+       y="130.87155"
+       id="text29587-3-4-1-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-8-08"
+         x="770.4342"
+         y="130.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-5-9"
+         x="770.4342"
+         y="147.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2,11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="433.34436"
+       y="130.87155"
+       id="text29587-3-4-2-6-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-4"
+         x="433.34436"
+         y="130.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-82"
+         x="433.34436"
+         y="147.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="466.69638"
+       y="130.87155"
+       id="text29587-3-4-2-6-9-72"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-68"
+         x="466.69638"
+         y="130.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-9"
+         x="466.69638"
+         y="147.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2,2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="500.68439"
+       y="130.87155"
+       id="text29587-3-4-2-6-9-0-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-0-9"
+         x="500.68439"
+         y="130.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-6-0"
+         x="500.68439"
+         y="147.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2,3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="534.51636"
+       y="130.87155"
+       id="text29587-3-4-2-6-9-2-56"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-6-1"
+         x="534.51636"
+         y="130.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-62-13"
+         x="534.51636"
+         y="147.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2,4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="568.67834"
+       y="130.87155"
+       id="text29587-3-4-2-6-9-1-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-4-2"
+         x="568.67834"
+         y="130.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-67-3"
+         x="568.67834"
+         y="147.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2,5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="602.56439"
+       y="130.87155"
+       id="text29587-3-4-2-6-9-7-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-8-4"
+         x="602.56439"
+         y="130.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-8-95"
+         x="602.56439"
+         y="147.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2,6</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="636.61835"
+       y="130.87155"
+       id="text29587-3-4-2-6-9-4-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-46-8"
+         x="636.61835"
+         y="130.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-4-6"
+         x="636.61835"
+         y="147.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2,7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="670.59436"
+       y="130.87155"
+       id="text29587-3-4-2-6-9-75-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-2-8"
+         x="670.59436"
+         y="130.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-68-5"
+         x="670.59436"
+         y="147.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2,8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="704.61237"
+       y="130.87155"
+       id="text29587-3-4-2-6-9-5-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-460-5"
+         x="704.61237"
+         y="130.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-7-92"
+         x="704.61237"
+         y="147.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2,9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="735.65424"
+       y="130.87155"
+       id="text29587-3-4-2-6-9-79-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-5-8"
+         x="735.65424"
+         y="130.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-0-4"
+         x="735.65424"
+         y="147.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">2,10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="398.54639"
+       y="164.87155"
+       id="text29587-3-4-2-68"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-54"
+         x="398.54639"
+         y="164.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-7"
+         x="398.54639"
+         y="181.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="770.4162"
+       y="164.87155"
+       id="text29587-3-4-1-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-8-9"
+         x="770.4162"
+         y="164.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-5-41"
+         x="770.4162"
+         y="181.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3,11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="433.32639"
+       y="164.87155"
+       id="text29587-3-4-2-6-09"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-64"
+         x="433.32639"
+         y="164.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-4"
+         x="433.32639"
+         y="181.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="466.67838"
+       y="164.87155"
+       id="text29587-3-4-2-6-9-01"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-3"
+         x="466.67838"
+         y="164.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-76"
+         x="466.67838"
+         y="181.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3,2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="500.66638"
+       y="164.87155"
+       id="text29587-3-4-2-6-9-0-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-0-4"
+         x="500.66638"
+         y="164.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-6-1"
+         x="500.66638"
+         y="181.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3,3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="534.49835"
+       y="164.87155"
+       id="text29587-3-4-2-6-9-2-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-6-9"
+         x="534.49835"
+         y="164.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-62-5"
+         x="534.49835"
+         y="181.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3,4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="568.6604"
+       y="164.87155"
+       id="text29587-3-4-2-6-9-1-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-4-0"
+         x="568.6604"
+         y="164.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-67-71"
+         x="568.6604"
+         y="181.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3,5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="602.54639"
+       y="164.87155"
+       id="text29587-3-4-2-6-9-7-04"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-8-7"
+         x="602.54639"
+         y="164.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-8-8"
+         x="602.54639"
+         y="181.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3,6</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="636.6004"
+       y="164.87155"
+       id="text29587-3-4-2-6-9-4-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-46-1"
+         x="636.6004"
+         y="164.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-4-5"
+         x="636.6004"
+         y="181.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3,7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="670.57635"
+       y="164.87155"
+       id="text29587-3-4-2-6-9-75-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-2-2"
+         x="670.57635"
+         y="164.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-68-11"
+         x="670.57635"
+         y="181.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3,8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="704.59436"
+       y="164.87155"
+       id="text29587-3-4-2-6-9-5-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-460-1"
+         x="704.59436"
+         y="164.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-7-7"
+         x="704.59436"
+         y="181.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3,9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="735.63623"
+       y="164.87155"
+       id="text29587-3-4-2-6-9-79-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-5-5"
+         x="735.63623"
+         y="164.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-0-90"
+         x="735.63623"
+         y="181.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">3,10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="398.63638"
+       y="198.87155"
+       id="text29587-3-4-2-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-6"
+         x="398.63638"
+         y="198.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-8"
+         x="398.63638"
+         y="215.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">4,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="770.50623"
+       y="198.77556"
+       id="text29587-3-4-1-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-8-2"
+         x="770.50623"
+         y="198.77556" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-5-90"
+         x="770.50623"
+         y="215.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">4,11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="433.41638"
+       y="198.77556"
+       id="text29587-3-4-2-6-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-41"
+         x="433.41638"
+         y="198.77556" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-3"
+         x="433.41638"
+         y="215.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">4,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="466.76837"
+       y="198.87155"
+       id="text29587-3-4-2-6-9-42"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-30"
+         x="466.76837"
+         y="198.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-1"
+         x="466.76837"
+         y="215.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">4,2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="500.75638"
+       y="198.87155"
+       id="text29587-3-4-2-6-9-0-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-0-1"
+         x="500.75638"
+         y="198.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-6-4"
+         x="500.75638"
+         y="215.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">4,3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="534.58838"
+       y="198.77556"
+       id="text29587-3-4-2-6-9-2-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-6-16"
+         x="534.58838"
+         y="198.77556" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-62-0"
+         x="534.58838"
+         y="215.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">4,4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="568.75037"
+       y="198.77556"
+       id="text29587-3-4-2-6-9-1-40"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-4-13"
+         x="568.75037"
+         y="198.77556" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-67-1"
+         x="568.75037"
+         y="215.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">4,5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="602.63635"
+       y="198.79955"
+       id="text29587-3-4-2-6-9-7-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-8-2"
+         x="602.63635"
+         y="198.79955" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-8-1"
+         x="602.63635"
+         y="215.21599"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">4,6</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="636.69037"
+       y="198.77556"
+       id="text29587-3-4-2-6-9-4-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-46-0"
+         x="636.69037"
+         y="198.77556" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-4-0"
+         x="636.69037"
+         y="215.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">4,7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="670.66638"
+       y="198.87155"
+       id="text29587-3-4-2-6-9-75-43"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-2-1"
+         x="670.66638"
+         y="198.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-68-6"
+         x="670.66638"
+         y="215.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">4,8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="704.68439"
+       y="198.87155"
+       id="text29587-3-4-2-6-9-5-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-460-8"
+         x="704.68439"
+         y="198.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-7-72"
+         x="704.68439"
+         y="215.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">4,9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="735.7262"
+       y="198.87155"
+       id="text29587-3-4-2-6-9-79-21"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-5-54"
+         x="735.7262"
+         y="198.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-0-2"
+         x="735.7262"
+         y="215.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">4,10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="398.49237"
+       y="232.87155"
+       id="text29587-3-4-2-95"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-8"
+         x="398.49237"
+         y="232.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-08"
+         x="398.49237"
+         y="249.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">5,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="770.36224"
+       y="232.77556"
+       id="text29587-3-4-1-60"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-8-27"
+         x="770.36224"
+         y="232.77556" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-5-45"
+         x="770.36224"
+         y="249.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">5,11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="433.27237"
+       y="232.77556"
+       id="text29587-3-4-2-6-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-3"
+         x="433.27237"
+         y="232.77556" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-9"
+         x="433.27237"
+         y="249.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">5,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="466.62439"
+       y="232.87155"
+       id="text29587-3-4-2-6-9-23"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-24"
+         x="466.62439"
+         y="232.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-95"
+         x="466.62439"
+         y="249.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">5,2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="500.61237"
+       y="232.87155"
+       id="text29587-3-4-2-6-9-0-56"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-0-3"
+         x="500.61237"
+         y="232.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-6-3"
+         x="500.61237"
+         y="249.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">5,3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="534.4444"
+       y="232.77556"
+       id="text29587-3-4-2-6-9-2-55"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-6-7"
+         x="534.4444"
+         y="232.77556" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-62-7"
+         x="534.4444"
+         y="249.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">5,4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="568.60638"
+       y="232.77556"
+       id="text29587-3-4-2-6-9-1-31"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-4-14"
+         x="568.60638"
+         y="232.77556" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-67-9"
+         x="568.60638"
+         y="249.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">5,5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="602.49237"
+       y="232.79955"
+       id="text29587-3-4-2-6-9-7-047"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-8-6"
+         x="602.49237"
+         y="232.79955" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-8-6"
+         x="602.49237"
+         y="249.21599"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">5,6</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="636.54639"
+       y="232.77556"
+       id="text29587-3-4-2-6-9-4-05"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-46-05"
+         x="636.54639"
+         y="232.77556" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-4-65"
+         x="636.54639"
+         y="249.192"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">5,7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="670.5224"
+       y="232.87155"
+       id="text29587-3-4-2-6-9-75-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-2-0"
+         x="670.5224"
+         y="232.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-68-0"
+         x="670.5224"
+         y="249.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">5,8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="704.54041"
+       y="232.87155"
+       id="text29587-3-4-2-6-9-5-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-460-4"
+         x="704.54041"
+         y="232.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-7-0"
+         x="704.54041"
+         y="249.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">5,9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="735.58221"
+       y="232.87155"
+       id="text29587-3-4-2-6-9-79-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-5-9"
+         x="735.58221"
+         y="232.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-0-8"
+         x="735.58221"
+         y="249.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">5,10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="398.52237"
+       y="266.87155"
+       id="text29587-3-4-2-953"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-74"
+         x="398.52237"
+         y="266.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-02"
+         x="398.52237"
+         y="283.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">6,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="770.39221"
+       y="266.79956"
+       id="text29587-3-4-1-82"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-8-6"
+         x="770.39221"
+         y="266.79956" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-5-7"
+         x="770.39221"
+         y="283.216"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">6,11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="433.30237"
+       y="266.79956"
+       id="text29587-3-4-2-6-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-2"
+         x="433.30237"
+         y="266.79956" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-42"
+         x="433.30237"
+         y="283.216"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">6,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="466.65439"
+       y="266.87155"
+       id="text29587-3-4-2-6-9-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-48"
+         x="466.65439"
+         y="266.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-12"
+         x="466.65439"
+         y="283.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">6,2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="500.64236"
+       y="266.87155"
+       id="text29587-3-4-2-6-9-0-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-0-8"
+         x="500.64236"
+         y="266.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-6-14"
+         x="500.64236"
+         y="283.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">6,3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="534.47437"
+       y="266.79956"
+       id="text29587-3-4-2-6-9-2-90"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-6-0"
+         x="534.47437"
+         y="266.79956" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-62-9"
+         x="534.47437"
+         y="283.216"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">6,4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="568.63635"
+       y="266.79956"
+       id="text29587-3-4-2-6-9-1-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-4-19"
+         x="568.63635"
+         y="266.79956" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-67-76"
+         x="568.63635"
+         y="283.216"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">6,5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="602.5224"
+       y="266.79956"
+       id="text29587-3-4-2-6-9-7-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-8-43"
+         x="602.5224"
+         y="266.79956" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-8-5"
+         x="602.5224"
+         y="283.216"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">6,6</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="636.57635"
+       y="266.79956"
+       id="text29587-3-4-2-6-9-4-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-46-17"
+         x="636.57635"
+         y="266.79956" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-4-4"
+         x="636.57635"
+         y="283.216"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">6,7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="670.55237"
+       y="266.87155"
+       id="text29587-3-4-2-6-9-75-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-2-3"
+         x="670.55237"
+         y="266.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-68-62"
+         x="670.55237"
+         y="283.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">6,8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="704.57037"
+       y="266.87155"
+       id="text29587-3-4-2-6-9-5-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-460-59"
+         x="704.57037"
+         y="266.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-7-3"
+         x="704.57037"
+         y="283.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">6,9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="735.61224"
+       y="266.87155"
+       id="text29587-3-4-2-6-9-79-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-5-3"
+         x="735.61224"
+         y="266.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-0-96"
+         x="735.61224"
+         y="283.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">6,10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="398.51639"
+       y="300.87155"
+       id="text29587-3-4-2-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-55"
+         x="398.51639"
+         y="300.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-4"
+         x="398.51639"
+         y="317.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">7,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="770.38623"
+       y="300.77554"
+       id="text29587-3-4-1-76"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-8-29"
+         x="770.38623"
+         y="300.77554" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-5-5"
+         x="770.38623"
+         y="317.19199"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">7,11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="433.29639"
+       y="300.77554"
+       id="text29587-3-4-2-6-97"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-8"
+         x="433.29639"
+         y="300.77554" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-6"
+         x="433.29639"
+         y="317.19199"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">7,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="466.64838"
+       y="300.87155"
+       id="text29587-3-4-2-6-9-03"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-21"
+         x="466.64838"
+         y="300.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-2"
+         x="466.64838"
+         y="317.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">7,2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="500.63638"
+       y="300.87155"
+       id="text29587-3-4-2-6-9-0-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-0-95"
+         x="500.63638"
+         y="300.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-6-5"
+         x="500.63638"
+         y="317.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">7,3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="534.46838"
+       y="300.77554"
+       id="text29587-3-4-2-6-9-2-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-6-2"
+         x="534.46838"
+         y="300.77554" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-62-2"
+         x="534.46838"
+         y="317.19199"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">7,4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="568.63037"
+       y="300.77554"
+       id="text29587-3-4-2-6-9-1-38"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-4-06"
+         x="568.63037"
+         y="300.77554" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-67-77"
+         x="568.63037"
+         y="317.19199"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">7,5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="602.51636"
+       y="300.79956"
+       id="text29587-3-4-2-6-9-7-05"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-8-46"
+         x="602.51636"
+         y="300.79956" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-8-2"
+         x="602.51636"
+         y="317.216"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">7,6</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="636.57037"
+       y="300.77554"
+       id="text29587-3-4-2-6-9-4-18"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-46-3"
+         x="636.57037"
+         y="300.77554" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-4-67"
+         x="636.57037"
+         y="317.19199"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">7,7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="670.54639"
+       y="300.87155"
+       id="text29587-3-4-2-6-9-75-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-2-6"
+         x="670.54639"
+         y="300.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-68-51"
+         x="670.54639"
+         y="317.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">7,8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="704.56439"
+       y="300.87155"
+       id="text29587-3-4-2-6-9-5-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-460-83"
+         x="704.56439"
+         y="300.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-7-37"
+         x="704.56439"
+         y="317.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">7,9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="735.6062"
+       y="300.87155"
+       id="text29587-3-4-2-6-9-79-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-5-0"
+         x="735.6062"
+         y="300.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-0-40"
+         x="735.6062"
+         y="317.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">7,10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="398.54639"
+       y="334.87155"
+       id="text29587-3-4-2-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-75"
+         x="398.54639"
+         y="334.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-3"
+         x="398.54639"
+         y="351.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">8,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="770.4162"
+       y="334.87155"
+       id="text29587-3-4-1-71"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-8-26"
+         x="770.4162"
+         y="334.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-5-3"
+         x="770.4162"
+         y="351.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">8,11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="433.32639"
+       y="334.87155"
+       id="text29587-3-4-2-6-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-31"
+         x="433.32639"
+         y="334.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-2"
+         x="433.32639"
+         y="351.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">8,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="466.67838"
+       y="334.87155"
+       id="text29587-3-4-2-6-9-49"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-52"
+         x="466.67838"
+         y="334.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-96"
+         x="466.67838"
+         y="351.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">8,2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="500.66638"
+       y="334.87155"
+       id="text29587-3-4-2-6-9-0-14"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-0-0"
+         x="500.66638"
+         y="334.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-6-2"
+         x="500.66638"
+         y="351.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">8,3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="534.49835"
+       y="334.87155"
+       id="text29587-3-4-2-6-9-2-45"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-6-8"
+         x="534.49835"
+         y="334.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-62-3"
+         x="534.49835"
+         y="351.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">8,4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="568.6604"
+       y="334.87155"
+       id="text29587-3-4-2-6-9-1-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-4-08"
+         x="568.6604"
+         y="334.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-67-2"
+         x="568.6604"
+         y="351.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">8,5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="602.54639"
+       y="334.87155"
+       id="text29587-3-4-2-6-9-7-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-8-5"
+         x="602.54639"
+         y="334.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-8-7"
+         x="602.54639"
+         y="351.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">8,6</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="636.6004"
+       y="334.87155"
+       id="text29587-3-4-2-6-9-4-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-46-4"
+         x="636.6004"
+         y="334.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-4-1"
+         x="636.6004"
+         y="351.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">8,7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="670.57635"
+       y="334.87155"
+       id="text29587-3-4-2-6-9-75-13"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-2-60"
+         x="670.57635"
+         y="334.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-68-68"
+         x="670.57635"
+         y="351.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">8,8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="704.59436"
+       y="334.87155"
+       id="text29587-3-4-2-6-9-5-20"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-460-90"
+         x="704.59436"
+         y="334.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-7-4"
+         x="704.59436"
+         y="351.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">8,9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="735.63623"
+       y="334.87155"
+       id="text29587-3-4-2-6-9-79-88"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-5-55"
+         x="735.63623"
+         y="334.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-0-80"
+         x="735.63623"
+         y="351.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">8,10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="770.44623"
+       y="368.87155"
+       id="text29587-3-4-1-71-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-8-26-5"
+         x="770.44623"
+         y="368.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-5-3-8"
+         x="770.44623"
+         y="385.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">9,11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="433.35638"
+       y="368.87155"
+       id="text29587-3-4-2-6-7-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-31-7"
+         x="433.35638"
+         y="368.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-2-4"
+         x="433.35638"
+         y="385.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">9,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="466.70837"
+       y="368.87155"
+       id="text29587-3-4-2-6-9-49-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-52-4"
+         x="466.70837"
+         y="368.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-96-2"
+         x="466.70837"
+         y="385.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">9,2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="500.69638"
+       y="368.87155"
+       id="text29587-3-4-2-6-9-0-14-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-0-0-7"
+         x="500.69638"
+         y="368.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-6-2-5"
+         x="500.69638"
+         y="385.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">9,3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="534.52838"
+       y="368.87155"
+       id="text29587-3-4-2-6-9-2-45-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-6-8-4"
+         x="534.52838"
+         y="368.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-62-3-6"
+         x="534.52838"
+         y="385.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">9,4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="568.69037"
+       y="368.87155"
+       id="text29587-3-4-2-6-9-1-9-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-4-08-2"
+         x="568.69037"
+         y="368.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-67-2-0"
+         x="568.69037"
+         y="385.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">9,5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="602.57635"
+       y="368.87155"
+       id="text29587-3-4-2-6-9-7-5-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-8-5-1"
+         x="602.57635"
+         y="368.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-8-7-2"
+         x="602.57635"
+         y="385.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">9,6</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="636.63037"
+       y="368.87155"
+       id="text29587-3-4-2-6-9-4-8-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-46-4-2"
+         x="636.63037"
+         y="368.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-4-1-1"
+         x="636.63037"
+         y="385.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">9,7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="670.60638"
+       y="368.87155"
+       id="text29587-3-4-2-6-9-75-13-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-2-60-9"
+         x="670.60638"
+         y="368.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-68-68-9"
+         x="670.60638"
+         y="385.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">9,8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="704.62439"
+       y="368.87155"
+       id="text29587-3-4-2-6-9-5-20-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-460-90-0"
+         x="704.62439"
+         y="368.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-7-4-5"
+         x="704.62439"
+         y="385.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">9,9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="735.6662"
+       y="368.87155"
+       id="text29587-3-4-2-6-9-79-88-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-5-55-7"
+         x="735.6662"
+         y="368.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-0-80-2"
+         x="735.6662"
+         y="385.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">9,10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="398.57639"
+       y="368.87155"
+       id="text29587-3-4-2-5-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-75-3"
+         x="398.57639"
+         y="368.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-3-8"
+         x="398.57639"
+         y="385.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">9,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="395.38422"
+       y="402.87155"
+       id="text29587-3-4-2-5-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-75-2"
+         x="395.38422"
+         y="402.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-3-9"
+         x="395.38422"
+         y="419.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">10,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="767.25409"
+       y="402.87155"
+       id="text29587-3-4-1-71-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-8-26-4"
+         x="767.25409"
+         y="402.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-5-3-5"
+         x="767.25409"
+         y="419.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">10,11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="430.16422"
+       y="402.87155"
+       id="text29587-3-4-2-6-7-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-31-1"
+         x="430.16422"
+         y="402.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-2-3"
+         x="430.16422"
+         y="419.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">10,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="463.5162"
+       y="402.87155"
+       id="text29587-3-4-2-6-9-49-22"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-52-9"
+         x="463.5162"
+         y="402.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-96-0"
+         x="463.5162"
+         y="419.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">10,2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="497.50421"
+       y="402.87155"
+       id="text29587-3-4-2-6-9-0-14-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-0-0-1"
+         x="497.50421"
+         y="402.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-6-2-2"
+         x="497.50421"
+         y="419.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">10,3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="531.33624"
+       y="402.87155"
+       id="text29587-3-4-2-6-9-2-45-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-6-8-45"
+         x="531.33624"
+         y="402.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-62-3-1"
+         x="531.33624"
+         y="419.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">10,4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="565.49823"
+       y="402.87155"
+       id="text29587-3-4-2-6-9-1-9-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-4-08-8"
+         x="565.49823"
+         y="402.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-67-2-1"
+         x="565.49823"
+         y="419.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">10,5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="599.38422"
+       y="402.87155"
+       id="text29587-3-4-2-6-9-7-5-79"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-8-5-0"
+         x="599.38422"
+         y="402.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-8-7-8"
+         x="599.38422"
+         y="419.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">10,6</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="633.43823"
+       y="402.87155"
+       id="text29587-3-4-2-6-9-4-8-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-46-4-0"
+         x="633.43823"
+         y="402.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-4-1-5"
+         x="633.43823"
+         y="419.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">10,7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="667.41425"
+       y="402.87155"
+       id="text29587-3-4-2-6-9-75-13-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-2-60-8"
+         x="667.41425"
+         y="402.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-68-68-0"
+         x="667.41425"
+         y="419.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">10,8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="701.43219"
+       y="402.87155"
+       id="text29587-3-4-2-6-9-5-20-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-460-90-04"
+         x="701.43219"
+         y="402.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-7-4-58"
+         x="701.43219"
+         y="419.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">10,9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="732.47406"
+       y="402.87155"
+       id="text29587-3-4-2-6-9-79-88-70"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-5-55-2"
+         x="732.47406"
+         y="402.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-0-80-29"
+         x="732.47406"
+         y="419.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">10,10</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="395.38422"
+       y="436.87155"
+       id="text29587-3-4-2-5-6-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-75-2-2"
+         x="395.38422"
+         y="436.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-3-9-2"
+         x="395.38422"
+         y="453.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">11,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="767.25409"
+       y="436.77554"
+       id="text29587-3-4-1-71-2-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-8-26-4-9"
+         x="767.25409"
+         y="436.77554" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-5-3-5-6"
+         x="767.25409"
+         y="453.19199"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">11,11</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="430.16422"
+       y="436.77554"
+       id="text29587-3-4-2-6-7-6-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-31-1-1"
+         x="430.16422"
+         y="436.77554" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-2-3-5"
+         x="430.16422"
+         y="453.19199"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">11,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="463.5162"
+       y="436.87155"
+       id="text29587-3-4-2-6-9-49-22-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-52-9-4"
+         x="463.5162"
+         y="436.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-96-0-4"
+         x="463.5162"
+         y="453.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">11,2</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="497.50421"
+       y="436.87155"
+       id="text29587-3-4-2-6-9-0-14-0-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-0-0-1-4"
+         x="497.50421"
+         y="436.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-6-2-2-2"
+         x="497.50421"
+         y="453.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">11,3</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="531.33624"
+       y="436.77554"
+       id="text29587-3-4-2-6-9-2-45-7-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-6-8-45-4"
+         x="531.33624"
+         y="436.77554" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-62-3-1-0"
+         x="531.33624"
+         y="453.19199"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">11,4</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="565.49823"
+       y="436.77554"
+       id="text29587-3-4-2-6-9-1-9-8-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-4-08-8-2"
+         x="565.49823"
+         y="436.77554" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-67-2-1-2"
+         x="565.49823"
+         y="453.19199"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">11,5</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="599.38422"
+       y="436.79956"
+       id="text29587-3-4-2-6-9-7-5-79-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-8-5-0-4"
+         x="599.38422"
+         y="436.79956" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-8-7-8-8"
+         x="599.38422"
+         y="453.216"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">11,6</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="633.43823"
+       y="436.77554"
+       id="text29587-3-4-2-6-9-4-8-4-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-46-4-0-3"
+         x="633.43823"
+         y="436.77554" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-4-1-5-8"
+         x="633.43823"
+         y="453.19199"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">11,7</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="667.41425"
+       y="436.87155"
+       id="text29587-3-4-2-6-9-75-13-6-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-2-60-8-5"
+         x="667.41425"
+         y="436.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-68-68-0-0"
+         x="667.41425"
+         y="453.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">11,8</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="701.43219"
+       y="436.87155"
+       id="text29587-3-4-2-6-9-5-20-7-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-460-90-04-0"
+         x="701.43219"
+         y="436.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-7-4-58-2"
+         x="701.43219"
+         y="453.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">11,9</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="732.47406"
+       y="436.87155"
+       id="text29587-3-4-2-6-9-79-88-70-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan29589-0-1-4-5-7-5-55-2-7"
+         x="732.47406"
+         y="436.87155" /><tspan
+         sodipodi:role="line"
+         id="tspan29591-5-0-3-0-8-0-80-29-3"
+         x="732.47406"
+         y="453.28799"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:500;font-stretch:normal;letter-spacing:-1px;font-family:Ubuntu;-inkscape-font-specification:Ubuntu Medium">11,10</tspan></text>
+  </g>
+</svg>
diff --git a/_images/mixed_assembly.svg b/_images/mixed_assembly.svg
new file mode 100644
index 000000000..94f08d5c0
--- /dev/null
+++ b/_images/mixed_assembly.svg
@@ -0,0 +1,3703 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:ns0="http://www.iki.fi/pav/software/textext/"
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:xlink="http://www.w3.org/1999/xlink"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="420"
+   height="280"
+   id="svg91417"
+   version="1.1"
+   inkscape:version="0.48.4 r9939"
+   sodipodi:docname="mixed_assembly.svg">
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="2.6939502"
+     inkscape:cx="179.14653"
+     inkscape:cy="138.03898"
+     inkscape:current-layer="layer9"
+     inkscape:document-units="px"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     inkscape:window-width="1920"
+     inkscape:window-height="1043"
+     inkscape:window-x="0"
+     inkscape:window-y="1098"
+     inkscape:window-maximized="0"
+     borderlayer="true">
+    <inkscape:grid
+       id="grid91425"
+       type="xygrid"
+       empspacing="5"
+       visible="true"
+       enabled="true"
+       snapvisiblegridlinesonly="true" />
+    <sodipodi:guide
+       id="guide91596"
+       position="0,10"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide91598"
+       position="40,180"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide91600"
+       position="0,30"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide91602"
+       position="280,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10739"
+       position="60,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10741"
+       position="80,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10743"
+       position="100,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10745"
+       position="120,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10749"
+       position="160,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10751"
+       position="180,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10753"
+       position="200,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10755"
+       position="220,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10757"
+       position="240,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10759"
+       position="260,280"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide10761"
+       position="0,250"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10763"
+       position="0,230"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10765"
+       position="0,50"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10767"
+       position="0,70"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10769"
+       position="0,90"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10771"
+       position="0,110"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10775"
+       position="0,150"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10777"
+       position="0,170"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10779"
+       position="0,190"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide10781"
+       position="0,210"
+       orientation="0,1" />
+    <sodipodi:guide
+       id="guide11285"
+       position="760,380"
+       orientation="1,0" />
+    <sodipodi:guide
+       id="guide11287"
+       position="730,390"
+       orientation="1,0" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="140,280"
+       id="guide33937" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,130"
+       id="guide33941" />
+  </sodipodi:namedview>
+  <defs
+     id="defs91419">
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow1Mend"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow1Mend">
+      <path
+         transform="matrix(-0.4,0,0,-0.4,-4,0)"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt"
+         d="M 0,0 5,-5 -12.5,0 5,5 0,0 z"
+         id="path12664"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="DotM"
+       style="overflow:visible">
+      <path
+         id="path21623"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91297"
+       style="overflow:visible">
+      <path
+         id="path91299"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91301"
+       style="overflow:visible">
+      <path
+         id="path91303"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91305"
+       style="overflow:visible">
+      <path
+         id="path91307"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91309"
+       style="overflow:visible">
+      <path
+         id="path91311"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91313"
+       style="overflow:visible">
+      <path
+         id="path91315"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker6626"
+       style="overflow:visible">
+      <path
+         id="path6628"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91319"
+       style="overflow:visible">
+      <path
+         id="path91321"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91323"
+       style="overflow:visible">
+      <path
+         id="path91325"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91327"
+       style="overflow:visible">
+      <path
+         id="path91329"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91331"
+       style="overflow:visible">
+      <path
+         id="path91333"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91335"
+       style="overflow:visible">
+      <path
+         id="path91337"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91339"
+       style="overflow:visible">
+      <path
+         id="path91341"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91343"
+       style="overflow:visible">
+      <path
+         id="path91345"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91347"
+       style="overflow:visible">
+      <path
+         id="path91349"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91351"
+       style="overflow:visible">
+      <path
+         id="path91353"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91355"
+       style="overflow:visible">
+      <path
+         id="path91357"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker91359"
+       style="overflow:visible">
+      <path
+         id="path91361"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="DotM-8"
+       style="overflow:visible">
+      <path
+         id="path21623-3"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="DotM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker11181"
+       style="overflow:visible">
+      <path
+         id="path11183"
+         d="m -2.5,-1 c 0,2.76 -2.24,5 -5,5 -2.76,0 -5,-2.24 -5,-5 0,-2.76 2.24,-5 5,-5 2.76,0 5,2.24 5,5 z"
+         style="fill-rule:evenodd;stroke:#000000;stroke-width:1pt;marker-start:none;marker-end:none"
+         transform="matrix(0.4,0,0,0.4,2.96,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-7"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-3"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-2"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-1"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-5"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-4"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-3"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-6"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-50"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-9"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-6"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-42"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-64"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-92"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-55"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-17"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-0"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-7"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-1"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-90"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-51"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-95"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="Arrow2Mend-4"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="Arrow2Mend">
+      <path
+         transform="scale(-0.6,-0.6)"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         id="path12682-68"
+         inkscape:connector-curvature="0" />
+    </marker>
+  </defs>
+  <metadata
+     id="metadata91422">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     style="display:inline"
+     inkscape:groupmode="layer"
+     inkscape:label="grey matrix"
+     id="layer1"
+     transform="translate(0,-320)">
+    <rect
+       y="570"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10940"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10954"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10956"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10958"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10960"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10966"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10968"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10974"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10976"
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer7"
+     inkscape:label="block10"
+     style="display:inline">
+    <rect
+       transform="translate(0,-320)"
+       y="530"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10859"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="510.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10861"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="530"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10863"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="510.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10865"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="530"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10869"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="510.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10871"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="570"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10920"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="570"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10922"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="570"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10924"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="510.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10932"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="530"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10934"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="570"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10936"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="570"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10962"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="570"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10964"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="530"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10970"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="530"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10972"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="510.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10978"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="510.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10980"
+       style="fill:#ad7fa8;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer6"
+     inkscape:label="block01"
+     style="display:inline">
+    <rect
+       transform="translate(0,-320)"
+       y="350.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10819"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="370.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10821"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="390.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10823"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="350.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10825"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="370.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10827"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="390.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10829"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="350.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10831"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="370.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10833"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="390.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10835"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="430.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10938"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="430.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10942"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="430.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10944"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="470"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10950"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="490.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect10952"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="490.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10982"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="490.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10984"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="470"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect10990"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="470"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect10992"
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer2"
+     inkscape:label="block00"
+     style="display:inline">
+    <rect
+       transform="translate(0,-320)"
+       y="350.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10783"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="370.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10785"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="390.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10787"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="350.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10789"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="370.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10791"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="390.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10793"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="350.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10795"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="370.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10797"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="390.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10799"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="350.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10801"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="370.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10803"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="390.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10805"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="350.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10807"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="370.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10809"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="390.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10811"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="350.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10813"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="370.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10815"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="390.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10817"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="430.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10837"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="430.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10843"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="430.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10845"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="470"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10847"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="470"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10849"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="470"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10851"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="490.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect10853"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="490.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect10855"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="490.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect10857"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="430.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10926"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="470"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10928"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="490.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect10930"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="430.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10946"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="430.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10948"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="490.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10986"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="490.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10988"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="470"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect10994"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="470"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect10996"
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+  </g>
+  <g
+     inkscape:label="red matrix"
+     id="layer3"
+     inkscape:groupmode="layer"
+     transform="translate(0,-320)">
+    <rect
+       y="350.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect10999"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11001"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11003"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect11005"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect11007"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect11009"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11011"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11013"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="350.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11015"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11017"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11019"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect11021"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect11023"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect11025"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect11027"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect11029"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="350.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11031"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="370.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11033"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="390.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11035"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="410"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect11037"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="430.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11039"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect11041"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect11043"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect11045"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect11047"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect11049"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect11051"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect11053"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect11055"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="450.00003"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect11057"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11059"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11061"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11063"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11065"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11067"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="260"
+       height="19.999996"
+       width="20"
+       id="rect11069"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="220.00002"
+       height="19.999996"
+       width="20"
+       id="rect11071"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="200"
+       height="19.999996"
+       width="20"
+       id="rect11073"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="180"
+       height="19.999996"
+       width="20"
+       id="rect11075"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="160"
+       height="19.999996"
+       width="20"
+       id="rect11077"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11079"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11081"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11083"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11085"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="470"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11087"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="490.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11089"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="510.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11091"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="530"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11093"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11095"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="570"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11097"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="119.99999"
+       height="19.999996"
+       width="20"
+       id="rect11099"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="80"
+       height="19.999996"
+       width="20"
+       id="rect11101"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="60"
+       height="19.999996"
+       width="20"
+       id="rect11103"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       y="550"
+       x="40"
+       height="19.999996"
+       width="20"
+       id="rect11105"
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     style="display:inline"
+     inkscape:label="assemble11"
+     id="layer4"
+     inkscape:groupmode="layer"
+     transform="translate(0,-320)">
+    <rect
+       y="550"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11126"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer12"
+     inkscape:label="assemble10">
+    <rect
+       transform="translate(0,-320)"
+       y="550"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11118"
+       style="display:inline;fill:#5c3566;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       transform="translate(0,-320)"
+       y="550"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11120"
+       style="display:inline;fill:#5c3566;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer11"
+     inkscape:label="assemble01">
+    <rect
+       transform="translate(0,-320)"
+       y="410"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11122"
+       style="display:inline;fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       transform="translate(0,-320)"
+       y="450.00003"
+       x="240"
+       height="19.999996"
+       width="20"
+       id="rect11124"
+       style="display:inline;fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer10"
+     inkscape:label="assemble00">
+    <rect
+       transform="translate(0,-320)"
+       y="410"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11108"
+       style="display:inline;fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       transform="translate(0,-320)"
+       y="410"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11110"
+       style="display:inline;fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       transform="translate(0,-320)"
+       y="450.00003"
+       x="100"
+       height="19.999996"
+       width="20"
+       id="rect11114"
+       style="display:inline;fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       transform="translate(0,-320)"
+       y="450.00003"
+       x="140"
+       height="19.999996"
+       width="20"
+       id="rect11116"
+       style="display:inline;fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     style="display:inline"
+     inkscape:label="local11"
+     id="layer5"
+     inkscape:groupmode="layer"
+     transform="translate(0,-320)">
+    <rect
+       y="490.04489"
+       x="380.4729"
+       height="30"
+       width="30"
+       id="rect11122-26"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer14"
+     inkscape:label="local10">
+    <rect
+       transform="translate(0,-320)"
+       y="490.04489"
+       x="320.4729"
+       height="30"
+       width="30"
+       id="rect11122-1"
+       style="display:inline;fill:#5c3566;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       transform="translate(0,-320)"
+       y="490.04489"
+       x="350.4729"
+       height="30"
+       width="30"
+       id="rect11122-6"
+       style="display:inline;fill:#5c3566;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer13"
+     inkscape:label="local01">
+    <rect
+       transform="translate(0,-320)"
+       y="430.04489"
+       x="380.4729"
+       height="30"
+       width="30"
+       id="rect11122-4"
+       style="display:inline;fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+    <rect
+       transform="translate(0,-320)"
+       y="460.04489"
+       x="380.4729"
+       height="30"
+       width="30"
+       id="rect11122-2"
+       style="display:inline;fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer8"
+     inkscape:label="local00"
+     style="display:inline">
+    <rect
+       transform="translate(0,-320)"
+       y="430.04489"
+       x="320.4729"
+       height="30"
+       width="30"
+       id="rect11122-9"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="430.04489"
+       x="350.4729"
+       height="30"
+       width="30"
+       id="rect11122-8"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="460.04489"
+       x="320.4729"
+       height="30"
+       width="30"
+       id="rect11122-82"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+    <rect
+       transform="translate(0,-320)"
+       y="460.04489"
+       x="350.4729"
+       height="30"
+       width="30"
+       id="rect11122-40"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
+  </g>
+  <g
+     style="display:inline"
+     inkscape:label="matrix labels"
+     id="layer9"
+     inkscape:groupmode="layer"
+     transform="translate(0,-320)">
+    <path
+       sodipodi:nodetypes="cc"
+       inkscape:connector-curvature="0"
+       id="path14850"
+       d="m 395.10259,505.04491 c 0.66559,34.40494 -39.54344,55.31254 -144.11771,54.96592"
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend-4)" />
+    <g
+       transform="matrix(1.7910448,0,0,1.7910448,-68.987823,182.54147)"
+       ns0:text="$0$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       id="g22235">
+      <defs
+         id="defs22237">
+        <g
+           id="g22239">
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-df25895d-0">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path22242" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-df25895d-1">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 4.578125,-3.1875 c 0,-0.796875 -0.046875,-1.59375 -0.390625,-2.328125 -0.453125,-0.96875 -1.28125,-1.125 -1.6875,-1.125 -0.609375,0 -1.328125,0.265625 -1.75,1.1875 -0.3125,0.6875 -0.359375,1.46875 -0.359375,2.265625 0,0.75 0.03125,1.640625 0.453125,2.40625 0.421875,0.796875 1.15625,1 1.640625,1 0.53125,0 1.296875,-0.203125 1.734375,-1.15625 0.3125,-0.6875 0.359375,-1.46875 0.359375,-2.25 z M 2.484375,0 C 2.09375,0 1.5,-0.25 1.328125,-1.203125 1.21875,-1.796875 1.21875,-2.71875 1.21875,-3.3125 c 0,-0.640625 0,-1.296875 0.078125,-1.828125 0.1875,-1.1875 0.9375,-1.28125 1.1875,-1.28125 0.328125,0 0.984375,0.1875 1.171875,1.171875 0.109375,0.5625 0.109375,1.3125 0.109375,1.9375 0,0.75 0,1.421875 -0.109375,2.0625 C 3.5,-0.296875 2.9375,0 2.484375,0 z"
+               id="path22245" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-df25895d-2">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g22248">
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-df25895d-1"
+             x="223.43201"
+             y="134.765"
+             id="use22250" />
+        </g>
+      </g>
+    </g>
+    <g
+       id="g23265"
+       style="display:inline"
+       transform="matrix(1.7910448,0,0,1.7910448,-39.722973,182.93326)"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       ns0:text="$1$">
+      <defs
+         id="defs23267">
+        <g
+           id="g23269">
+          <symbol
+             id="textext-c16aad89-0"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path23272"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-c16aad89-1"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path23275"
+               d="m 2.9375,-6.375 c 0,-0.25 0,-0.265625 -0.234375,-0.265625 C 2.078125,-6 1.203125,-6 0.890625,-6 l 0,0.3125 c 0.203125,0 0.78125,0 1.296875,-0.265625 l 0,5.171875 c 0,0.359375 -0.03125,0.46875 -0.921875,0.46875 l -0.3125,0 0,0.3125 c 0.34375,-0.03125 1.203125,-0.03125 1.609375,-0.03125 0.390625,0 1.265625,0 1.609375,0.03125 l 0,-0.3125 -0.3125,0 c -0.90625,0 -0.921875,-0.109375 -0.921875,-0.46875 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-c16aad89-2">
+        <g
+           id="g23278"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use23280"
+             y="134.765"
+             x="223.43201"
+             xlink:href="#textext-c16aad89-1"
+             width="800"
+             height="600" />
+        </g>
+      </g>
+    </g>
+    <g
+       ns0:text="$2$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       transform="matrix(1.7910448,0,0,1.7910448,-9.0130194,182.93326)"
+       style="display:inline"
+       id="g24285">
+      <defs
+         id="defs24287">
+        <g
+           id="g24289">
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-97b990b5-0">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path24292" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-97b990b5-1">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 1.265625,-0.765625 1.0625,-1.03125 c 1.546875,-1.375 2.140625,-1.90625 2.140625,-2.90625 0,-1.140625 -0.890625,-1.9375 -2.109375,-1.9375 -1.125,0 -1.859375,0.921875 -1.859375,1.8125 0,0.546875 0.5,0.546875 0.53125,0.546875 0.171875,0 0.515625,-0.109375 0.515625,-0.53125 0,-0.25 -0.1875,-0.515625 -0.53125,-0.515625 -0.078125,0 -0.09375,0 -0.125,0.015625 0.21875,-0.65625 0.765625,-1.015625 1.34375,-1.015625 0.90625,0 1.328125,0.8125 1.328125,1.625 C 3.5625,-3.90625 3.078125,-3.125 2.515625,-2.5 l -1.90625,2.125 C 0.5,-0.265625 0.5,-0.234375 0.5,0 l 3.703125,0 0.265625,-1.734375 -0.234375,0 C 4.171875,-1.4375 4.109375,-1 4,-0.84375 3.9375,-0.765625 3.28125,-0.765625 3.0625,-0.765625 z"
+               id="path24295" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-97b990b5-2">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g24298">
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-97b990b5-1"
+             x="223.43201"
+             y="134.765"
+             id="use24300" />
+        </g>
+      </g>
+    </g>
+    <g
+       transform="matrix(1.7910448,0,0,1.7910448,-93.836934,209.53037)"
+       ns0:text="$0$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       id="g22235-7"
+       style="display:inline">
+      <defs
+         id="defs22237-6">
+        <g
+           id="g22239-2">
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-df25895d-0-3">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path22242-8" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-df25895d-1-1">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 4.578125,-3.1875 c 0,-0.796875 -0.046875,-1.59375 -0.390625,-2.328125 -0.453125,-0.96875 -1.28125,-1.125 -1.6875,-1.125 -0.609375,0 -1.328125,0.265625 -1.75,1.1875 -0.3125,0.6875 -0.359375,1.46875 -0.359375,2.265625 0,0.75 0.03125,1.640625 0.453125,2.40625 0.421875,0.796875 1.15625,1 1.640625,1 0.53125,0 1.296875,-0.203125 1.734375,-1.15625 0.3125,-0.6875 0.359375,-1.46875 0.359375,-2.25 z M 2.484375,0 C 2.09375,0 1.5,-0.25 1.328125,-1.203125 1.21875,-1.796875 1.21875,-2.71875 1.21875,-3.3125 c 0,-0.640625 0,-1.296875 0.078125,-1.828125 0.1875,-1.1875 0.9375,-1.28125 1.1875,-1.28125 0.328125,0 0.984375,0.1875 1.171875,1.171875 0.109375,0.5625 0.109375,1.3125 0.109375,1.9375 0,0.75 0,1.421875 -0.109375,2.0625 C 3.5,-0.296875 2.9375,0 2.484375,0 z"
+               id="path22245-4" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-df25895d-2-2">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g22248-1">
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-df25895d-1-1"
+             x="223.43201"
+             y="134.765"
+             id="use22250-9" />
+        </g>
+      </g>
+    </g>
+    <g
+       id="g23265-6"
+       style="display:inline"
+       transform="matrix(1.7910448,0,0,1.7910448,-93.920889,239.45479)"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       ns0:text="$1$">
+      <defs
+         id="defs23267-2">
+        <g
+           id="g23269-2">
+          <symbol
+             id="textext-c16aad89-0-2"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path23272-5"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-c16aad89-1-2"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path23275-0"
+               d="m 2.9375,-6.375 c 0,-0.25 0,-0.265625 -0.234375,-0.265625 C 2.078125,-6 1.203125,-6 0.890625,-6 l 0,0.3125 c 0.203125,0 0.78125,0 1.296875,-0.265625 l 0,5.171875 c 0,0.359375 -0.03125,0.46875 -0.921875,0.46875 l -0.3125,0 0,0.3125 c 0.34375,-0.03125 1.203125,-0.03125 1.609375,-0.03125 0.390625,0 1.265625,0 1.609375,0.03125 l 0,-0.3125 -0.3125,0 c -0.90625,0 -0.921875,-0.109375 -0.921875,-0.46875 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-c16aad89-2-8">
+        <g
+           id="g23278-5"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use23280-9"
+             y="134.765"
+             x="223.43201"
+             xlink:href="#textext-c16aad89-1-2"
+             width="800"
+             height="600" />
+        </g>
+      </g>
+    </g>
+    <g
+       ns0:text="$2$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       transform="matrix(1.7910448,0,0,1.7910448,-93.836934,269.97338)"
+       style="display:inline"
+       id="g24285-0">
+      <defs
+         id="defs24287-4">
+        <g
+           id="g24289-5">
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-97b990b5-0-2">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path24292-7" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-97b990b5-1-5">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 1.265625,-0.765625 1.0625,-1.03125 c 1.546875,-1.375 2.140625,-1.90625 2.140625,-2.90625 0,-1.140625 -0.890625,-1.9375 -2.109375,-1.9375 -1.125,0 -1.859375,0.921875 -1.859375,1.8125 0,0.546875 0.5,0.546875 0.53125,0.546875 0.171875,0 0.515625,-0.109375 0.515625,-0.53125 0,-0.25 -0.1875,-0.515625 -0.53125,-0.515625 -0.078125,0 -0.09375,0 -0.125,0.015625 0.21875,-0.65625 0.765625,-1.015625 1.34375,-1.015625 0.90625,0 1.328125,0.8125 1.328125,1.625 C 3.5625,-3.90625 3.078125,-3.125 2.515625,-2.5 l -1.90625,2.125 C 0.5,-0.265625 0.5,-0.234375 0.5,0 l 3.703125,0 0.265625,-1.734375 -0.234375,0 C 4.171875,-1.4375 4.109375,-1 4,-0.84375 3.9375,-0.765625 3.28125,-0.765625 3.0625,-0.765625 z"
+               id="path24295-4" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-97b990b5-2-2">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g24298-8">
+          <use
+             height="600"
+             width="800"
+             xlink:href="#textext-97b990b5-1-5"
+             x="223.43201"
+             y="134.765"
+             id="use24300-7" />
+        </g>
+      </g>
+    </g>
+    <g
+       id="g26694"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       ns0:text="$A_{\\iota_K(i)} \\stackrel{+}{=} A^K_i$"
+       transform="matrix(1.8616997,0,0,1.8616997,-121.85962,328.33845)">
+      <defs
+         id="defs26696">
+        <g
+           id="g26698">
+          <symbol
+             id="textext-f6ab3895-0"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26701"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-1"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26704"
+               d="M 1.78125,-1.140625 C 1.390625,-0.484375 1,-0.34375 0.5625,-0.3125 0.4375,-0.296875 0.34375,-0.296875 0.34375,-0.109375 0.34375,-0.046875 0.40625,0 0.484375,0 0.75,0 1.0625,-0.03125 1.328125,-0.03125 c 0.34375,0 0.6875,0.03125 1,0.03125 0.0625,0 0.1875,0 0.1875,-0.1875 0,-0.109375 -0.078125,-0.125 -0.15625,-0.125 -0.21875,-0.015625 -0.46875,-0.09375 -0.46875,-0.34375 0,-0.125 0.0625,-0.234375 0.140625,-0.375 l 0.765625,-1.265625 2.5,0 c 0.015625,0.203125 0.15625,1.5625 0.15625,1.65625 0,0.296875 -0.515625,0.328125 -0.71875,0.328125 C 4.59375,-0.3125 4.5,-0.3125 4.5,-0.109375 4.5,0 4.609375,0 4.640625,0 5.046875,0 5.46875,-0.03125 5.875,-0.03125 6.125,-0.03125 6.765625,0 7.015625,0 7.0625,0 7.1875,0 7.1875,-0.203125 7.1875,-0.3125 7.09375,-0.3125 6.953125,-0.3125 6.34375,-0.3125 6.34375,-0.375 6.3125,-0.671875 l -0.609375,-6.21875 c -0.015625,-0.203125 -0.015625,-0.25 -0.1875,-0.25 -0.15625,0 -0.203125,0.078125 -0.265625,0.171875 z M 2.984375,-2.609375 4.9375,-5.90625 5.265625,-2.609375 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-2"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26707"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-3"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26710"
+               d="m 0.8125,-1.453125 c -0.078125,0.234375 -0.296875,0.734375 -0.296875,0.9375 0,0.265625 0.21875,0.578125 0.6875,0.578125 0.3125,0 0.671875,-0.125 0.953125,-0.34375 C 2.546875,-0.609375 2.609375,-0.984375 2.609375,-1 c 0,-0.09375 -0.09375,-0.09375 -0.109375,-0.09375 -0.09375,0 -0.109375,0.03125 -0.140625,0.140625 -0.171875,0.5 -0.71875,0.828125 -1.140625,0.828125 -0.109375,0 -0.1875,-0.015625 -0.1875,-0.25 0,-0.046875 0,-0.140625 0.078125,-0.359375 0.375,-1 0.625,-2.09375 0.625,-2.109375 0,-0.125 -0.09375,-0.234375 -0.234375,-0.234375 -0.140625,0 -0.25,0.109375 -0.296875,0.1875 -0.046875,0.125 -0.109375,0.46875 -0.15625,0.59375 C 1.015625,-2.1875 0.9375,-1.875 0.90625,-1.765625 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-4"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26713"
+               d="m 2.265625,-4.359375 c 0,-0.109375 -0.09375,-0.265625 -0.28125,-0.265625 -0.1875,0 -0.390625,0.1875 -0.390625,0.390625 0,0.109375 0.078125,0.265625 0.28125,0.265625 0.1875,0 0.390625,-0.203125 0.390625,-0.390625 z M 0.84375,-0.8125 c -0.03125,0.09375 -0.0625,0.171875 -0.0625,0.296875 0,0.328125 0.265625,0.578125 0.65625,0.578125 0.6875,0 1,-0.953125 1,-1.0625 0,-0.09375 -0.09375,-0.09375 -0.109375,-0.09375 -0.09375,0 -0.109375,0.046875 -0.140625,0.125 -0.15625,0.5625 -0.453125,0.84375 -0.734375,0.84375 -0.140625,0 -0.171875,-0.09375 -0.171875,-0.25 0,-0.15625 0.046875,-0.28125 0.109375,-0.4375 C 1.46875,-1 1.546875,-1.1875 1.609375,-1.375 1.671875,-1.546875 1.9375,-2.171875 1.953125,-2.265625 1.984375,-2.328125 2,-2.40625 2,-2.484375 2,-2.8125 1.71875,-3.078125 1.34375,-3.078125 0.640625,-3.078125 0.328125,-2.125 0.328125,-2 c 0,0.078125 0.09375,0.078125 0.125,0.078125 0.09375,0 0.09375,-0.03125 0.125,-0.109375 C 0.75,-2.625 1.0625,-2.875 1.3125,-2.875 c 0.109375,0 0.171875,0.046875 0.171875,0.234375 0,0.171875 -0.03125,0.265625 -0.203125,0.703125 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-5"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26716"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-6"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26719"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-7"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26722"
+               d="M 3.328125,-2 C 3.3125,-2.03125 3.296875,-2.046875 3.296875,-2.0625 c 0,0 0.125,-0.078125 0.1875,-0.125 C 4.328125,-2.71875 4.625,-2.921875 4.84375,-3.03125 5,-3.09375 5.203125,-3.171875 5.40625,-3.1875 c 0.0625,0 0.140625,0 0.140625,-0.125 0,-0.078125 -0.046875,-0.09375 -0.0625,-0.09375 -0.171875,0.015625 -0.328125,0.015625 -0.4375,0.015625 l -0.3125,0 c -0.109375,0 -0.21875,-0.015625 -0.3125,-0.015625 -0.09375,0 -0.125,0.0625 -0.125,0.140625 0,0 0,0.078125 0.09375,0.078125 C 4.5,-3.171875 4.5,-3.140625 4.5,-3.125 4.5,-3.078125 4.453125,-3.046875 4.40625,-3 c -0.0625,0.046875 -0.0625,0.046875 -0.125,0.078125 L 2,-1.453125 2.375,-2.984375 C 2.421875,-3.140625 2.421875,-3.1875 2.8125,-3.1875 c 0.125,0 0.140625,0 0.15625,0 C 3,-3.21875 3.015625,-3.28125 3.015625,-3.3125 3.015625,-3.328125 3,-3.40625 2.921875,-3.40625 c -0.109375,0 -0.21875,0.015625 -0.328125,0.015625 -0.125,0 -0.25,0 -0.375,0 -0.125,0 -0.234375,0 -0.359375,0 -0.125,0 -0.25,-0.015625 -0.359375,-0.015625 -0.03125,0 -0.125,0 -0.125,0.140625 0,0.078125 0.0625,0.078125 0.1875,0.078125 0.046875,0 0.21875,0 0.328125,0.03125 0,0.0625 0,0.078125 -0.015625,0.125 l -0.65625,2.625 c -0.046875,0.140625 -0.046875,0.1875 -0.4375,0.1875 -0.125,0 -0.203125,0 -0.203125,0.140625 C 0.578125,-0.046875 0.625,0 0.671875,0 0.78125,0 0.890625,-0.015625 1,-0.015625 c 0.125,0 0.25,0 0.375,0 0.125,0 0.25,0 0.375,0 C 1.859375,-0.015625 1.984375,0 2.09375,0 c 0.03125,0 0.125,0 0.125,-0.140625 0,-0.078125 -0.078125,-0.078125 -0.171875,-0.078125 0,0 -0.125,0 -0.203125,-0.015625 C 1.71875,-0.25 1.703125,-0.25 1.703125,-0.296875 c 0,-0.015625 0.0625,-0.234375 0.09375,-0.359375 0,-0.046875 0.125,-0.5 0.125,-0.515625 C 1.9375,-1.1875 1.9375,-1.203125 2,-1.234375 L 2.796875,-1.75 c 0,0 0.046875,-0.03125 0.046875,-0.03125 0.015625,0 0.015625,0 0.0625,0.078125 l 0.796875,1.28125 C 3.75,-0.34375 3.75,-0.34375 3.75,-0.3125 c 0,0.09375 -0.1875,0.09375 -0.21875,0.09375 -0.0625,0 -0.140625,0 -0.140625,0.140625 C 3.390625,-0.046875 3.421875,0 3.46875,0 3.578125,0 3.703125,-0.015625 3.8125,-0.015625 c 0.109375,0 0.21875,0 0.34375,0 0.09375,0 0.1875,0 0.28125,0 C 4.5,-0.015625 4.703125,0 4.71875,0 4.796875,0 4.828125,-0.0625 4.828125,-0.140625 4.828125,-0.21875 4.75,-0.21875 4.6875,-0.21875 4.5,-0.21875 4.40625,-0.265625 4.328125,-0.390625 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-8"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26725"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-9"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26728"
+               d="M 2.46875,-5.21875 C 1.15625,-4.296875 0.796875,-2.8125 0.796875,-1.75 c 0,0.984375 0.296875,2.515625 1.671875,3.484375 0.0625,0 0.140625,0 0.140625,-0.078125 0,-0.046875 -0.015625,-0.0625 -0.0625,-0.109375 C 1.609375,0.703125 1.28125,-0.46875 1.28125,-1.734375 1.28125,-3.625 2,-4.546875 2.5625,-5.0625 2.59375,-5.09375 2.609375,-5.109375 2.609375,-5.140625 2.609375,-5.21875 2.53125,-5.21875 2.46875,-5.21875 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-10"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26731"
+               d="m 0.625,-5.21875 c -0.046875,0 -0.125,0 -0.125,0.078125 0,0.03125 0.015625,0.046875 0.0625,0.109375 0.59375,0.546875 1.265625,1.484375 1.265625,3.28125 0,1.453125 -0.453125,2.5625 -1.203125,3.234375 -0.125,0.125 -0.125,0.125 -0.125,0.171875 0,0.03125 0.015625,0.078125 0.078125,0.078125 0.09375,0 0.75,-0.453125 1.21875,-1.328125 0.296875,-0.578125 0.5,-1.328125 0.5,-2.140625 C 2.296875,-2.71875 2,-4.25 0.625,-5.21875 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-11"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26734"
+               d="m 3.21875,-1.578125 2.140625,0 c 0.09375,0 0.25,0 0.25,-0.15625 0,-0.1875 -0.15625,-0.1875 -0.25,-0.1875 l -2.140625,0 0,-2.140625 c 0,-0.078125 0,-0.25 -0.15625,-0.25 -0.171875,0 -0.171875,0.15625 -0.171875,0.25 l 0,2.140625 -2.140625,0 c -0.09375,0 -0.265625,0 -0.265625,0.171875 0,0.171875 0.15625,0.171875 0.265625,0.171875 l 2.140625,0 0,2.140625 c 0,0.09375 0,0.265625 0.15625,0.265625 0.171875,0 0.171875,-0.171875 0.171875,-0.265625 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-12"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26737"
+               d=""
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+          <symbol
+             id="textext-f6ab3895-13"
+             overflow="visible"
+             style="overflow:visible">
+            <path
+               id="path26740"
+               d="m 6.84375,-3.265625 c 0.15625,0 0.34375,0 0.34375,-0.1875 C 7.1875,-3.65625 7,-3.65625 6.859375,-3.65625 l -5.96875,0 c -0.140625,0 -0.328125,0 -0.328125,0.203125 0,0.1875 0.1875,0.1875 0.328125,0.1875 z m 0.015625,1.9375 c 0.140625,0 0.328125,0 0.328125,-0.203125 0,-0.1875 -0.1875,-0.1875 -0.34375,-0.1875 l -5.953125,0 c -0.140625,0 -0.328125,0 -0.328125,0.1875 0,0.203125 0.1875,0.203125 0.328125,0.203125 z"
+               style="stroke:none"
+               inkscape:connector-curvature="0" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-f6ab3895-14">
+        <g
+           id="g26743"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26745"
+             y="135.763"
+             x="223.43201"
+             xlink:href="#textext-f6ab3895-1"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26747"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26749"
+             y="137.562"
+             x="230.90401"
+             xlink:href="#textext-f6ab3895-3"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26751"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26753"
+             y="138.564"
+             x="233.853"
+             xlink:href="#textext-f6ab3895-7"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26755"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26757"
+             y="137.562"
+             x="240.36301"
+             xlink:href="#textext-f6ab3895-9"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26759"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26761"
+             y="137.562"
+             x="243.476"
+             xlink:href="#textext-f6ab3895-4"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26763"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26765"
+             y="137.562"
+             x="246.295"
+             xlink:href="#textext-f6ab3895-10"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26767"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26769"
+             y="130.11501"
+             x="253.49001"
+             xlink:href="#textext-f6ab3895-11"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26771"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26773"
+             y="135.763"
+             x="252.674"
+             xlink:href="#textext-f6ab3895-13"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26775"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26777"
+             y="135.763"
+             x="263.19"
+             xlink:href="#textext-f6ab3895-1"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26779"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26781"
+             y="132.14799"
+             x="270.66199"
+             xlink:href="#textext-f6ab3895-5"
+             width="800"
+             height="600" />
+        </g>
+        <g
+           id="g26783"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             id="use26785"
+             y="138.356"
+             x="270.66199"
+             xlink:href="#textext-f6ab3895-4"
+             width="800"
+             height="600" />
+        </g>
+      </g>
+    </g>
+    <g
+       ns0:text="$\\iota_K^{1,0}(0)$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       transform="matrix(1.5259717,0,0,1.5259717,-341.46025,219.18118)"
+       style="display:inline"
+       id="g4129">
+      <defs
+         id="defs4131">
+        <g
+           id="g4133">
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-e099a786-0">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path4136" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-e099a786-1">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 3.234375,-1.421875 c 0,-0.109375 -0.09375,-0.109375 -0.125,-0.109375 -0.09375,0 -0.109375,0.046875 -0.125,0.109375 -0.3125,0.984375 -1.140625,1.3125 -1.5625,1.3125 -0.140625,0 -0.265625,-0.03125 -0.265625,-0.328125 0,-0.234375 0.078125,-0.46875 0.171875,-0.734375 C 1.78125,-2.375 2.1875,-4.0625 2.1875,-4.140625 2.1875,-4.3125 2.078125,-4.40625 1.90625,-4.40625 c -0.109375,0 -0.296875,0.0625 -0.375,0.265625 -0.0625,0.1875 -0.15625,0.671875 -0.21875,0.859375 -0.015625,0.046875 -0.265625,0.921875 -0.296875,1.0625 -0.03125,0.09375 -0.125,0.34375 -0.140625,0.4375 -0.078125,0.28125 -0.3125,0.75 -0.3125,1.078125 0,0.40625 0.28125,0.8125 0.828125,0.8125 1.140625,0 1.84375,-1.203125 1.84375,-1.53125 z"
+               id="path4139" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-e099a786-2">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path4142" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-e099a786-3">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 2.328125,-4.4375 c 0,-0.1875 0,-0.1875 -0.203125,-0.1875 -0.453125,0.4375 -1.078125,0.4375 -1.359375,0.4375 l 0,0.25 c 0.15625,0 0.625,0 1,-0.1875 l 0,3.546875 c 0,0.234375 0,0.328125 -0.6875,0.328125 l -0.265625,0 0,0.25 c 0.125,0 0.984375,-0.03125 1.234375,-0.03125 0.21875,0 1.09375,0.03125 1.25,0.03125 l 0,-0.25 -0.265625,0 c -0.703125,0 -0.703125,-0.09375 -0.703125,-0.328125 z"
+               id="path4145" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-e099a786-4">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="M 3.59375,-2.21875 C 3.59375,-2.984375 3.5,-3.546875 3.1875,-4.03125 2.96875,-4.34375 2.53125,-4.625 1.984375,-4.625 c -1.625,0 -1.625,1.90625 -1.625,2.40625 0,0.5 0,2.359375 1.625,2.359375 1.609375,0 1.609375,-1.859375 1.609375,-2.359375 z M 1.984375,-0.0625 c -0.328125,0 -0.75,-0.1875 -0.890625,-0.75 C 1,-1.21875 1,-1.796875 1,-2.3125 1,-2.828125 1,-3.359375 1.09375,-3.734375 1.25,-4.28125 1.6875,-4.4375 1.984375,-4.4375 c 0.375,0 0.734375,0.234375 0.859375,0.640625 0.109375,0.375 0.125,0.875 0.125,1.484375 0,0.515625 0,1.03125 -0.09375,1.46875 -0.140625,0.640625 -0.609375,0.78125 -0.890625,0.78125 z"
+               id="path4148" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-e099a786-5">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path4151" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-e099a786-6">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 1.46875,-0.109375 c 0,0.375 -0.0625,0.828125 -0.546875,1.265625 C 0.90625,1.1875 0.875,1.21875 0.875,1.25 c 0,0.046875 0.0625,0.09375 0.09375,0.09375 0.109375,0 0.703125,-0.5625 0.703125,-1.390625 0,-0.421875 -0.171875,-0.75 -0.5,-0.75 -0.21875,0 -0.390625,0.171875 -0.390625,0.390625 C 0.78125,-0.1875 0.9375,0 1.1875,0 1.359375,0 1.46875,-0.109375 1.46875,-0.109375 z"
+               id="path4154" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-e099a786-7">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               id="path4157" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-e099a786-8">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path4160" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-e099a786-9">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 3.296875,2.390625 c 0,-0.03125 0,-0.046875 -0.171875,-0.21875 C 1.890625,0.921875 1.5625,-0.96875 1.5625,-2.5 c 0,-1.734375 0.375,-3.46875 1.609375,-4.703125 0.125,-0.125 0.125,-0.140625 0.125,-0.171875 0,-0.078125 -0.03125,-0.109375 -0.09375,-0.109375 -0.109375,0 -1,0.6875 -1.59375,1.953125 -0.5,1.09375 -0.625,2.203125 -0.625,3.03125 0,0.78125 0.109375,1.984375 0.65625,3.125 C 2.25,1.84375 3.09375,2.5 3.203125,2.5 c 0.0625,0 0.09375,-0.03125 0.09375,-0.109375 z"
+               id="path4163" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-e099a786-10">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 4.578125,-3.1875 c 0,-0.796875 -0.046875,-1.59375 -0.390625,-2.328125 -0.453125,-0.96875 -1.28125,-1.125 -1.6875,-1.125 -0.609375,0 -1.328125,0.265625 -1.75,1.1875 -0.3125,0.6875 -0.359375,1.46875 -0.359375,2.265625 0,0.75 0.03125,1.640625 0.453125,2.40625 0.421875,0.796875 1.15625,1 1.640625,1 0.53125,0 1.296875,-0.203125 1.734375,-1.15625 0.3125,-0.6875 0.359375,-1.46875 0.359375,-2.25 z M 2.484375,0 C 2.09375,0 1.5,-0.25 1.328125,-1.203125 1.21875,-1.796875 1.21875,-2.71875 1.21875,-3.3125 c 0,-0.640625 0,-1.296875 0.078125,-1.828125 0.1875,-1.1875 0.9375,-1.28125 1.1875,-1.28125 0.328125,0 0.984375,0.1875 1.171875,1.171875 0.109375,0.5625 0.109375,1.3125 0.109375,1.9375 0,0.75 0,1.421875 -0.109375,2.0625 C 3.5,-0.296875 2.9375,0 2.484375,0 z"
+               id="path4166" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-e099a786-11">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 2.875,-2.5 c 0,-0.765625 -0.109375,-1.96875 -0.65625,-3.109375 -0.59375,-1.21875 -1.453125,-1.875 -1.546875,-1.875 -0.0625,0 -0.109375,0.046875 -0.109375,0.109375 0,0.03125 0,0.046875 0.1875,0.234375 0.984375,0.984375 1.546875,2.5625 1.546875,4.640625 0,1.71875 -0.359375,3.46875 -1.59375,4.71875 C 0.5625,2.34375 0.5625,2.359375 0.5625,2.390625 0.5625,2.453125 0.609375,2.5 0.671875,2.5 0.765625,2.5 1.671875,1.8125 2.25,0.546875 2.765625,-0.546875 2.875,-1.65625 2.875,-2.5 z"
+               id="path4169" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-e099a786-12">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g4172">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-e099a786-1"
+             x="223.43201"
+             y="134.765"
+             id="use4174" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g4176">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-e099a786-3"
+             x="226.95799"
+             y="129.97701"
+             id="use4178" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g4180">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-e099a786-6"
+             x="230.929"
+             y="129.97701"
+             id="use4182" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g4184">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-e099a786-4"
+             x="233.29601"
+             y="129.97701"
+             id="use4186" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g4188">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-e099a786-7"
+             x="226.95799"
+             y="137.692"
+             id="use4190" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g4192">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-e099a786-9"
+             x="237.765"
+             y="134.765"
+             id="use4194" />
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-e099a786-10"
+             x="241.63945"
+             y="134.765"
+             id="use4196" />
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-e099a786-11"
+             x="246.62076"
+             y="134.765"
+             id="use4198" />
+        </g>
+      </g>
+    </g>
+    <g
+       id="g5354"
+       style="display:inline"
+       transform="matrix(1.5259717,0,0,1.5259717,-341.46025,258.99586)"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       ns0:text="$\\iota_K^{1,0}(1)$">
+      <defs
+         id="defs5356">
+        <g
+           id="g5358">
+          <symbol
+             style="overflow:visible"
+             id="textext-1affc9fb-0"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path5361"
+               d=""
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-1affc9fb-1"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path5364"
+               d="m 3.234375,-1.421875 c 0,-0.109375 -0.09375,-0.109375 -0.125,-0.109375 -0.09375,0 -0.109375,0.046875 -0.125,0.109375 -0.3125,0.984375 -1.140625,1.3125 -1.5625,1.3125 -0.140625,0 -0.265625,-0.03125 -0.265625,-0.328125 0,-0.234375 0.078125,-0.46875 0.171875,-0.734375 C 1.78125,-2.375 2.1875,-4.0625 2.1875,-4.140625 2.1875,-4.3125 2.078125,-4.40625 1.90625,-4.40625 c -0.109375,0 -0.296875,0.0625 -0.375,0.265625 -0.0625,0.1875 -0.15625,0.671875 -0.21875,0.859375 -0.015625,0.046875 -0.265625,0.921875 -0.296875,1.0625 -0.03125,0.09375 -0.125,0.34375 -0.140625,0.4375 -0.078125,0.28125 -0.3125,0.75 -0.3125,1.078125 0,0.40625 0.28125,0.8125 0.828125,0.8125 1.140625,0 1.84375,-1.203125 1.84375,-1.53125 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-1affc9fb-2"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path5367"
+               d=""
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-1affc9fb-3"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path5370"
+               d="m 2.328125,-4.4375 c 0,-0.1875 0,-0.1875 -0.203125,-0.1875 -0.453125,0.4375 -1.078125,0.4375 -1.359375,0.4375 l 0,0.25 c 0.15625,0 0.625,0 1,-0.1875 l 0,3.546875 c 0,0.234375 0,0.328125 -0.6875,0.328125 l -0.265625,0 0,0.25 c 0.125,0 0.984375,-0.03125 1.234375,-0.03125 0.21875,0 1.09375,0.03125 1.25,0.03125 l 0,-0.25 -0.265625,0 c -0.703125,0 -0.703125,-0.09375 -0.703125,-0.328125 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-1affc9fb-4"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path5373"
+               d="M 3.59375,-2.21875 C 3.59375,-2.984375 3.5,-3.546875 3.1875,-4.03125 2.96875,-4.34375 2.53125,-4.625 1.984375,-4.625 c -1.625,0 -1.625,1.90625 -1.625,2.40625 0,0.5 0,2.359375 1.625,2.359375 1.609375,0 1.609375,-1.859375 1.609375,-2.359375 z M 1.984375,-0.0625 c -0.328125,0 -0.75,-0.1875 -0.890625,-0.75 C 1,-1.21875 1,-1.796875 1,-2.3125 1,-2.828125 1,-3.359375 1.09375,-3.734375 1.25,-4.28125 1.6875,-4.4375 1.984375,-4.4375 c 0.375,0 0.734375,0.234375 0.859375,0.640625 0.109375,0.375 0.125,0.875 0.125,1.484375 0,0.515625 0,1.03125 -0.09375,1.46875 -0.140625,0.640625 -0.609375,0.78125 -0.890625,0.78125 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-1affc9fb-5"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path5376"
+               d=""
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-1affc9fb-6"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path5379"
+               d="m 1.46875,-0.109375 c 0,0.375 -0.0625,0.828125 -0.546875,1.265625 C 0.90625,1.1875 0.875,1.21875 0.875,1.25 c 0,0.046875 0.0625,0.09375 0.09375,0.09375 0.109375,0 0.703125,-0.5625 0.703125,-1.390625 0,-0.421875 -0.171875,-0.75 -0.5,-0.75 -0.21875,0 -0.390625,0.171875 -0.390625,0.390625 C 0.78125,-0.1875 0.9375,0 1.1875,0 1.359375,0 1.46875,-0.109375 1.46875,-0.109375 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-1affc9fb-7"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path5382"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-1affc9fb-8"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path5385"
+               d=""
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-1affc9fb-9"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path5388"
+               d="m 3.296875,2.390625 c 0,-0.03125 0,-0.046875 -0.171875,-0.21875 C 1.890625,0.921875 1.5625,-0.96875 1.5625,-2.5 c 0,-1.734375 0.375,-3.46875 1.609375,-4.703125 0.125,-0.125 0.125,-0.140625 0.125,-0.171875 0,-0.078125 -0.03125,-0.109375 -0.09375,-0.109375 -0.109375,0 -1,0.6875 -1.59375,1.953125 -0.5,1.09375 -0.625,2.203125 -0.625,3.03125 0,0.78125 0.109375,1.984375 0.65625,3.125 C 2.25,1.84375 3.09375,2.5 3.203125,2.5 c 0.0625,0 0.09375,-0.03125 0.09375,-0.109375 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-1affc9fb-10"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path5391"
+               d="m 2.9375,-6.375 c 0,-0.25 0,-0.265625 -0.234375,-0.265625 C 2.078125,-6 1.203125,-6 0.890625,-6 l 0,0.3125 c 0.203125,0 0.78125,0 1.296875,-0.265625 l 0,5.171875 c 0,0.359375 -0.03125,0.46875 -0.921875,0.46875 l -0.3125,0 0,0.3125 c 0.34375,-0.03125 1.203125,-0.03125 1.609375,-0.03125 0.390625,0 1.265625,0 1.609375,0.03125 l 0,-0.3125 -0.3125,0 c -0.90625,0 -0.921875,-0.109375 -0.921875,-0.46875 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-1affc9fb-11"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path5394"
+               d="m 2.875,-2.5 c 0,-0.765625 -0.109375,-1.96875 -0.65625,-3.109375 -0.59375,-1.21875 -1.453125,-1.875 -1.546875,-1.875 -0.0625,0 -0.109375,0.046875 -0.109375,0.109375 0,0.03125 0,0.046875 0.1875,0.234375 0.984375,0.984375 1.546875,2.5625 1.546875,4.640625 0,1.71875 -0.359375,3.46875 -1.59375,4.71875 C 0.5625,2.34375 0.5625,2.359375 0.5625,2.390625 0.5625,2.453125 0.609375,2.5 0.671875,2.5 0.765625,2.5 1.671875,1.8125 2.25,0.546875 2.765625,-0.546875 2.875,-1.65625 2.875,-2.5 z"
+               style="stroke:none" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-1affc9fb-12">
+        <g
+           id="g5397"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             height="280"
+             width="420"
+             id="use5399"
+             y="134.765"
+             x="223.43201"
+             xlink:href="#textext-1affc9fb-1" />
+        </g>
+        <g
+           id="g5401"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             height="280"
+             width="420"
+             id="use5403"
+             y="129.97701"
+             x="226.95799"
+             xlink:href="#textext-1affc9fb-3" />
+        </g>
+        <g
+           id="g5405"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             height="280"
+             width="420"
+             id="use5407"
+             y="129.97701"
+             x="230.929"
+             xlink:href="#textext-1affc9fb-6" />
+        </g>
+        <g
+           id="g5409"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             height="280"
+             width="420"
+             id="use5411"
+             y="129.97701"
+             x="233.29601"
+             xlink:href="#textext-1affc9fb-4" />
+        </g>
+        <g
+           id="g5413"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             height="280"
+             width="420"
+             id="use5415"
+             y="137.692"
+             x="226.95799"
+             xlink:href="#textext-1affc9fb-7" />
+        </g>
+        <g
+           id="g5417"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             height="280"
+             width="420"
+             id="use5419"
+             y="134.765"
+             x="237.765"
+             xlink:href="#textext-1affc9fb-9" />
+          <use
+             height="280"
+             width="420"
+             id="use5421"
+             y="134.765"
+             x="241.63945"
+             xlink:href="#textext-1affc9fb-10" />
+          <use
+             height="280"
+             width="420"
+             id="use5423"
+             y="134.765"
+             x="246.62076"
+             xlink:href="#textext-1affc9fb-11" />
+        </g>
+      </g>
+    </g>
+    <g
+       ns0:text="$\\iota_K^{1,1}(0)$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       transform="matrix(1.5259717,0,0,1.5259717,-341.46025,359.10361)"
+       style="display:inline"
+       id="g6595">
+      <defs
+         id="defs6597">
+        <g
+           id="g6599">
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-554eb49b-0">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path6602" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-554eb49b-1">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 3.234375,-1.421875 c 0,-0.109375 -0.09375,-0.109375 -0.125,-0.109375 -0.09375,0 -0.109375,0.046875 -0.125,0.109375 -0.3125,0.984375 -1.140625,1.3125 -1.5625,1.3125 -0.140625,0 -0.265625,-0.03125 -0.265625,-0.328125 0,-0.234375 0.078125,-0.46875 0.171875,-0.734375 C 1.78125,-2.375 2.1875,-4.0625 2.1875,-4.140625 2.1875,-4.3125 2.078125,-4.40625 1.90625,-4.40625 c -0.109375,0 -0.296875,0.0625 -0.375,0.265625 -0.0625,0.1875 -0.15625,0.671875 -0.21875,0.859375 -0.015625,0.046875 -0.265625,0.921875 -0.296875,1.0625 -0.03125,0.09375 -0.125,0.34375 -0.140625,0.4375 -0.078125,0.28125 -0.3125,0.75 -0.3125,1.078125 0,0.40625 0.28125,0.8125 0.828125,0.8125 1.140625,0 1.84375,-1.203125 1.84375,-1.53125 z"
+               id="path6605" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-554eb49b-2">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path6608" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-554eb49b-3">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 2.328125,-4.4375 c 0,-0.1875 0,-0.1875 -0.203125,-0.1875 -0.453125,0.4375 -1.078125,0.4375 -1.359375,0.4375 l 0,0.25 c 0.15625,0 0.625,0 1,-0.1875 l 0,3.546875 c 0,0.234375 0,0.328125 -0.6875,0.328125 l -0.265625,0 0,0.25 c 0.125,0 0.984375,-0.03125 1.234375,-0.03125 0.21875,0 1.09375,0.03125 1.25,0.03125 l 0,-0.25 -0.265625,0 c -0.703125,0 -0.703125,-0.09375 -0.703125,-0.328125 z"
+               id="path6611" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-554eb49b-4">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path6614" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-554eb49b-5">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 1.46875,-0.109375 c 0,0.375 -0.0625,0.828125 -0.546875,1.265625 C 0.90625,1.1875 0.875,1.21875 0.875,1.25 c 0,0.046875 0.0625,0.09375 0.09375,0.09375 0.109375,0 0.703125,-0.5625 0.703125,-1.390625 0,-0.421875 -0.171875,-0.75 -0.5,-0.75 -0.21875,0 -0.390625,0.171875 -0.390625,0.390625 C 0.78125,-0.1875 0.9375,0 1.1875,0 1.359375,0 1.46875,-0.109375 1.46875,-0.109375 z"
+               id="path6617" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-554eb49b-6">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               id="path6620" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-554eb49b-7">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path6623" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-554eb49b-8">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 3.296875,2.390625 c 0,-0.03125 0,-0.046875 -0.171875,-0.21875 C 1.890625,0.921875 1.5625,-0.96875 1.5625,-2.5 c 0,-1.734375 0.375,-3.46875 1.609375,-4.703125 0.125,-0.125 0.125,-0.140625 0.125,-0.171875 0,-0.078125 -0.03125,-0.109375 -0.09375,-0.109375 -0.109375,0 -1,0.6875 -1.59375,1.953125 -0.5,1.09375 -0.625,2.203125 -0.625,3.03125 0,0.78125 0.109375,1.984375 0.65625,3.125 C 2.25,1.84375 3.09375,2.5 3.203125,2.5 c 0.0625,0 0.09375,-0.03125 0.09375,-0.109375 z"
+               id="path6626" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-554eb49b-9">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 4.578125,-3.1875 c 0,-0.796875 -0.046875,-1.59375 -0.390625,-2.328125 -0.453125,-0.96875 -1.28125,-1.125 -1.6875,-1.125 -0.609375,0 -1.328125,0.265625 -1.75,1.1875 -0.3125,0.6875 -0.359375,1.46875 -0.359375,2.265625 0,0.75 0.03125,1.640625 0.453125,2.40625 0.421875,0.796875 1.15625,1 1.640625,1 0.53125,0 1.296875,-0.203125 1.734375,-1.15625 0.3125,-0.6875 0.359375,-1.46875 0.359375,-2.25 z M 2.484375,0 C 2.09375,0 1.5,-0.25 1.328125,-1.203125 1.21875,-1.796875 1.21875,-2.71875 1.21875,-3.3125 c 0,-0.640625 0,-1.296875 0.078125,-1.828125 0.1875,-1.1875 0.9375,-1.28125 1.1875,-1.28125 0.328125,0 0.984375,0.1875 1.171875,1.171875 0.109375,0.5625 0.109375,1.3125 0.109375,1.9375 0,0.75 0,1.421875 -0.109375,2.0625 C 3.5,-0.296875 2.9375,0 2.484375,0 z"
+               id="path6629" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-554eb49b-10">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 2.875,-2.5 c 0,-0.765625 -0.109375,-1.96875 -0.65625,-3.109375 -0.59375,-1.21875 -1.453125,-1.875 -1.546875,-1.875 -0.0625,0 -0.109375,0.046875 -0.109375,0.109375 0,0.03125 0,0.046875 0.1875,0.234375 0.984375,0.984375 1.546875,2.5625 1.546875,4.640625 0,1.71875 -0.359375,3.46875 -1.59375,4.71875 C 0.5625,2.34375 0.5625,2.359375 0.5625,2.390625 0.5625,2.453125 0.609375,2.5 0.671875,2.5 0.765625,2.5 1.671875,1.8125 2.25,0.546875 2.765625,-0.546875 2.875,-1.65625 2.875,-2.5 z"
+               id="path6632" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-554eb49b-11">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g6635">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-554eb49b-1"
+             x="223.43201"
+             y="134.765"
+             id="use6637" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g6639">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-554eb49b-3"
+             x="226.95799"
+             y="129.97701"
+             id="use6641" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g6643">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-554eb49b-5"
+             x="230.929"
+             y="129.97701"
+             id="use6645" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g6647">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-554eb49b-3"
+             x="233.29601"
+             y="129.97701"
+             id="use6649" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g6651">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-554eb49b-6"
+             x="226.95799"
+             y="137.692"
+             id="use6653" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g6655">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-554eb49b-8"
+             x="237.765"
+             y="134.765"
+             id="use6657" />
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-554eb49b-9"
+             x="241.63945"
+             y="134.765"
+             id="use6659" />
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-554eb49b-10"
+             x="246.62076"
+             y="134.765"
+             id="use6661" />
+        </g>
+      </g>
+    </g>
+    <g
+       id="g7845"
+       style="display:inline"
+       transform="matrix(1.5259717,0,0,1.5259717,-256.66415,135.42153)"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       ns0:text="$\\iota_K^{2,0}(0)$">
+      <defs
+         id="defs7847">
+        <g
+           id="g7849">
+          <symbol
+             style="overflow:visible"
+             id="textext-f08ea6d6-0"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path7852"
+               d=""
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-f08ea6d6-1"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path7855"
+               d="m 3.234375,-1.421875 c 0,-0.109375 -0.09375,-0.109375 -0.125,-0.109375 -0.09375,0 -0.109375,0.046875 -0.125,0.109375 -0.3125,0.984375 -1.140625,1.3125 -1.5625,1.3125 -0.140625,0 -0.265625,-0.03125 -0.265625,-0.328125 0,-0.234375 0.078125,-0.46875 0.171875,-0.734375 C 1.78125,-2.375 2.1875,-4.0625 2.1875,-4.140625 2.1875,-4.3125 2.078125,-4.40625 1.90625,-4.40625 c -0.109375,0 -0.296875,0.0625 -0.375,0.265625 -0.0625,0.1875 -0.15625,0.671875 -0.21875,0.859375 -0.015625,0.046875 -0.265625,0.921875 -0.296875,1.0625 -0.03125,0.09375 -0.125,0.34375 -0.140625,0.4375 -0.078125,0.28125 -0.3125,0.75 -0.3125,1.078125 0,0.40625 0.28125,0.8125 0.828125,0.8125 1.140625,0 1.84375,-1.203125 1.84375,-1.53125 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-f08ea6d6-2"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path7858"
+               d=""
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-f08ea6d6-3"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path7861"
+               d="m 3.515625,-1.265625 -0.234375,0 c -0.015625,0.15625 -0.09375,0.5625 -0.1875,0.625 -0.046875,0.046875 -0.578125,0.046875 -0.6875,0.046875 l -1.28125,0 c 0.734375,-0.640625 0.984375,-0.84375 1.390625,-1.171875 0.515625,-0.40625 1,-0.84375 1,-1.5 0,-0.84375 -0.734375,-1.359375 -1.625,-1.359375 -0.859375,0 -1.453125,0.609375 -1.453125,1.25 0,0.34375 0.296875,0.390625 0.375,0.390625 0.15625,0 0.359375,-0.125 0.359375,-0.375 0,-0.125 -0.046875,-0.375 -0.40625,-0.375 C 0.984375,-4.21875 1.453125,-4.375 1.78125,-4.375 c 0.703125,0 1.0625,0.546875 1.0625,1.109375 0,0.609375 -0.4375,1.078125 -0.65625,1.328125 L 0.515625,-0.265625 C 0.4375,-0.203125 0.4375,-0.1875 0.4375,0 l 2.875,0 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-f08ea6d6-4"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path7864"
+               d="M 3.59375,-2.21875 C 3.59375,-2.984375 3.5,-3.546875 3.1875,-4.03125 2.96875,-4.34375 2.53125,-4.625 1.984375,-4.625 c -1.625,0 -1.625,1.90625 -1.625,2.40625 0,0.5 0,2.359375 1.625,2.359375 1.609375,0 1.609375,-1.859375 1.609375,-2.359375 z M 1.984375,-0.0625 c -0.328125,0 -0.75,-0.1875 -0.890625,-0.75 C 1,-1.21875 1,-1.796875 1,-2.3125 1,-2.828125 1,-3.359375 1.09375,-3.734375 1.25,-4.28125 1.6875,-4.4375 1.984375,-4.4375 c 0.375,0 0.734375,0.234375 0.859375,0.640625 0.109375,0.375 0.125,0.875 0.125,1.484375 0,0.515625 0,1.03125 -0.09375,1.46875 -0.140625,0.640625 -0.609375,0.78125 -0.890625,0.78125 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-f08ea6d6-5"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path7867"
+               d=""
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-f08ea6d6-6"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path7870"
+               d="m 1.46875,-0.109375 c 0,0.375 -0.0625,0.828125 -0.546875,1.265625 C 0.90625,1.1875 0.875,1.21875 0.875,1.25 c 0,0.046875 0.0625,0.09375 0.09375,0.09375 0.109375,0 0.703125,-0.5625 0.703125,-1.390625 0,-0.421875 -0.171875,-0.75 -0.5,-0.75 -0.21875,0 -0.390625,0.171875 -0.390625,0.390625 C 0.78125,-0.1875 0.9375,0 1.1875,0 1.359375,0 1.46875,-0.109375 1.46875,-0.109375 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-f08ea6d6-7"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path7873"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-f08ea6d6-8"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path7876"
+               d=""
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-f08ea6d6-9"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path7879"
+               d="m 3.296875,2.390625 c 0,-0.03125 0,-0.046875 -0.171875,-0.21875 C 1.890625,0.921875 1.5625,-0.96875 1.5625,-2.5 c 0,-1.734375 0.375,-3.46875 1.609375,-4.703125 0.125,-0.125 0.125,-0.140625 0.125,-0.171875 0,-0.078125 -0.03125,-0.109375 -0.09375,-0.109375 -0.109375,0 -1,0.6875 -1.59375,1.953125 -0.5,1.09375 -0.625,2.203125 -0.625,3.03125 0,0.78125 0.109375,1.984375 0.65625,3.125 C 2.25,1.84375 3.09375,2.5 3.203125,2.5 c 0.0625,0 0.09375,-0.03125 0.09375,-0.109375 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-f08ea6d6-10"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path7882"
+               d="m 4.578125,-3.1875 c 0,-0.796875 -0.046875,-1.59375 -0.390625,-2.328125 -0.453125,-0.96875 -1.28125,-1.125 -1.6875,-1.125 -0.609375,0 -1.328125,0.265625 -1.75,1.1875 -0.3125,0.6875 -0.359375,1.46875 -0.359375,2.265625 0,0.75 0.03125,1.640625 0.453125,2.40625 0.421875,0.796875 1.15625,1 1.640625,1 0.53125,0 1.296875,-0.203125 1.734375,-1.15625 0.3125,-0.6875 0.359375,-1.46875 0.359375,-2.25 z M 2.484375,0 C 2.09375,0 1.5,-0.25 1.328125,-1.203125 1.21875,-1.796875 1.21875,-2.71875 1.21875,-3.3125 c 0,-0.640625 0,-1.296875 0.078125,-1.828125 0.1875,-1.1875 0.9375,-1.28125 1.1875,-1.28125 0.328125,0 0.984375,0.1875 1.171875,1.171875 0.109375,0.5625 0.109375,1.3125 0.109375,1.9375 0,0.75 0,1.421875 -0.109375,2.0625 C 3.5,-0.296875 2.9375,0 2.484375,0 z"
+               style="stroke:none" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             id="textext-f08ea6d6-11"
+             overflow="visible">
+            <path
+               inkscape:connector-curvature="0"
+               id="path7885"
+               d="m 2.875,-2.5 c 0,-0.765625 -0.109375,-1.96875 -0.65625,-3.109375 -0.59375,-1.21875 -1.453125,-1.875 -1.546875,-1.875 -0.0625,0 -0.109375,0.046875 -0.109375,0.109375 0,0.03125 0,0.046875 0.1875,0.234375 0.984375,0.984375 1.546875,2.5625 1.546875,4.640625 0,1.71875 -0.359375,3.46875 -1.59375,4.71875 C 0.5625,2.34375 0.5625,2.359375 0.5625,2.390625 0.5625,2.453125 0.609375,2.5 0.671875,2.5 0.765625,2.5 1.671875,1.8125 2.25,0.546875 2.765625,-0.546875 2.875,-1.65625 2.875,-2.5 z"
+               style="stroke:none" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-f08ea6d6-12">
+        <g
+           id="g7888"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             height="280"
+             width="420"
+             id="use7890"
+             y="134.765"
+             x="223.43201"
+             xlink:href="#textext-f08ea6d6-1" />
+        </g>
+        <g
+           id="g7892"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             height="280"
+             width="420"
+             id="use7894"
+             y="129.97701"
+             x="226.95799"
+             xlink:href="#textext-f08ea6d6-3" />
+        </g>
+        <g
+           id="g7896"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             height="280"
+             width="420"
+             id="use7898"
+             y="129.97701"
+             x="230.929"
+             xlink:href="#textext-f08ea6d6-6" />
+        </g>
+        <g
+           id="g7900"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             height="280"
+             width="420"
+             id="use7902"
+             y="129.97701"
+             x="233.29601"
+             xlink:href="#textext-f08ea6d6-4" />
+        </g>
+        <g
+           id="g7904"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             height="280"
+             width="420"
+             id="use7906"
+             y="137.692"
+             x="226.95799"
+             xlink:href="#textext-f08ea6d6-7" />
+        </g>
+        <g
+           id="g7908"
+           style="fill:#000000;fill-opacity:1">
+          <use
+             height="280"
+             width="420"
+             id="use7910"
+             y="134.765"
+             x="237.765"
+             xlink:href="#textext-f08ea6d6-9" />
+          <use
+             height="280"
+             width="420"
+             id="use7912"
+             y="134.765"
+             x="241.63945"
+             xlink:href="#textext-f08ea6d6-10" />
+          <use
+             height="280"
+             width="420"
+             id="use7914"
+             y="134.765"
+             x="246.62076"
+             xlink:href="#textext-f08ea6d6-11" />
+        </g>
+      </g>
+    </g>
+    <g
+       ns0:text="$\\iota_K^{2,0}(1)$"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       transform="matrix(1.5259717,0,0,1.5259717,-204.15159,135.42153)"
+       style="display:inline"
+       id="g9114">
+      <defs
+         id="defs9116">
+        <g
+           id="g9118">
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-585f26aa-0">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path9121" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-585f26aa-1">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 3.234375,-1.421875 c 0,-0.109375 -0.09375,-0.109375 -0.125,-0.109375 -0.09375,0 -0.109375,0.046875 -0.125,0.109375 -0.3125,0.984375 -1.140625,1.3125 -1.5625,1.3125 -0.140625,0 -0.265625,-0.03125 -0.265625,-0.328125 0,-0.234375 0.078125,-0.46875 0.171875,-0.734375 C 1.78125,-2.375 2.1875,-4.0625 2.1875,-4.140625 2.1875,-4.3125 2.078125,-4.40625 1.90625,-4.40625 c -0.109375,0 -0.296875,0.0625 -0.375,0.265625 -0.0625,0.1875 -0.15625,0.671875 -0.21875,0.859375 -0.015625,0.046875 -0.265625,0.921875 -0.296875,1.0625 -0.03125,0.09375 -0.125,0.34375 -0.140625,0.4375 -0.078125,0.28125 -0.3125,0.75 -0.3125,1.078125 0,0.40625 0.28125,0.8125 0.828125,0.8125 1.140625,0 1.84375,-1.203125 1.84375,-1.53125 z"
+               id="path9124" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-585f26aa-2">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path9127" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-585f26aa-3">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 3.515625,-1.265625 -0.234375,0 c -0.015625,0.15625 -0.09375,0.5625 -0.1875,0.625 -0.046875,0.046875 -0.578125,0.046875 -0.6875,0.046875 l -1.28125,0 c 0.734375,-0.640625 0.984375,-0.84375 1.390625,-1.171875 0.515625,-0.40625 1,-0.84375 1,-1.5 0,-0.84375 -0.734375,-1.359375 -1.625,-1.359375 -0.859375,0 -1.453125,0.609375 -1.453125,1.25 0,0.34375 0.296875,0.390625 0.375,0.390625 0.15625,0 0.359375,-0.125 0.359375,-0.375 0,-0.125 -0.046875,-0.375 -0.40625,-0.375 C 0.984375,-4.21875 1.453125,-4.375 1.78125,-4.375 c 0.703125,0 1.0625,0.546875 1.0625,1.109375 0,0.609375 -0.4375,1.078125 -0.65625,1.328125 L 0.515625,-0.265625 C 0.4375,-0.203125 0.4375,-0.1875 0.4375,0 l 2.875,0 z"
+               id="path9130" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-585f26aa-4">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="M 3.59375,-2.21875 C 3.59375,-2.984375 3.5,-3.546875 3.1875,-4.03125 2.96875,-4.34375 2.53125,-4.625 1.984375,-4.625 c -1.625,0 -1.625,1.90625 -1.625,2.40625 0,0.5 0,2.359375 1.625,2.359375 1.609375,0 1.609375,-1.859375 1.609375,-2.359375 z M 1.984375,-0.0625 c -0.328125,0 -0.75,-0.1875 -0.890625,-0.75 C 1,-1.21875 1,-1.796875 1,-2.3125 1,-2.828125 1,-3.359375 1.09375,-3.734375 1.25,-4.28125 1.6875,-4.4375 1.984375,-4.4375 c 0.375,0 0.734375,0.234375 0.859375,0.640625 0.109375,0.375 0.125,0.875 0.125,1.484375 0,0.515625 0,1.03125 -0.09375,1.46875 -0.140625,0.640625 -0.609375,0.78125 -0.890625,0.78125 z"
+               id="path9133" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-585f26aa-5">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path9136" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-585f26aa-6">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 1.46875,-0.109375 c 0,0.375 -0.0625,0.828125 -0.546875,1.265625 C 0.90625,1.1875 0.875,1.21875 0.875,1.25 c 0,0.046875 0.0625,0.09375 0.09375,0.09375 0.109375,0 0.703125,-0.5625 0.703125,-1.390625 0,-0.421875 -0.171875,-0.75 -0.5,-0.75 -0.21875,0 -0.390625,0.171875 -0.390625,0.390625 C 0.78125,-0.1875 0.9375,0 1.1875,0 1.359375,0 1.46875,-0.109375 1.46875,-0.109375 z"
+               id="path9139" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-585f26aa-7">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="M 3.984375,-2.796875 C 3.953125,-2.859375 3.9375,-2.875 3.9375,-2.890625 c 0,-0.015625 0.015625,-0.015625 0.171875,-0.125 l 0.703125,-0.5 c 0.921875,-0.640625 1.359375,-0.953125 1.84375,-1 0.078125,0 0.171875,0 0.171875,-0.140625 0,-0.0625 -0.046875,-0.09375 -0.09375,-0.09375 -0.15625,0 -0.328125,0.015625 -0.484375,0.015625 -0.1875,0 -0.65625,-0.03125 -0.84375,-0.03125 -0.046875,0 -0.140625,0 -0.140625,0.15625 0,0.015625 0,0.09375 0.09375,0.09375 0.09375,0.015625 0.1875,0.03125 0.1875,0.109375 0,0.125 -0.21875,0.28125 -0.3125,0.34375 L 2.328125,-2.015625 2.875,-4.21875 c 0.0625,-0.234375 0.078125,-0.296875 0.609375,-0.296875 0.125,0 0.21875,0 0.21875,-0.140625 0,-0.0625 -0.046875,-0.109375 -0.109375,-0.109375 -0.203125,0 -0.71875,0.03125 -0.921875,0.03125 -0.109375,0 -0.359375,0 -0.484375,0 C 2.0625,-4.75 1.890625,-4.765625 1.75,-4.765625 c -0.03125,0 -0.140625,0 -0.140625,0.15625 0,0.09375 0.078125,0.09375 0.234375,0.09375 0.109375,0 0.140625,0 0.265625,0.015625 0.140625,0.015625 0.15625,0.03125 0.15625,0.109375 0,0 0,0.046875 -0.03125,0.140625 l -0.9375,3.703125 C 1.25,-0.3125 1.234375,-0.25 0.6875,-0.25 c -0.125,0 -0.203125,0 -0.203125,0.15625 0,0 0,0.09375 0.109375,0.09375 0.203125,0 0.703125,-0.03125 0.90625,-0.03125 0.109375,0 0.359375,0 0.484375,0.015625 C 2.125,-0.015625 2.296875,0 2.421875,0 2.46875,0 2.578125,0 2.578125,-0.15625 2.578125,-0.25 2.484375,-0.25 2.34375,-0.25 c 0,0 -0.140625,0 -0.265625,-0.015625 C 1.921875,-0.28125 1.921875,-0.296875 1.921875,-0.375 1.921875,-0.421875 2,-0.6875 2.25,-1.703125 l 1.15625,-0.8125 1.015625,1.953125 c 0.046875,0.09375 0.046875,0.09375 0.046875,0.125 0,0.171875 -0.203125,0.1875 -0.328125,0.1875 -0.078125,0 -0.171875,0 -0.171875,0.15625 0,0 0,0.09375 0.109375,0.09375 C 4.28125,0 4.78125,-0.03125 4.96875,-0.03125 5.1875,-0.03125 5.46875,0 5.65625,0 5.75,0 5.796875,-0.046875 5.796875,-0.140625 5.796875,-0.25 5.703125,-0.25 5.640625,-0.25 c -0.125,0 -0.34375,-0.015625 -0.46875,-0.234375 z"
+               id="path9142" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-585f26aa-8">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d=""
+               id="path9145" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-585f26aa-9">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 3.296875,2.390625 c 0,-0.03125 0,-0.046875 -0.171875,-0.21875 C 1.890625,0.921875 1.5625,-0.96875 1.5625,-2.5 c 0,-1.734375 0.375,-3.46875 1.609375,-4.703125 0.125,-0.125 0.125,-0.140625 0.125,-0.171875 0,-0.078125 -0.03125,-0.109375 -0.09375,-0.109375 -0.109375,0 -1,0.6875 -1.59375,1.953125 -0.5,1.09375 -0.625,2.203125 -0.625,3.03125 0,0.78125 0.109375,1.984375 0.65625,3.125 C 2.25,1.84375 3.09375,2.5 3.203125,2.5 c 0.0625,0 0.09375,-0.03125 0.09375,-0.109375 z"
+               id="path9148" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-585f26aa-10">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 2.9375,-6.375 c 0,-0.25 0,-0.265625 -0.234375,-0.265625 C 2.078125,-6 1.203125,-6 0.890625,-6 l 0,0.3125 c 0.203125,0 0.78125,0 1.296875,-0.265625 l 0,5.171875 c 0,0.359375 -0.03125,0.46875 -0.921875,0.46875 l -0.3125,0 0,0.3125 c 0.34375,-0.03125 1.203125,-0.03125 1.609375,-0.03125 0.390625,0 1.265625,0 1.609375,0.03125 l 0,-0.3125 -0.3125,0 c -0.90625,0 -0.921875,-0.109375 -0.921875,-0.46875 z"
+               id="path9151" />
+          </symbol>
+          <symbol
+             style="overflow:visible"
+             overflow="visible"
+             id="textext-585f26aa-11">
+            <path
+               inkscape:connector-curvature="0"
+               style="stroke:none"
+               d="m 2.875,-2.5 c 0,-0.765625 -0.109375,-1.96875 -0.65625,-3.109375 -0.59375,-1.21875 -1.453125,-1.875 -1.546875,-1.875 -0.0625,0 -0.109375,0.046875 -0.109375,0.109375 0,0.03125 0,0.046875 0.1875,0.234375 0.984375,0.984375 1.546875,2.5625 1.546875,4.640625 0,1.71875 -0.359375,3.46875 -1.59375,4.71875 C 0.5625,2.34375 0.5625,2.359375 0.5625,2.390625 0.5625,2.453125 0.609375,2.5 0.671875,2.5 0.765625,2.5 1.671875,1.8125 2.25,0.546875 2.765625,-0.546875 2.875,-1.65625 2.875,-2.5 z"
+               id="path9154" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-585f26aa-12">
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g9157">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-585f26aa-1"
+             x="223.43201"
+             y="134.765"
+             id="use9159" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g9161">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-585f26aa-3"
+             x="226.95799"
+             y="129.97701"
+             id="use9163" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g9165">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-585f26aa-6"
+             x="230.929"
+             y="129.97701"
+             id="use9167" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g9169">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-585f26aa-4"
+             x="233.29601"
+             y="129.97701"
+             id="use9171" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g9173">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-585f26aa-7"
+             x="226.95799"
+             y="137.692"
+             id="use9175" />
+        </g>
+        <g
+           style="fill:#000000;fill-opacity:1"
+           id="g9177">
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-585f26aa-9"
+             x="237.765"
+             y="134.765"
+             id="use9179" />
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-585f26aa-10"
+             x="241.63945"
+             y="134.765"
+             id="use9181" />
+          <use
+             height="280"
+             width="420"
+             xlink:href="#textext-585f26aa-11"
+             x="246.62076"
+             y="134.765"
+             id="use9183" />
+        </g>
+      </g>
+    </g>
+    <g
+       id="g10399"
+       style="display:inline"
+       transform="matrix(1.5259717,0,0,1.5259717,-110.04385,135.42153)"
+       ns0:preamble="/home/fr710/Documents/projects/mapdes/diagrams/abstractions_svg/preamble.tex"
+       ns0:text="$\\iota_K^{2,1}(0)$">
+      <defs
+         id="defs10401">
+        <g
+           id="g10403">
+          <symbol
+             id="textext-635ebb23-0"
+             overflow="visible">
+            <path
+               id="path10406"
+               d=""
+               style="stroke:none;" />
+          </symbol>
+          <symbol
+             id="textext-635ebb23-1"
+             overflow="visible">
+            <path
+               id="path10409"
+               d="M 3.234375 -1.421875 C 3.234375 -1.53125 3.140625 -1.53125 3.109375 -1.53125 C 3.015625 -1.53125 3 -1.484375 2.984375 -1.421875 C 2.671875 -0.4375 1.84375 -0.109375 1.421875 -0.109375 C 1.28125 -0.109375 1.15625 -0.140625 1.15625 -0.4375 C 1.15625 -0.671875 1.234375 -0.90625 1.328125 -1.171875 C 1.78125 -2.375 2.1875 -4.0625 2.1875 -4.140625 C 2.1875 -4.3125 2.078125 -4.40625 1.90625 -4.40625 C 1.796875 -4.40625 1.609375 -4.34375 1.53125 -4.140625 C 1.46875 -3.953125 1.375 -3.46875 1.3125 -3.28125 C 1.296875 -3.234375 1.046875 -2.359375 1.015625 -2.21875 C 0.984375 -2.125 0.890625 -1.875 0.875 -1.78125 C 0.796875 -1.5 0.5625 -1.03125 0.5625 -0.703125 C 0.5625 -0.296875 0.84375 0.109375 1.390625 0.109375 C 2.53125 0.109375 3.234375 -1.09375 3.234375 -1.421875 Z "
+               style="stroke:none;" />
+          </symbol>
+          <symbol
+             id="textext-635ebb23-2"
+             overflow="visible">
+            <path
+               id="path10412"
+               d=""
+               style="stroke:none;" />
+          </symbol>
+          <symbol
+             id="textext-635ebb23-3"
+             overflow="visible">
+            <path
+               id="path10415"
+               d="M 3.515625 -1.265625 L 3.28125 -1.265625 C 3.265625 -1.109375 3.1875 -0.703125 3.09375 -0.640625 C 3.046875 -0.59375 2.515625 -0.59375 2.40625 -0.59375 L 1.125 -0.59375 C 1.859375 -1.234375 2.109375 -1.4375 2.515625 -1.765625 C 3.03125 -2.171875 3.515625 -2.609375 3.515625 -3.265625 C 3.515625 -4.109375 2.78125 -4.625 1.890625 -4.625 C 1.03125 -4.625 0.4375 -4.015625 0.4375 -3.375 C 0.4375 -3.03125 0.734375 -2.984375 0.8125 -2.984375 C 0.96875 -2.984375 1.171875 -3.109375 1.171875 -3.359375 C 1.171875 -3.484375 1.125 -3.734375 0.765625 -3.734375 C 0.984375 -4.21875 1.453125 -4.375 1.78125 -4.375 C 2.484375 -4.375 2.84375 -3.828125 2.84375 -3.265625 C 2.84375 -2.65625 2.40625 -2.1875 2.1875 -1.9375 L 0.515625 -0.265625 C 0.4375 -0.203125 0.4375 -0.1875 0.4375 0 L 3.3125 0 Z "
+               style="stroke:none;" />
+          </symbol>
+          <symbol
+             id="textext-635ebb23-4"
+             overflow="visible">
+            <path
+               id="path10418"
+               d="M 2.328125 -4.4375 C 2.328125 -4.625 2.328125 -4.625 2.125 -4.625 C 1.671875 -4.1875 1.046875 -4.1875 0.765625 -4.1875 L 0.765625 -3.9375 C 0.921875 -3.9375 1.390625 -3.9375 1.765625 -4.125 L 1.765625 -0.578125 C 1.765625 -0.34375 1.765625 -0.25 1.078125 -0.25 L 0.8125 -0.25 L 0.8125 0 C 0.9375 0 1.796875 -0.03125 2.046875 -0.03125 C 2.265625 -0.03125 3.140625 0 3.296875 0 L 3.296875 -0.25 L 3.03125 -0.25 C 2.328125 -0.25 2.328125 -0.34375 2.328125 -0.578125 Z "
+               style="stroke:none;" />
+          </symbol>
+          <symbol
+             id="textext-635ebb23-5"
+             overflow="visible">
+            <path
+               id="path10421"
+               d=""
+               style="stroke:none;" />
+          </symbol>
+          <symbol
+             id="textext-635ebb23-6"
+             overflow="visible">
+            <path
+               id="path10424"
+               d="M 1.46875 -0.109375 C 1.46875 0.265625 1.40625 0.71875 0.921875 1.15625 C 0.90625 1.1875 0.875 1.21875 0.875 1.25 C 0.875 1.296875 0.9375 1.34375 0.96875 1.34375 C 1.078125 1.34375 1.671875 0.78125 1.671875 -0.046875 C 1.671875 -0.46875 1.5 -0.796875 1.171875 -0.796875 C 0.953125 -0.796875 0.78125 -0.625 0.78125 -0.40625 C 0.78125 -0.1875 0.9375 0 1.1875 0 C 1.359375 0 1.46875 -0.109375 1.46875 -0.109375 Z "
+               style="stroke:none;" />
+          </symbol>
+          <symbol
+             id="textext-635ebb23-7"
+             overflow="visible">
+            <path
+               id="path10427"
+               d="M 3.984375 -2.796875 C 3.953125 -2.859375 3.9375 -2.875 3.9375 -2.890625 C 3.9375 -2.90625 3.953125 -2.90625 4.109375 -3.015625 L 4.8125 -3.515625 C 5.734375 -4.15625 6.171875 -4.46875 6.65625 -4.515625 C 6.734375 -4.515625 6.828125 -4.515625 6.828125 -4.65625 C 6.828125 -4.71875 6.78125 -4.75 6.734375 -4.75 C 6.578125 -4.75 6.40625 -4.734375 6.25 -4.734375 C 6.0625 -4.734375 5.59375 -4.765625 5.40625 -4.765625 C 5.359375 -4.765625 5.265625 -4.765625 5.265625 -4.609375 C 5.265625 -4.59375 5.265625 -4.515625 5.359375 -4.515625 C 5.453125 -4.5 5.546875 -4.484375 5.546875 -4.40625 C 5.546875 -4.28125 5.328125 -4.125 5.234375 -4.0625 L 2.328125 -2.015625 L 2.875 -4.21875 C 2.9375 -4.453125 2.953125 -4.515625 3.484375 -4.515625 C 3.609375 -4.515625 3.703125 -4.515625 3.703125 -4.65625 C 3.703125 -4.71875 3.65625 -4.765625 3.59375 -4.765625 C 3.390625 -4.765625 2.875 -4.734375 2.671875 -4.734375 C 2.5625 -4.734375 2.3125 -4.734375 2.1875 -4.734375 C 2.0625 -4.75 1.890625 -4.765625 1.75 -4.765625 C 1.71875 -4.765625 1.609375 -4.765625 1.609375 -4.609375 C 1.609375 -4.515625 1.6875 -4.515625 1.84375 -4.515625 C 1.953125 -4.515625 1.984375 -4.515625 2.109375 -4.5 C 2.25 -4.484375 2.265625 -4.46875 2.265625 -4.390625 C 2.265625 -4.390625 2.265625 -4.34375 2.234375 -4.25 L 1.296875 -0.546875 C 1.25 -0.3125 1.234375 -0.25 0.6875 -0.25 C 0.5625 -0.25 0.484375 -0.25 0.484375 -0.09375 C 0.484375 -0.09375 0.484375 0 0.59375 0 C 0.796875 0 1.296875 -0.03125 1.5 -0.03125 C 1.609375 -0.03125 1.859375 -0.03125 1.984375 -0.015625 C 2.125 -0.015625 2.296875 0 2.421875 0 C 2.46875 0 2.578125 0 2.578125 -0.15625 C 2.578125 -0.25 2.484375 -0.25 2.34375 -0.25 C 2.34375 -0.25 2.203125 -0.25 2.078125 -0.265625 C 1.921875 -0.28125 1.921875 -0.296875 1.921875 -0.375 C 1.921875 -0.421875 2 -0.6875 2.25 -1.703125 L 3.40625 -2.515625 L 4.421875 -0.5625 C 4.46875 -0.46875 4.46875 -0.46875 4.46875 -0.4375 C 4.46875 -0.265625 4.265625 -0.25 4.140625 -0.25 C 4.0625 -0.25 3.96875 -0.25 3.96875 -0.09375 C 3.96875 -0.09375 3.96875 0 4.078125 0 C 4.28125 0 4.78125 -0.03125 4.96875 -0.03125 C 5.1875 -0.03125 5.46875 0 5.65625 0 C 5.75 0 5.796875 -0.046875 5.796875 -0.140625 C 5.796875 -0.25 5.703125 -0.25 5.640625 -0.25 C 5.515625 -0.25 5.296875 -0.265625 5.171875 -0.484375 Z "
+               style="stroke:none;" />
+          </symbol>
+          <symbol
+             id="textext-635ebb23-8"
+             overflow="visible">
+            <path
+               id="path10430"
+               d=""
+               style="stroke:none;" />
+          </symbol>
+          <symbol
+             id="textext-635ebb23-9"
+             overflow="visible">
+            <path
+               id="path10433"
+               d="M 3.296875 2.390625 C 3.296875 2.359375 3.296875 2.34375 3.125 2.171875 C 1.890625 0.921875 1.5625 -0.96875 1.5625 -2.5 C 1.5625 -4.234375 1.9375 -5.96875 3.171875 -7.203125 C 3.296875 -7.328125 3.296875 -7.34375 3.296875 -7.375 C 3.296875 -7.453125 3.265625 -7.484375 3.203125 -7.484375 C 3.09375 -7.484375 2.203125 -6.796875 1.609375 -5.53125 C 1.109375 -4.4375 0.984375 -3.328125 0.984375 -2.5 C 0.984375 -1.71875 1.09375 -0.515625 1.640625 0.625 C 2.25 1.84375 3.09375 2.5 3.203125 2.5 C 3.265625 2.5 3.296875 2.46875 3.296875 2.390625 Z "
+               style="stroke:none;" />
+          </symbol>
+          <symbol
+             id="textext-635ebb23-10"
+             overflow="visible">
+            <path
+               id="path10436"
+               d="M 4.578125 -3.1875 C 4.578125 -3.984375 4.53125 -4.78125 4.1875 -5.515625 C 3.734375 -6.484375 2.90625 -6.640625 2.5 -6.640625 C 1.890625 -6.640625 1.171875 -6.375 0.75 -5.453125 C 0.4375 -4.765625 0.390625 -3.984375 0.390625 -3.1875 C 0.390625 -2.4375 0.421875 -1.546875 0.84375 -0.78125 C 1.265625 0.015625 2 0.21875 2.484375 0.21875 C 3.015625 0.21875 3.78125 0.015625 4.21875 -0.9375 C 4.53125 -1.625 4.578125 -2.40625 4.578125 -3.1875 Z M 2.484375 0 C 2.09375 0 1.5 -0.25 1.328125 -1.203125 C 1.21875 -1.796875 1.21875 -2.71875 1.21875 -3.3125 C 1.21875 -3.953125 1.21875 -4.609375 1.296875 -5.140625 C 1.484375 -6.328125 2.234375 -6.421875 2.484375 -6.421875 C 2.8125 -6.421875 3.46875 -6.234375 3.65625 -5.25 C 3.765625 -4.6875 3.765625 -3.9375 3.765625 -3.3125 C 3.765625 -2.5625 3.765625 -1.890625 3.65625 -1.25 C 3.5 -0.296875 2.9375 0 2.484375 0 Z "
+               style="stroke:none;" />
+          </symbol>
+          <symbol
+             id="textext-635ebb23-11"
+             overflow="visible">
+            <path
+               id="path10439"
+               d="M 2.875 -2.5 C 2.875 -3.265625 2.765625 -4.46875 2.21875 -5.609375 C 1.625 -6.828125 0.765625 -7.484375 0.671875 -7.484375 C 0.609375 -7.484375 0.5625 -7.4375 0.5625 -7.375 C 0.5625 -7.34375 0.5625 -7.328125 0.75 -7.140625 C 1.734375 -6.15625 2.296875 -4.578125 2.296875 -2.5 C 2.296875 -0.78125 1.9375 0.96875 0.703125 2.21875 C 0.5625 2.34375 0.5625 2.359375 0.5625 2.390625 C 0.5625 2.453125 0.609375 2.5 0.671875 2.5 C 0.765625 2.5 1.671875 1.8125 2.25 0.546875 C 2.765625 -0.546875 2.875 -1.65625 2.875 -2.5 Z "
+               style="stroke:none;" />
+          </symbol>
+        </g>
+      </defs>
+      <g
+         id="textext-635ebb23-12">
+        <g
+           id="g10442"
+           style="fill:rgb(0%,0%,0%);fill-opacity:1;">
+          <use
+             id="use10444"
+             y="134.765"
+             x="223.432"
+             xlink:href="#textext-635ebb23-1" />
+        </g>
+        <g
+           id="g10446"
+           style="fill:rgb(0%,0%,0%);fill-opacity:1;">
+          <use
+             id="use10448"
+             y="129.977"
+             x="226.958"
+             xlink:href="#textext-635ebb23-3" />
+        </g>
+        <g
+           id="g10450"
+           style="fill:rgb(0%,0%,0%);fill-opacity:1;">
+          <use
+             id="use10452"
+             y="129.977"
+             x="230.929"
+             xlink:href="#textext-635ebb23-6" />
+        </g>
+        <g
+           id="g10454"
+           style="fill:rgb(0%,0%,0%);fill-opacity:1;">
+          <use
+             id="use10456"
+             y="129.977"
+             x="233.296"
+             xlink:href="#textext-635ebb23-4" />
+        </g>
+        <g
+           id="g10458"
+           style="fill:rgb(0%,0%,0%);fill-opacity:1;">
+          <use
+             id="use10460"
+             y="137.692"
+             x="226.958"
+             xlink:href="#textext-635ebb23-7" />
+        </g>
+        <g
+           id="g10462"
+           style="fill:rgb(0%,0%,0%);fill-opacity:1;">
+          <use
+             id="use10464"
+             y="134.765"
+             x="237.765"
+             xlink:href="#textext-635ebb23-9" />
+          <use
+             id="use10466"
+             y="134.765"
+             x="241.639455"
+             xlink:href="#textext-635ebb23-10" />
+          <use
+             id="use10468"
+             y="134.765"
+             x="246.620755"
+             xlink:href="#textext-635ebb23-11" />
+        </g>
+      </g>
+    </g>
+  </g>
+</svg>
diff --git a/_images/mixed_sparsity.svg b/_images/mixed_sparsity.svg
new file mode 100644
index 000000000..ae9d71e13
--- /dev/null
+++ b/_images/mixed_sparsity.svg
@@ -0,0 +1,602 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="225"
+   height="210"
+   id="svg14016"
+   version="1.1"
+   inkscape:version="0.48.4 r9939"
+   sodipodi:docname="mixed_sparsity2.svg">
+  <defs
+     id="defs14018">
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend"
+       style="overflow:visible">
+      <path
+         id="path3895"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="StopM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="StopM"
+       style="overflow:visible">
+      <path
+         id="path14733"
+         d="M 0,5.65 0,-5.65"
+         style="fill:none;stroke:#000000;stroke-width:1pt"
+         transform="scale(0.4,0.4)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="StopL"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="StopL"
+       style="overflow:visible">
+      <path
+         id="path14730"
+         d="M 0,5.65 0,-5.65"
+         style="fill:none;stroke:#000000;stroke-width:1pt"
+         transform="scale(0.8,0.8)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       style="overflow:visible"
+       id="DistanceStart"
+       refX="0"
+       refY="0"
+       orient="auto"
+       inkscape:stockid="DistanceStart">
+      <g
+         id="g2300">
+        <path
+           style="fill:none;stroke:#ffffff;stroke-width:1.14999998;stroke-linecap:square"
+           d="M 0,0 2,0"
+           id="path2306"
+           inkscape:connector-curvature="0" />
+        <path
+           style="fill:#000000;fill-rule:evenodd;stroke:none"
+           d="M 0,0 13,4 9,0 13,-4 0,0 z"
+           id="path2302"
+           inkscape:connector-curvature="0" />
+        <path
+           style="fill:none;stroke:#000000;stroke-width:1;stroke-linecap:square"
+           d="M 0,-4 0,40"
+           id="path2304"
+           inkscape:connector-curvature="0" />
+      </g>
+    </marker>
+    <marker
+       inkscape:stockid="StopM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="StopM-5"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path14733-0"
+         d="M 0,5.65 0,-5.65"
+         style="fill:none;stroke:#000000;stroke-width:1pt"
+         transform="scale(0.4,0.4)" />
+    </marker>
+    <marker
+       inkscape:stockid="StopM"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="marker16155"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path16157"
+         d="M 0,5.65 0,-5.65"
+         style="fill:none;stroke:#000000;stroke-width:1pt"
+         transform="scale(0.4,0.4)" />
+    </marker>
+  </defs>
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="4.145147"
+     inkscape:cx="171.43632"
+     inkscape:cy="107.05052"
+     inkscape:document-units="px"
+     inkscape:current-layer="layer18"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     inkscape:window-width="1920"
+     inkscape:window-height="1043"
+     inkscape:window-x="0"
+     inkscape:window-y="1098"
+     inkscape:window-maximized="0"
+     inkscape:snap-global="true"
+     inkscape:snap-bbox="true"
+     inkscape:bbox-nodes="false"
+     inkscape:snap-bbox-edge-midpoints="false">
+    <inkscape:grid
+       type="xygrid"
+       id="grid14024"
+       empspacing="5"
+       visible="true"
+       enabled="true"
+       snapvisiblegridlinesonly="true" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="220,210"
+       id="guide14026" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,5"
+       id="guide14028" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,65"
+       id="guide14030" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,145"
+       id="guide14032" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="160,210"
+       id="guide14034" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="80,210"
+       id="guide14036" />
+  </sodipodi:namedview>
+  <metadata
+     id="metadata14021">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:label="blocks"
+     inkscape:groupmode="layer"
+     id="layer1"
+     transform="translate(0,-842.36218)">
+    <rect
+       style="fill:none;stroke:#000000;stroke-opacity:1"
+       id="rect14038"
+       width="80"
+       height="80"
+       x="80.499496"
+       y="907.86218" />
+    <rect
+       style="fill:none;stroke:#000000;stroke-width:0.99999994;stroke-opacity:1"
+       id="rect14040"
+       width="80"
+       height="60"
+       x="80.499496"
+       y="987.86218" />
+    <rect
+       style="fill:none;stroke:#000000;stroke-width:0.99999994;stroke-opacity:1"
+       id="rect14042"
+       width="60.000004"
+       height="80"
+       x="160.49951"
+       y="907.86218" />
+    <rect
+       style="fill:none;stroke:#000000;stroke-width:1;stroke-opacity:1"
+       id="rect14044"
+       width="60"
+       height="60.000004"
+       x="160.4995"
+       y="987.86224" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer3"
+     inkscape:label="block labels"
+     transform="translate(0,-30)">
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="120.50267"
+       y="125"
+       id="text4913"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="120.50267"
+         y="125"
+         id="tspan4917">0,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="191.51768"
+       y="125.069"
+       id="text4913-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="191.51768"
+         y="125.069"
+         id="tspan4917-5">0,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="120.24422"
+       y="195.069"
+       id="text4913-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="120.24422"
+         y="195.069"
+         id="tspan4917-6">1,0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="191.11421"
+       y="195.06906"
+       id="text4913-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="191.11421"
+         y="195.06906"
+         id="tspan4917-3">1,1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#4e9a06;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="171.2404"
+       y="142"
+       id="text16570-1-9-9-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-1-4-7-7"
+         x="171.2404"
+         y="142"
+         style="font-size:12px;fill:#4e9a06"><tspan
+           style="font-size:14px;fill:#4e9a06"
+           id="tspan12146">Map</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#4e9a06"
+           id="tspan17203-9-6-1-8">r,0</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#204a87;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="171.24886"
+       y="159.31601"
+       id="text16570-1-3-4-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-1-5-3-4"
+         x="171.24886"
+         y="159.31601"
+         style="font-size:12px;fill:#204a87"><tspan
+           style="font-size:14px"
+           id="tspan12148">Map</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#204a87"
+           id="tspan17203-9-2-7-6">c,1</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#4e9a06;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="101.24038"
+       y="142"
+       id="text16570-1-9-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-1-4-7"
+         x="101.24038"
+         y="142"
+         style="font-size:12px;fill:#4e9a06"><tspan
+           style="font-size:14px;fill:#4e9a06"
+           id="tspan12138">Map</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#4e9a06"
+           id="tspan17203-9-6-1">r,0</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#ce5c00;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="100.59633"
+       y="159.31601"
+       id="text16570-1-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-1-1"
+         x="100.59633"
+         y="159.31601"
+         style="font-size:12px;fill:#ce5c00"><tspan
+           style="font-size:14px;fill:#ce5c00"
+           id="tspan12140">Map</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#ce5c00"
+           id="tspan17203-9-9">c,0</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#5c3566;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="101.89288"
+       y="208.31599"
+       id="text16570-1-4-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-1-6-5"
+         x="101.89288"
+         y="208.31599"
+         style="font-size:12px;fill:#5c3566"><tspan
+           style="font-size:14px;fill:#5c3566"
+           id="tspan12142">Map</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#5c3566"
+           id="tspan17203-9-64-3">r,1</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#ce5c00;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="100.59633"
+       y="224.31599"
+       id="text16570-1-36"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-1-9"
+         x="100.59633"
+         y="224.31599"
+         style="font-size:12px;fill:#ce5c00"><tspan
+           style="font-size:14px;fill:#ce5c00"
+           id="tspan12144">Map</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#ce5c00"
+           id="tspan17203-9-3">c,0</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#5c3566;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="171.89288"
+       y="208.31599"
+       id="text16570-1-4-8-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-1-6-5-0"
+         x="171.89288"
+         y="208.31599"
+         style="font-size:12px;fill:#5c3566"><tspan
+           style="font-size:14px;fill:#5c3566"
+           id="tspan12150">Map</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#5c3566"
+           id="tspan17203-9-64-3-9">r,1</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#204a87;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="171.24883"
+       y="224.31599"
+       id="text16570-1-3-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-1-5-3"
+         x="171.24883"
+         y="224.31599"
+         style="font-size:12px;fill:#204a87"><tspan
+           style="font-size:14px"
+           id="tspan12152">Map</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#204a87"
+           id="tspan17203-9-2-7">c,1</tspan></tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer17"
+     inkscape:label="datasets"
+     transform="translate(0,10)">
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-start:url(#marker16155);marker-mid:none;marker-end:url(#marker16155)"
+       d="m 79.9995,45 80,0"
+       id="path14047"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-start:url(#marker16155);marker-end:url(#marker16155)"
+       d="m 219.9995,45 -60,0"
+       id="path16177"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-start:url(#marker16155);marker-end:url(#marker16155)"
+       d="m 69.9995,55 0,80"
+       id="path16179"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-start:url(#marker16155);marker-end:url(#marker16155)"
+       d="m 69.9995,195 0,-60"
+       id="path16181"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer18"
+     inkscape:label="labels"
+     transform="translate(0,10)">
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#ce5c00;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="90.967499"
+       y="38.507999"
+       id="text16570"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572"
+         x="90.967499"
+         y="38.507999"
+         style="font-size:12px;fill:#ce5c00"><tspan
+           style="font-size:14px;fill:#ce5c00"
+           id="tspan9988">DataSet</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#ce5c00"
+           id="tspan17203">c,0</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#204a87;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="158.9675"
+       y="38.091999"
+       id="text16570-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-9"
+         x="158.9675"
+         y="38.091999"
+         style="font-size:12px;fill:#204a87"><tspan
+           style="font-size:14px;fill:#204a87"
+           id="tspan9990">DataSet</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#204a87"
+           id="tspan17201">c,1</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#4e9a06;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="5.9994998"
+       y="97"
+       id="text16570-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-0"
+         x="5.9994998"
+         y="97"
+         style="font-size:12px;fill:#4e9a06"><tspan
+           style="font-size:14px"
+           id="tspan9992">DataSet</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#4e9a06"
+           id="tspan17229">r,0</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#5c3566;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="5.9994998"
+       y="170"
+       id="text16570-5-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-0-7"
+         x="5.9994998"
+         y="170"
+         style="font-size:12px;fill:#5c3566"><tspan
+           style="font-size:14px;fill:#5c3566"
+           id="tspan9994">DataSet</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#5c3566"
+           id="tspan17229-4">r,1</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#a40000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="29.9995"
+       y="15"
+       id="text16570-5-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-0-2"
+         x="29.9995"
+         y="15"
+         style="font-size:12px;fill:#a40000"><tspan
+           style="font-size:14px"
+           id="tspan12132">Set</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#a40000"
+           id="tspan17229-0">it,0</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#ce5c00;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="74.195496"
+       y="17.316"
+       id="text16570-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-1"
+         x="74.195496"
+         y="17.316"
+         style="font-size:12px;fill:#ce5c00"><tspan
+           style="font-size:14px;fill:#ce5c00"
+           id="tspan9998">Map</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#ce5c00"
+           id="tspan17203-9">c,0</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#204a87;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="160.1955"
+       y="13.316"
+       id="text16570-1-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-1-5"
+         x="160.1955"
+         y="13.316"
+         style="font-size:12px;fill:#204a87"><tspan
+           style="font-size:14px"
+           id="tspan9996">Map</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#204a87"
+           id="tspan17203-9-2">c,1</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#4e9a06;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="39.195499"
+       y="43.316002"
+       id="text16570-1-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-1-4"
+         x="39.195499"
+         y="43.316002"
+         style="font-size:12px;fill:#4e9a06"><tspan
+           style="font-size:14px;fill:#4e9a06"
+           id="tspan12134">Map</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#4e9a06"
+           id="tspan17203-9-6">r,0</tspan></tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#5c3566;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="9.8251839"
+       y="137.31599"
+       id="text16570-1-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan16572-1-6"
+         x="9.8251839"
+         y="137.31599"
+         style="font-size:12px;fill:#5c3566"><tspan
+           style="font-size:14px;fill:#5c3566"
+           id="tspan12136">Map</tspan><tspan
+           style="font-size:9px;baseline-shift:sub;fill:#5c3566"
+           id="tspan17203-9-64">r,1</tspan></tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer2"
+     inkscape:label="arrows"
+     transform="translate(0,-30)">
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 34.999525,60 0,65"
+       id="path3055"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 24.9995,55 c -25,30 -30,85 -15,140"
+       id="path4321"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 64.9995,55 25,15"
+       id="path4518"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 49.9995,40 c 50,-10 85,-10 115,25"
+       id="path4715"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+  </g>
+</svg>
diff --git a/_images/mpi_matrix.svg b/_images/mpi_matrix.svg
new file mode 100644
index 000000000..a305ba41c
--- /dev/null
+++ b/_images/mpi_matrix.svg
@@ -0,0 +1,297 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="240"
+   height="210"
+   id="svg4764"
+   version="1.1"
+   inkscape:version="0.48.4 r9939"
+   sodipodi:docname="mpi_matrix.svg">
+  <defs
+     id="defs4766" />
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="3.4068184"
+     inkscape:cx="83.707846"
+     inkscape:cy="128.28658"
+     inkscape:document-units="px"
+     inkscape:current-layer="layer10"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     inkscape:window-width="1920"
+     inkscape:window-height="1043"
+     inkscape:window-x="0"
+     inkscape:window-y="1098"
+     inkscape:window-maximized="0">
+    <inkscape:grid
+       type="xygrid"
+       id="grid4772"
+       empspacing="5"
+       visible="true"
+       enabled="true"
+       snapvisiblegridlinesonly="true" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,205"
+       id="guide4774" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="35,240"
+       id="guide4776" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="235,240"
+       id="guide4778" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,5"
+       id="guide4780" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,65"
+       id="guide4782" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,135"
+       id="guide4784" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="105,240"
+       id="guide4786" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="175,240"
+       id="guide4788" />
+  </sodipodi:namedview>
+  <metadata
+     id="metadata4769">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title></dc:title>
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:label="matrix"
+     inkscape:groupmode="layer"
+     id="layer1"
+     transform="translate(0,-842.36218)"
+     style="display:inline">
+    <rect
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;stroke:none"
+       id="rect4790"
+       width="70"
+       height="70"
+       x="35"
+       y="35"
+       transform="translate(0,812.36218)" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:none"
+       id="rect4792"
+       width="130"
+       height="70"
+       x="105"
+       y="35"
+       transform="translate(0,812.36218)" />
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;stroke:none"
+       id="rect4794"
+       width="70"
+       height="70"
+       x="105"
+       y="105"
+       transform="translate(0,812.36218)" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:none"
+       id="rect4796"
+       width="60"
+       height="70"
+       x="175"
+       y="105"
+       transform="translate(0,812.36218)" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:none"
+       id="rect4798"
+       width="70"
+       height="70"
+       x="35"
+       y="105"
+       transform="translate(0,812.36218)" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:none"
+       id="rect4800"
+       width="140"
+       height="60"
+       x="35"
+       y="175"
+       transform="translate(0,812.36218)" />
+    <rect
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;stroke:none"
+       id="rect4802"
+       width="60"
+       height="60"
+       x="175"
+       y="175"
+       transform="translate(0,812.36218)" />
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:middle;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="69.814064"
+       y="947.72821"
+       id="text4805-2-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4807-5-11"
+         x="69.814064"
+         y="947.72821"
+         style="text-align:center;writing-mode:lr-tb;text-anchor:middle">off</tspan><tspan
+         sodipodi:role="line"
+         x="69.814064"
+         y="965.22821"
+         style="text-align:center;writing-mode:lr-tb;text-anchor:middle"
+         id="tspan4887">diagonal</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:middle;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="204.81406"
+       y="947.72821"
+       id="text4805-2-9-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4807-5-11-1"
+         x="204.81406"
+         y="947.72821"
+         style="text-align:center;writing-mode:lr-tb;text-anchor:middle">off</tspan><tspan
+         sodipodi:role="line"
+         x="204.81406"
+         y="965.22821"
+         style="text-align:center;writing-mode:lr-tb;text-anchor:middle"
+         id="tspan4887-9">diagonal</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer9"
+     inkscape:label="labels"
+     transform="translate(0,-30)">
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="42.497658"
+       y="74.115997"
+       id="text4805"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4807"
+         x="42.497658"
+         y="74.115997"
+         style="writing-mode:lr-tb">diagonal</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="112.49766"
+       y="144.116"
+       id="text4805-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4807-9"
+         x="112.49766"
+         y="144.116"
+         style="writing-mode:lr-tb">diagonal</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="177.49765"
+       y="209.116"
+       id="text4805-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4807-4"
+         x="177.49765"
+         y="209.116"
+         style="writing-mode:lr-tb">diagonal</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="131.09422"
+       y="74.115997"
+       id="text4805-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4807-5"
+         x="131.09422"
+         y="74.115997"
+         style="writing-mode:lr-tb">off-diagonal</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="66.094215"
+       y="209.116"
+       id="text4805-2-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4807-5-1"
+         x="66.094215"
+         y="209.116"
+         style="writing-mode:lr-tb">off-diagonal</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer10"
+     inkscape:label="title"
+     transform="translate(0,-30)">
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="15"
+       y="75"
+       id="text4805-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4807-3"
+         x="15"
+         y="75"
+         style="writing-mode:lr-tb">0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="15"
+       y="145"
+       id="text4805-0-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4807-3-7"
+         x="15"
+         y="145"
+         style="writing-mode:lr-tb">1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:tb-rl;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="15"
+       y="210"
+       id="text4805-0-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan4807-3-0"
+         x="15"
+         y="210"
+         style="writing-mode:lr-tb">2</tspan></text>
+  </g>
+</svg>
diff --git a/_images/pyop2_architecture.svg b/_images/pyop2_architecture.svg
new file mode 100644
index 000000000..eb33a5a03
--- /dev/null
+++ b/_images/pyop2_architecture.svg
@@ -0,0 +1,890 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="720"
+   height="480"
+   id="svg34594"
+   version="1.1"
+   inkscape:version="0.48.4 r9939"
+   sodipodi:docname="pyop2_architecture.svg">
+  <defs
+     id="defs34596">
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend"
+       style="overflow:visible">
+      <path
+         id="path12682"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-0"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-7"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-07"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-6"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-3"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-4"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-40"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-5"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-8"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-9"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-2"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-78"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-79"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-96"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-27"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-4"
+       style="overflow:visible">
+      <path
+         id="path12682-71"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-79"
+       style="overflow:visible">
+      <path
+         id="path12682-24"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-8"
+       style="overflow:visible">
+      <path
+         id="path12682-23"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-43"
+       style="overflow:visible">
+      <path
+         id="path12682-9"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-1"
+       style="overflow:visible">
+      <path
+         id="path12682-70"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-57"
+       style="overflow:visible">
+      <path
+         id="path12682-1"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-75"
+       style="overflow:visible">
+      <path
+         id="path12682-5"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18"
+       style="overflow:visible">
+      <path
+         id="path12682-0"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+  </defs>
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="2"
+     inkscape:cx="333.87487"
+     inkscape:cy="197.43082"
+     inkscape:current-layer="layer18"
+     inkscape:document-units="px"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     inkscape:window-width="1920"
+     inkscape:window-height="1043"
+     inkscape:window-x="0"
+     inkscape:window-y="1098"
+     inkscape:window-maximized="0"
+     fit-margin-top="20"
+     fit-margin-left="20"
+     fit-margin-right="20"
+     fit-margin-bottom="20">
+    <inkscape:grid
+       type="xygrid"
+       id="grid34602"
+       empspacing="5"
+       visible="true"
+       enabled="true"
+       snapvisiblegridlinesonly="true"
+       originx="-40px"
+       originy="0px" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="110,240"
+       id="guide34604" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="50,120"
+       id="guide34606" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="120,360"
+       id="guide34608" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="110,480"
+       id="guide34610" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="360,600"
+       id="guide34612" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="540,380"
+       id="guide34614" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="720,690"
+       id="guide34616" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="0,690"
+       id="guide34618" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="180,700"
+       id="guide34620" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="190,60"
+       id="guide34686" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="370,420"
+       id="guide35212" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="260,550"
+       id="guide35217" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="450,550"
+       id="guide35219" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="100,540"
+       id="guide35907" />
+  </sodipodi:namedview>
+  <metadata
+     id="metadata34599">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title></dc:title>
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:groupmode="layer"
+     id="layer20"
+     inkscape:label="background"
+     style="display:none">
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       id="rect36087"
+       width="720"
+       height="120"
+       x="0"
+       y="360" />
+    <rect
+       style="fill:#d3d7cf;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       id="rect36089"
+       width="720"
+       height="120"
+       x="0"
+       y="240" />
+    <rect
+       style="fill:#ef2929;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       id="rect36091"
+       width="720"
+       height="120"
+       x="0"
+       y="120" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       id="rect36093"
+       width="720"
+       height="120"
+       x="0"
+       y="0" />
+  </g>
+  <g
+     id="layer1"
+     inkscape:label="hardware"
+     inkscape:groupmode="layer"
+     transform="translate(-40,-120)">
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="rect34624"
+       width="140"
+       height="35"
+       x="420"
+       y="545"
+       rx="10"
+       ry="10" />
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="rect34626"
+       width="140"
+       height="35"
+       x="600"
+       y="545"
+       rx="10"
+       ry="10" />
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="rect34690"
+       width="680"
+       height="35"
+       x="60"
+       y="500"
+       rx="10"
+       ry="10" />
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="rect34692"
+       width="155"
+       height="35"
+       x="225"
+       y="545"
+       rx="10"
+       ry="10" />
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="rect34694"
+       width="155"
+       height="35"
+       x="60"
+       y="545"
+       rx="10"
+       ry="10" />
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="490"
+       y="568.78802"
+       id="text35227-2-8-0-1-6-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="490"
+         y="568.78802"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35349-4-3-8">OpenCL</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="670"
+       y="570.828"
+       id="text35227-2-8-0-1-6-3-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="670"
+         y="570.828"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35349-4-3-8-8">CUDA</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer14"
+     inkscape:label="codegen"
+     style="display:inline"
+     transform="translate(-40,-120)">
+    <rect
+       style="fill:#555753;fill-opacity:1;fill-rule:nonzero;stroke:none"
+       id="rect34624-8"
+       width="140"
+       height="80"
+       x="420"
+       y="380"
+       rx="10"
+       ry="10" />
+    <rect
+       style="fill:#555753;fill-opacity:1;fill-rule:nonzero;stroke:none"
+       id="rect34626-8"
+       width="140"
+       height="80"
+       x="600"
+       y="380"
+       rx="10"
+       ry="10" />
+    <rect
+       style="fill:#555753;fill-opacity:1;fill-rule:nonzero;stroke:none"
+       id="rect34622-8"
+       width="320"
+       height="80"
+       x="60"
+       y="380"
+       rx="10"
+       ry="10" />
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="220"
+       y="425"
+       id="text35227-2-8-0-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="220"
+         y="425"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35349-4">CPU compiler</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="490"
+       y="428"
+       id="text35227-2-8-0-1-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="490"
+         y="428"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35349-4-3">PyOpenCL</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="670"
+       y="427"
+       id="text35227-2-8-0-1-6-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="670"
+         y="427"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35349-4-3-4">PyCUDA</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="303"
+       y="570"
+       id="text35227-2-8-0-1-6-3-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="303"
+         y="570"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35349-4-3-8-5">CPU OpenMP</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="135"
+       y="570"
+       id="text35227-2-8-0-1-6-3-0-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="135"
+         y="570"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35349-4-3-8-5-8">CPU seq.</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="400.23962"
+       y="525.90002"
+       id="text35227-2-8-0-1-6-3-0-8-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="400.23962"
+         y="525.90002"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35349-4-3-8-5-8-0">MPI</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer15"
+     inkscape:label="Runtime core"
+     transform="translate(-40,-120)">
+    <rect
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="rect35204"
+       width="320"
+       height="80"
+       x="240"
+       y="260"
+       rx="10"
+       ry="10" />
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="400"
+       y="295"
+       id="text35227-2-8-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="400"
+         y="295"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35349">PyOP2 Lib &amp; Runtime Core</tspan><tspan
+         sodipodi:role="line"
+         x="400"
+         y="320.94431"
+         style="font-size:20px;font-style:italic;font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium Italic"
+         id="tspan35905">colouring, parallel scheduling</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer16"
+     inkscape:label="linear algebra"
+     transform="translate(-40,-120)">
+    <rect
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero"
+       id="rect35210"
+       width="140"
+       height="80"
+       x="600"
+       y="260"
+       rx="10"
+       ry="10" />
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="605"
+       y="292"
+       id="text35227-2-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="605"
+         y="292"
+         style="font-weight:500;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35319">Lin. algebra</tspan><tspan
+         sodipodi:role="line"
+         x="605"
+         y="322"
+         style="font-weight:500;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35317">PETSc/Cusp</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer17"
+     inkscape:label="Application code"
+     transform="translate(-40,-120)">
+    <rect
+       style="fill:#3465a4;fill-opacity:1;fill-rule:nonzero"
+       id="rect35215"
+       width="320"
+       height="35"
+       x="240"
+       y="185"
+       rx="10"
+       ry="10" />
+    <rect
+       style="fill:#3465a4;fill-opacity:1;fill-rule:nonzero"
+       id="rect35221"
+       width="95"
+       height="35"
+       x="465"
+       y="140"
+       rx="10"
+       ry="10" />
+    <rect
+       style="fill:#3465a4;fill-opacity:1;fill-rule:nonzero"
+       id="rect35223"
+       width="110"
+       height="35"
+       x="345"
+       y="140"
+       rx="10"
+       ry="10" />
+    <rect
+       style="fill:#3465a4;fill-opacity:1;fill-rule:nonzero"
+       id="rect35225"
+       width="95"
+       height="35"
+       x="240"
+       y="140"
+       rx="10"
+       ry="10" />
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="357.31393"
+       y="166.65601"
+       id="text35227"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan35229"
+         x="357.31393"
+         y="166.65601"
+         style="font-weight:500;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium">Kernels</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="260.95917"
+       y="165.756"
+       id="text35227-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan35229-6"
+         x="260.95917"
+         y="165.756"
+         style="font-weight:500;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium">Data</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="512"
+       y="152"
+       id="text35227-5-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan35229-6-1"
+         x="512"
+         y="152"
+         style="font-size:14px;font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium">Access</tspan><tspan
+         sodipodi:role="line"
+         x="512"
+         y="169.5"
+         style="font-size:14px;font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35273">Descriptors</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="310"
+       y="210"
+       id="text35227-2"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan35229-0"
+         x="310"
+         y="210"
+         style="font-weight:500;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium">Application code</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer18"
+     inkscape:label="arrows"
+     transform="translate(-40,-120)"
+     style="display:inline">
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="M 400,340 220,380"
+       id="path35590"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 400,340 90,40"
+       id="path35590-0"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 400,340 270,40"
+       id="path35590-7"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 670,460 0,40"
+       id="path35590-6"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 490,460 0,40"
+       id="path35590-6-0"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 300,460 0,40"
+       id="path35590-6-5"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 140,460 0,40"
+       id="path35590-6-9"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 560,300 40,0"
+       id="path35590-6-9-3"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 400,220 0,40"
+       id="path35590-6-9-2"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 513,175 0,10"
+       id="path35590-6-9-2-4"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 400,175 0,10"
+       id="path35590-6-9-2-4-2"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc"
+       inkscape:transform-center-x="-40.019216"
+       inkscape:transform-center-y="15.824374" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 288,175 0,10"
+       id="path35590-6-9-2-4-29"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc"
+       inkscape:transform-center-x="-55.019216"
+       inkscape:transform-center-y="15.824374" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 300,535 0,10"
+       id="path35590-6-9-2-4-0"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 140,535 0,10"
+       id="path35590-6-9-2-4-06"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend);display:inline"
+       d="m 490.5,534.5 0,10"
+       id="path35590-6-9-2-4-0-3"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend);display:inline"
+       d="m 670,535 0,10"
+       id="path35590-6-9-2-4-0-1"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer19"
+     inkscape:label="caption">
+    <text
+       xml:space="preserve"
+       style="font-size:20px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#ce5c00;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="10"
+       y="377"
+       id="text36014"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan36016"
+         x="10"
+         y="377">Backends</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:20px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#555753;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="10"
+       y="256"
+       id="text36014-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan36016-2"
+         x="10"
+         y="256">Code generation</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:20px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#a40000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="10"
+       y="136"
+       id="text36014-3-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan36016-2-2"
+         x="10"
+         y="136">PyOP2 core</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:20px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#204a87;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="10"
+       y="20"
+       id="text36014-32"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan36016-9"
+         x="10"
+         y="20">User code</tspan></text>
+  </g>
+</svg>
diff --git a/_images/pyop2_colouring.svg b/_images/pyop2_colouring.svg
new file mode 100644
index 000000000..0544909ac
--- /dev/null
+++ b/_images/pyop2_colouring.svg
@@ -0,0 +1,2370 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="920"
+   height="720"
+   id="svg36116"
+   version="1.1"
+   inkscape:version="0.48.3.1 r9886"
+   sodipodi:docname="partitioning.svg">
+  <defs
+     id="defs36118">
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend"
+       style="overflow:visible">
+      <path
+         id="path12682"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-3"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-79"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-2"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-5"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-8"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-3"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-5"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-1"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-7"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-6"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-4"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18-7"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56-6"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18-9"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56-3"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18-6"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56-8"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18-5"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56-9"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18-3"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56-89"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18-74"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56-90"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18-63"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56-62"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18-0"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56-4"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18-51"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56-2"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18-2"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56-7"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-8"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-77"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-73"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-87"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-14"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-1"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18-50"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56-80"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-18-4"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path12682-56-36"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+  </defs>
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="0.99886493"
+     inkscape:cx="427.73624"
+     inkscape:cy="376.95299"
+     inkscape:current-layer="layer32"
+     inkscape:document-units="px"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     inkscape:snap-object-midpoints="true"
+     inkscape:snap-nodes="true"
+     inkscape:snap-center="true"
+     inkscape:snap-global="true"
+     inkscape:window-width="1370"
+     inkscape:window-height="1043"
+     inkscape:window-x="0"
+     inkscape:window-y="18"
+     inkscape:window-maximized="0">
+    <inkscape:grid
+       type="xygrid"
+       id="grid36124"
+       empspacing="5"
+       visible="true"
+       enabled="true"
+       snapvisiblegridlinesonly="true" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="45,680"
+       id="guide36126" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="40,740"
+       id="guide36128" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="960,750"
+       id="guide36130" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="-30,560"
+       id="guide36132" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="570,320"
+       id="guide36134" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="-20,440"
+       id="guide36136" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="160,810"
+       id="guide36138" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="280,220"
+       id="guide36140" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="400,800"
+       id="guide36142" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="520,810"
+       id="guide36144" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="760,780"
+       id="guide36148" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="880,730"
+       id="guide37181" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="640,90"
+       id="guide37771" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="50,40"
+       id="guide37773" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="80,80"
+       id="guide37775" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="-10,120"
+       id="guide37777" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="20,160"
+       id="guide37779" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="30,200"
+       id="guide37781" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="50,240"
+       id="guide37783" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="80,310"
+       id="guide37785" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="120,300"
+       id="guide37787" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="200,220"
+       id="guide37789" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="240,220"
+       id="guide37791" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="320,170"
+       id="guide37793" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="360,110"
+       id="guide37795" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="440,150"
+       id="guide37797" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="480,130"
+       id="guide37799" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="560,210"
+       id="guide37942" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="600,230"
+       id="guide37944" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="680,240"
+       id="guide37946" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="720,240"
+       id="guide37948" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="800,190"
+       id="guide37950" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="840,190"
+       id="guide37952" />
+  </sodipodi:namedview>
+  <metadata
+     id="metadata36121">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title></dc:title>
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:groupmode="layer"
+     id="layer32"
+     inkscape:label="background">
+    <rect
+       style="fill:#babdb6;fill-opacity:1;fill-rule:nonzero"
+       id="rect39292"
+       width="920"
+       height="80"
+       x="0"
+       y="540" />
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="10"
+       y="470"
+       id="text39294"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan39296"
+         x="10"
+         y="470"
+         style="font-weight:500;-inkscape-font-specification:Ubuntu Medium">edges</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="10"
+       y="572"
+       id="text39294-1"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan39296-9"
+         x="10"
+         y="572"
+         style="font-weight:500;-inkscape-font-specification:Ubuntu Medium">shared / staging</tspan><tspan
+         sodipodi:role="line"
+         x="10"
+         y="602"
+         style="font-weight:500;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan39319">memory</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="10.504812"
+       y="707.05603"
+       id="text39294-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan39296-0"
+         x="10.504812"
+         y="707.05603"
+         style="font-weight:500;-inkscape-font-specification:Ubuntu Medium">vertices</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer21"
+     inkscape:label="partitions"
+     style="display:inline">
+    <path
+       style="fill:#729fcf"
+       d="m 260,420 0,-160 120,-120 160,0 0,280 z"
+       id="path37162"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:#fcaf3e"
+       d="M 180,420 180,300 420,60 420,20 20,20 20,420 z"
+       id="path37164"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:#8ae234"
+       d="m 500,20 0,40 120,0 0,360 280,0 0,-400 z"
+       id="path37166"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="ccccccc" />
+  </g>
+  <g
+     id="layer1"
+     inkscape:label="mesh"
+     inkscape:groupmode="layer"
+     transform="translate(0,-48)"
+     style="display:inline">
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="M 40,88 160,88 40,208 z"
+       id="path36351"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="M 160,88 280,88 160,208 z"
+       id="path36351-2"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="M 280,88 400,88 280,208 z"
+       id="path36351-7"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="M 400,88 520,88 400,208 z"
+       id="path36351-5"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="M 520,88 640,88 520,208 z"
+       id="path36351-3"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="M 640,88 760,88 640,208 z"
+       id="path36351-1"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="M 40,208 160,208 40,328 z"
+       id="path36351-8"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 160,208 120,0 -120,120 z"
+       id="path36351-9"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 280,208 120,0 -120,120 z"
+       id="path36351-71"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 400,208 120,0 -120,120 z"
+       id="path36351-31"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 520,208 120,0 -120,120 z"
+       id="path36351-92"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 640,208 120,0 -120,120 z"
+       id="path36351-96"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="M 40,328 160,328 40,448 z"
+       id="path36351-39"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 160,328 120,0 -120,120 z"
+       id="path36351-75"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 280,328 120,0 -120,120 z"
+       id="path36351-34"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 400,328 120,0 -120,120 z"
+       id="path36351-38"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 520,328 120,0 -120,120 z"
+       id="path36351-90"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 640,328 120,0 -120,120 z"
+       id="path36351-35"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 40,208 120,0 0,-120 z"
+       id="path36991"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 160,208 120,0 0,-120 z"
+       id="path36991-9"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 280,208 120,0 0,-120 z"
+       id="path36991-0"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 400,208 120,0 0,-120 z"
+       id="path36991-3"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 520,208 120,0 0,-120 z"
+       id="path36991-39"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 640,208 120,0 0,-120 z"
+       id="path36991-07"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 40,328 120,0 0,-120 z"
+       id="path36991-2"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 160,328 120,0 0,-120 z"
+       id="path36991-08"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 280,328 120,0 0,-120 z"
+       id="path36991-22"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 400,328 120,0 0,-120 z"
+       id="path36991-4"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 520,328 120,0 0,-120 z"
+       id="path36991-33"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 640,328 120,0 0,-120 z"
+       id="path36991-8"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 40,448 120,0 0,-120 z"
+       id="path36991-5"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 160,448 120,0 0,-120 z"
+       id="path36991-94"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 280,448 120,0 0,-120 z"
+       id="path36991-48"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 400,448 120,0 0,-120 z"
+       id="path36991-1"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 520,448 120,0 0,-120 z"
+       id="path36991-93"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 640,448 120,0 0,-120 z"
+       id="path36991-47"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 760,208 120,0 0,-120 z"
+       id="path36991-07-1"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 760,328 120,0 0,-120 z"
+       id="path36991-07-3"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 760,448 120,0 0,-120 z"
+       id="path36991-07-17"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="M 760,88 880,88 760,208 z"
+       id="path36351-1-9"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 760,208 120,0 -120,120 z"
+       id="path36351-1-2"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 760,328 120,0 -120,120 z"
+       id="path36351-1-7"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer25"
+     inkscape:label="colored elements"
+     style="display:none">
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="M 400,40 520,40 400,160 z"
+       id="path36351-5-5"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="M 520,40 640,40 520,160 z"
+       id="path36351-3-5"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 280,160 120,0 -120,120 z"
+       id="path36351-71-3"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 400,160 120,0 -120,120 z"
+       id="path36351-31-0"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 520,160 120,0 -120,120 z"
+       id="path36351-92-4"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 160,280 120,0 -120,120 z"
+       id="path36351-75-9"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 280,280 120,0 -120,120 z"
+       id="path36351-34-8"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 400,280 120,0 -120,120 z"
+       id="path36351-38-3"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 520,280 120,0 -120,120 z"
+       id="path36351-90-9"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:#4e9a06;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 280,160 120,0 0,-120 z"
+       id="path36991-0-8"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 400,160 120,0 0,-120 z"
+       id="path36991-3-2"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:#4e9a06;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 520,160 120,0 0,-120 z"
+       id="path36991-39-9"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 160,280 120,0 0,-120 z"
+       id="path36991-08-9"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:#ce5c00;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 280,280 120,0 0,-120 z"
+       id="path36991-22-3"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 400,280 120,0 0,-120 z"
+       id="path36991-4-0"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:#ce5c00;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 520,280 120,0 0,-120 z"
+       id="path36991-33-1"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:#4e9a06;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 160,400 120,0 0,-120 z"
+       id="path36991-94-9"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 280,400 120,0 0,-120 z"
+       id="path36991-48-8"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:#4e9a06;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 400,400 120,0 0,-120 z"
+       id="path36991-1-5"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 520,400 120,0 0,-120 z"
+       id="path36991-93-4"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer22"
+     inkscape:label="nodes"
+     style="display:inline">
+    <path
+       transform="translate(835,-5)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-58-4"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(835,115)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-58-7"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(835,235)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-58-2"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(835,355)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-58-9"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       id="path36150"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="translate(-5,-5)" />
+    <path
+       transform="translate(115,-5)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(235,-5)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-2"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(355,-5)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-6"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(475,-5)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-5"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(595,-5)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-9"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(715,-5)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-58"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(-5,115)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-29"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(115,115)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-4"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(235,115)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-8"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(355,115)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-1"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(475,115)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-7"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(595,115)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-92"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(715,115)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-49"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(-5,235)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-21"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(115,235)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-64"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(235,235)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-14"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(355,235)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-46"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(475,235)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-76"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(595,235)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-41"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(715,235)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-99"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(-5,355)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-0"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(115,355)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-47"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(235,355)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-73"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(355,355)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-45"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(475,355)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-54"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(595,355)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-23"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       transform="translate(715,355)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-59"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       sodipodi:type="arc" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       id="path37298"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="translate(235,355)" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       id="path37300"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="translate(355,355)" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none"
+       id="path37302"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="translate(475,355)" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer23"
+     inkscape:label="colored nodes"
+     style="display:inline">
+    <path
+       transform="matrix(2,0,0,2,310,-50)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-6-6"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,430,-50)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-5-6"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,190,70)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-8-6"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,310,70)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-1-8"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,430,70)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-7-4"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,190,190)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-14-7"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,310,190)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-46-1"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,430,190)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-76-9"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,190,310)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-73-5"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,310,310)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-45-7"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,430,310)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-54-6"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,190,310)" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37300-3"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,310,310)" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37302-3"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,430,310)" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer24"
+     inkscape:label="colored edges"
+     style="display:inline">
+    <path
+       style="fill:none;stroke:#4e9a06;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="M 400,160 520,40"
+       id="path37403-8"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#4e9a06;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="M 280,400 400,280"
+       id="path37403-0"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#4e9a06;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="M 400,400 520,280"
+       id="path37403-7"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#ce5c00;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="M 280,280 400,160"
+       id="path37403-02-4"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#ce5c00;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="M 400,280 520,160"
+       id="path37403-02-0"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#204a87;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 400,40 0,120"
+       id="path37502"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#204a87;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 520,40 0,120"
+       id="path37502-0"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#204a87;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 520,280 0,120"
+       id="path37502-4"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#204a87;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 400,280 0,120"
+       id="path37502-9"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#204a87;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 280,280 0,120"
+       id="path37502-5"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#8f5902;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 280,160 0,120"
+       id="path37502-06"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#8f5902;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 400,160 0,120"
+       id="path37502-06-7"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#8f5902;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 520,160 0,120"
+       id="path37502-06-1"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#5c3566;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 400,400 120,0"
+       id="path37610-7"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#5c3566;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 400,280 120,0"
+       id="path37610-4"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#5c3566;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 400,160 120,0"
+       id="path37610-8"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#a40000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 280,400 120,0"
+       id="path37610-3"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#a40000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 280,280 120,0"
+       id="path37610-3-6"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#a40000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       d="m 280,160 120,0"
+       id="path37610-3-7"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer26"
+     inkscape:label="unused"
+     style="display:none">
+    <path
+       style="fill:none;stroke:#5c3566;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 160,280 120,0"
+       id="path37610-5"
+       inkscape:connector-curvature="0" />
+    <path
+       transform="matrix(2,0,0,2,70,190)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-64-4"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       style="fill:none;stroke:#4e9a06;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="M 160,400 280,280"
+       id="path37403"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#5c3566;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 160,400 120,0"
+       id="path37610"
+       inkscape:connector-curvature="0" />
+    <path
+       transform="matrix(2,0,0,2,70,310)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-47-5"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       style="fill:none;stroke:#4e9a06;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="M 520,160 640,40"
+       id="path37403-30"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#a40000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 522,160 120,0"
+       id="path37610-3-8"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#ce5c00;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="M 520,280 640,160"
+       id="path37403-02-01"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#a40000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 520,280 120,0"
+       id="path37610-3-3"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#4e9a06;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="M 520,400 640,280"
+       id="path37403-9"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#a40000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       d="m 520,400 120,0"
+       id="path37610-3-64"
+       inkscape:connector-curvature="0" />
+    <path
+       transform="matrix(2,0,0,2,550,-50)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-9-0"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,550,70)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-92-0"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,550,190)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-41-9"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+    <path
+       transform="matrix(2,0,0,2,550,310)"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       sodipodi:ry="5"
+       sodipodi:rx="5"
+       sodipodi:cy="45"
+       sodipodi:cx="45"
+       id="path36152-23-4"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       sodipodi:type="arc" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer27"
+     inkscape:label="shared memory"
+     style="display:inline">
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980"
+       width="40"
+       height="40"
+       x="240"
+       y="560" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-8"
+       width="40"
+       height="40"
+       x="280"
+       y="560" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5"
+       width="40"
+       height="40"
+       x="320"
+       y="560" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-5"
+       width="40"
+       height="40"
+       x="400"
+       y="560" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-8"
+       width="40"
+       height="40"
+       x="360"
+       y="560" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-3"
+       width="40"
+       height="40"
+       x="440"
+       y="560" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-0"
+       width="40"
+       height="40"
+       x="480"
+       y="560" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-9"
+       width="40"
+       height="40"
+       x="520"
+       y="560" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-87"
+       width="40"
+       height="40"
+       x="560"
+       y="560" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-6"
+       width="40"
+       height="40"
+       x="600"
+       y="560" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-4"
+       width="40"
+       height="40"
+       x="640"
+       y="560" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer28"
+     inkscape:label="vertices"
+     style="display:inline">
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-7"
+       width="40"
+       height="40"
+       x="320"
+       y="640" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-5-2"
+       width="40"
+       height="40"
+       x="400"
+       y="640" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-8-4"
+       width="40"
+       height="40"
+       x="360"
+       y="640" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-3-1"
+       width="40"
+       height="40"
+       x="440"
+       y="640" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-0-1"
+       width="40"
+       height="40"
+       x="480"
+       y="640" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-9-4"
+       width="40"
+       height="40"
+       x="520"
+       y="640" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-87-4"
+       width="40"
+       height="40"
+       x="560"
+       y="640" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-5-6-2"
+       width="40"
+       height="40"
+       x="600"
+       y="640" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-83"
+       width="40"
+       height="40"
+       x="240"
+       y="640" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-8-6"
+       width="40"
+       height="40"
+       x="280"
+       y="640" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-7"
+       width="40"
+       height="40"
+       x="160"
+       y="640" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-8-4"
+       width="40"
+       height="40"
+       x="200"
+       y="640" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-0"
+       width="40"
+       height="40"
+       x="80"
+       y="640" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
+       id="rect37980-8-9"
+       width="40"
+       height="40"
+       x="120"
+       y="640" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-0-5"
+       width="40"
+       height="40"
+       x="40"
+       y="640" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-4-1"
+       width="40"
+       height="40"
+       x="640"
+       y="640" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-4-7"
+       width="40"
+       height="40"
+       x="680"
+       y="640" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-4-0"
+       width="40"
+       height="40"
+       x="720"
+       y="640" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-4-5"
+       width="40"
+       height="40"
+       x="760"
+       y="640" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-4-6"
+       width="40"
+       height="40"
+       x="800"
+       y="640" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-4-70"
+       width="40"
+       height="40"
+       x="840"
+       y="640" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer29"
+     inkscape:label="edges"
+     style="display:inline">
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-37"
+       width="40"
+       height="40"
+       x="80"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-5-9"
+       width="40"
+       height="40"
+       x="160"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-8-0"
+       width="40"
+       height="40"
+       x="120"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-3-3"
+       width="40"
+       height="40"
+       x="200"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-0-5"
+       width="40"
+       height="40"
+       x="240"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-9-7"
+       width="40"
+       height="40"
+       x="280"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-87-7"
+       width="40"
+       height="40"
+       x="320"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-6-1"
+       width="40"
+       height="40"
+       x="360"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-00"
+       width="40"
+       height="40"
+       x="400"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-5-7"
+       width="40"
+       height="40"
+       x="480"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-8-7"
+       width="40"
+       height="40"
+       x="440"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-3-2"
+       width="40"
+       height="40"
+       x="520"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-0-6"
+       width="40"
+       height="40"
+       x="560"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-9-0"
+       width="40"
+       height="40"
+       x="600"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-87-9"
+       width="40"
+       height="40"
+       x="640"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-6-5"
+       width="40"
+       height="40"
+       x="680"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-61"
+       width="40"
+       height="40"
+       x="720"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-5-5"
+       width="40"
+       height="40"
+       x="800"
+       y="480" />
+    <rect
+       style="fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-8-2"
+       width="40"
+       height="40"
+       x="760"
+       y="480" />
+    <rect
+       style="fill:#fcaf3e;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-8-2"
+       width="40"
+       height="40"
+       x="40"
+       y="480" />
+    <rect
+       style="fill:#8ae234;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
+       id="rect37980-5-4-65"
+       width="40"
+       height="40"
+       x="840"
+       y="480" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer30"
+     inkscape:label="memory load"
+     style="display:inline">
+    <path
+       style="fill:none;stroke:#000000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 340,640 0,-40"
+       id="path38350"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 380.01922,640.82437 0,-40"
+       id="path38350-6"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 420.01922,640.82437 0,-40"
+       id="path38350-68"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 460.01922,640.82437 0,-40"
+       id="path38350-9"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 500.01922,640.82437 0,-40"
+       id="path38350-1"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 540.01922,640.82437 0,-40"
+       id="path38350-0"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 580.01922,640.82437 0,-40"
+       id="path38350-3"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="m 620.01922,640.82437 0,-40"
+       id="path38350-2"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="M 180,640 300,600"
+       id="path38350-5"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="M 60,640 260,600"
+       id="path38350-5-4"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker-end:url(#Arrow2Mend)"
+       d="M 780,640 660,600"
+       id="path38350-2-2"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer33"
+     inkscape:label="indirect access"
+     style="display:inline">
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:6, 2;stroke-dashoffset:0;marker-end:url(#Arrow2Mend-18);display:inline"
+       d="m 100,500 160,80"
+       id="path38626"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:6, 2;stroke-dashoffset:0;marker-end:url(#Arrow2Mend-18);display:inline"
+       d="m 100,500 240,80"
+       id="path38626-6"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:6, 2;stroke-dashoffset:0;marker-end:url(#Arrow2Mend-18);display:inline"
+       d="m 180,500 200,80"
+       id="path38626-1"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:6, 2;stroke-dashoffset:0;marker-end:url(#Arrow2Mend-18);display:inline"
+       d="m 180,500 480,80"
+       id="path38626-7"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:6, 2;stroke-dashoffset:0;marker-end:url(#Arrow2Mend-18);display:inline"
+       d="m 660,500 -80,80"
+       id="path38626-69"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:6, 2;stroke-dashoffset:0;marker-end:url(#Arrow2Mend-18);display:inline"
+       d="M 660,500 460,580"
+       id="path38626-69-5"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:6, 2;stroke-dashoffset:0;marker-end:url(#Arrow2Mend-18);display:inline"
+       d="M 580,500 420,580"
+       id="path38626-69-5-3"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:6, 2;stroke-dashoffset:0;marker-end:url(#Arrow2Mend-18);display:inline"
+       d="m 580,500 -40,80"
+       id="path38626-69-5-7"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:6, 2;stroke-dashoffset:0;marker-end:url(#Arrow2Mend-18);display:inline"
+       d="M 740,500 500,580"
+       id="path38626-69-3"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:6, 2;stroke-dashoffset:0;marker-end:url(#Arrow2Mend-18);display:inline"
+       d="M 740,500 620,580"
+       id="path38626-69-0"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer31"
+     inkscape:label="colors"
+     style="display:inline">
+    <path
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,10,410)" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-8"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,50,410)"
+       inkscape:transform-center-x="-30"
+       inkscape:transform-center-y="40" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-1"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,90,410)"
+       inkscape:transform-center-y="50" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-9"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,130,410)"
+       inkscape:transform-center-x="-80"
+       inkscape:transform-center-y="-50" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-6"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,170,410)"
+       inkscape:transform-center-x="-10"
+       inkscape:transform-center-y="-30" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-3"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,210,410)"
+       inkscape:transform-center-x="-30" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-3-6"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,290,410)"
+       inkscape:transform-center-x="-30" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-3-0"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,370,410)"
+       inkscape:transform-center-x="-30" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-3-1"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,250,410)"
+       inkscape:transform-center-x="-30" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-3-1-1"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,330,410)"
+       inkscape:transform-center-x="-30" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-9-3"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,410,410)"
+       inkscape:transform-center-x="-80"
+       inkscape:transform-center-y="-50" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-6-5"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,450,410)"
+       inkscape:transform-center-x="-10"
+       inkscape:transform-center-y="-30" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-9-6"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,690,410)"
+       inkscape:transform-center-x="-80"
+       inkscape:transform-center-y="-50" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-6-52"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,730,410)"
+       inkscape:transform-center-x="-10"
+       inkscape:transform-center-y="-30" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-35"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,490,410)" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-8-2"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,530,410)"
+       inkscape:transform-center-x="-30"
+       inkscape:transform-center-y="40" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-2"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,570,410)" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-8-0"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,610,410)"
+       inkscape:transform-center-x="-30"
+       inkscape:transform-center-y="40" />
+    <path
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;display:inline"
+       id="path37298-2-6-2-9"
+       sodipodi:cx="45"
+       sodipodi:cy="45"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 50,45 a 5,5 0 1 1 -10,0 5,5 0 1 1 10,0 z"
+       transform="matrix(2,0,0,2,650,410)" />
+  </g>
+</svg>
diff --git a/_images/pyop2_device_data_state.svg b/_images/pyop2_device_data_state.svg
new file mode 100644
index 000000000..c85170146
--- /dev/null
+++ b/_images/pyop2_device_data_state.svg
@@ -0,0 +1,529 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="420"
+   height="240"
+   id="svg13119"
+   version="1.1"
+   inkscape:version="0.48.4 r9939"
+   sodipodi:docname="pyop2_device_data_state.svg">
+  <defs
+     id="defs13121">
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend"
+       style="overflow:visible">
+      <path
+         id="path4920"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-7"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4920-4"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-4"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4920-0"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-0"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4920-9"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-6"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4920-3"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-00"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4920-1"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-3"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4920-16"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-76"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4920-17"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+  </defs>
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="2.9310615"
+     inkscape:cx="179.5938"
+     inkscape:cy="130.01371"
+     inkscape:document-units="px"
+     inkscape:current-layer="layer1"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     inkscape:window-width="1920"
+     inkscape:window-height="1043"
+     inkscape:window-x="0"
+     inkscape:window-y="18"
+     inkscape:window-maximized="0">
+    <inkscape:grid
+       type="xygrid"
+       id="grid13127"
+       empspacing="5"
+       visible="true"
+       enabled="true"
+       snapvisiblegridlinesonly="true" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="125,240"
+       id="guide13229" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="295,240"
+       id="guide13231" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,195"
+       id="guide13233" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,215"
+       id="guide13235" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,45"
+       id="guide13237" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,25"
+       id="guide13239" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="395,240"
+       id="guide14184" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="345,240"
+       id="guide14186" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="25,240"
+       id="guide14188" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="75,240"
+       id="guide14190" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="210,240"
+       id="guide14531" />
+  </sodipodi:namedview>
+  <metadata
+     id="metadata13124">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:label="states"
+     inkscape:groupmode="layer"
+     id="layer1"
+     transform="translate(0,-812.36218)">
+    <rect
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1.0"
+       id="rect34624"
+       width="140"
+       height="60"
+       x="5"
+       y="987.36218"
+       rx="10"
+       ry="10" />
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="75.068436"
+       y="1011.2062"
+       id="text35227-2-8-0-1-6-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="75.068436"
+         y="1011.2062"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan35349-4-3-8">Device</tspan><tspan
+         sodipodi:role="line"
+         x="75.068436"
+         y="1041.2062"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan4011">unallocated</tspan></text>
+    <rect
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero"
+       id="rect34624-2-2"
+       width="140"
+       height="60"
+       x="275"
+       y="987.36218"
+       rx="10"
+       ry="10" />
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="345.06842"
+       y="1025.5103"
+       id="text35227-2-8-0-1-6-3-0-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="345.06842"
+         y="1025.5103"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan4011-9-8">Device</tspan></text>
+    <rect
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero"
+       id="rect34624-2-3"
+       width="140"
+       height="60"
+       x="275"
+       y="817.36218"
+       rx="10"
+       ry="10" />
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="345.06842"
+       y="855.51019"
+       id="text35227-2-8-0-1-6-3-0-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="345.06842"
+         y="855.51019"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan4011-9-87">Both</tspan></text>
+    <rect
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero"
+       id="rect34624-2-3-6"
+       width="140"
+       height="60"
+       x="5"
+       y="817.36218"
+       rx="10"
+       ry="10" />
+    <text
+       xml:space="preserve"
+       style="font-size:24px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="74.231628"
+       y="855.51019"
+       id="text35227-2-8-0-1-6-3-0-4-3"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="74.231628"
+         y="855.51019"
+         style="font-weight:500;text-align:center;text-anchor:middle;fill:#ffffff;fill-opacity:1;-inkscape-font-specification:Ubuntu Medium"
+         id="tspan4011-9-87-5">Host</tspan></text>
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer25"
+     inkscape:label="arrows">
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="M 145,70 270,175"
+       id="path13258"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="M 275,170 150,65"
+       id="path13952"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 150,40 120,0"
+       id="path13258-9"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="M 270,30 150,30"
+       id="path13258-9-3"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 340,70 0,100"
+       id="path13258-9-3-8"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="M 350,170 350,70"
+       id="path13258-9-3-8-0"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="M 145,175 275,65"
+       id="path13258-9-3-8-0-0"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 150,205 120,0"
+       id="path13258-9-3-8-0-0-1"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="M 75,170 75,70"
+       id="path13258-9-3-8-0-0-6"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer26"
+     inkscape:label="labels">
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#a40000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="43"
+       y="116"
+       id="text5372-4"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan5374-3"
+         x="43"
+         y="116">allocate_</tspan><tspan
+         sodipodi:role="line"
+         x="43"
+         y="133.5"
+         id="tspan14481">device()</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#204a87;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="210"
+       y="218"
+       id="text5372-6-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="210"
+         y="218"
+         id="tspan5886">par_loop</tspan><tspan
+         sodipodi:role="line"
+         x="210"
+         y="235.5"
+         id="tspan6031">(write)</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#204a87;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="132"
+       y="92"
+       id="text5372-6-8-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="132"
+         y="92"
+         id="tspan5886-9">par_loop</tspan><tspan
+         sodipodi:role="line"
+         x="132"
+         y="109.5"
+         id="tspan6031-3">(write)</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#204a87;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="311"
+       y="116"
+       id="text5372-6-8-5"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="311"
+         y="116"
+         id="tspan5886-2">par_loop</tspan><tspan
+         sodipodi:role="line"
+         x="311"
+         y="133.5"
+         id="tspan6031-0">(write)</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#204a87;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="210"
+       y="54"
+       id="text5372-6"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="210"
+         y="54"
+         id="tspan6037">par_loop (read)</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#a40000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="210"
+       y="71"
+       id="text5372-9"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan5374-7"
+         x="210"
+         y="71">to_device()</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr;text-anchor:middle;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="210"
+       y="25"
+       id="text5372-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="210"
+         y="25"
+         id="tspan6091">access data</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr;text-anchor:middle;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="381"
+       y="95"
+       id="text5372-7-8"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="381"
+         y="95"
+         id="tspan6091-7">access</tspan><tspan
+         sodipodi:role="line"
+         x="381"
+         y="110"
+         id="tspan14456">data_ro</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr;text-anchor:middle;fill:#a40000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="380"
+       y="134"
+       id="text5372"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan5374"
+         x="380"
+         y="134">from_</tspan><tspan
+         sodipodi:role="line"
+         x="380"
+         y="149"
+         id="tspan14479">device()</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="256"
+       y="124"
+       id="text5372-7-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan5374-0-4"
+         x="256"
+         y="124">access</tspan><tspan
+         sodipodi:role="line"
+         x="256"
+         y="141.5"
+         id="tspan6091-9">data</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:center;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#204a87;fill-opacity:1;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="132"
+       y="147"
+       id="text5372-6-8-7"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         x="132"
+         y="147"
+         id="tspan5886-7">par_loop</tspan><tspan
+         sodipodi:role="line"
+         x="132"
+         y="164.5"
+         id="tspan6033">(read)</tspan></text>
+  </g>
+</svg>
diff --git a/_images/pyop2_mpi_mesh.svg b/_images/pyop2_mpi_mesh.svg
new file mode 100644
index 000000000..51d2636f1
--- /dev/null
+++ b/_images/pyop2_mpi_mesh.svg
@@ -0,0 +1,2267 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="430"
+   height="360"
+   id="svg6190"
+   version="1.1"
+   inkscape:version="0.48.4 r9939"
+   sodipodi:docname="pyop2_mpi_mesh.svg">
+  <defs
+     id="defs6192">
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend"
+       style="overflow:visible">
+      <path
+         id="path4920"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)"
+         inkscape:connector-curvature="0" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-1"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4920-8"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-8"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4920-6"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+    <marker
+       inkscape:stockid="Arrow2Mend"
+       orient="auto"
+       refY="0"
+       refX="0"
+       id="Arrow2Mend-80"
+       style="overflow:visible">
+      <path
+         inkscape:connector-curvature="0"
+         id="path4920-0"
+         style="fill-rule:evenodd;stroke-width:0.625;stroke-linejoin:round"
+         d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
+         transform="scale(-0.6,-0.6)" />
+    </marker>
+  </defs>
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="2.4089844"
+     inkscape:cx="215.39486"
+     inkscape:cy="256.42528"
+     inkscape:document-units="px"
+     inkscape:current-layer="layer23"
+     showgrid="true"
+     showguides="true"
+     inkscape:guide-bbox="true"
+     inkscape:snap-global="true"
+     inkscape:snap-bbox="true"
+     inkscape:bbox-nodes="false"
+     inkscape:snap-bbox-edge-midpoints="false"
+     inkscape:snap-bbox-midpoints="true"
+     inkscape:window-width="1920"
+     inkscape:window-height="1043"
+     inkscape:window-x="1920"
+     inkscape:window-y="18"
+     inkscape:window-maximized="0"
+     inkscape:snap-object-midpoints="true">
+    <inkscape:grid
+       type="xygrid"
+       id="grid6198"
+       empspacing="5"
+       visible="true"
+       enabled="true"
+       snapvisiblegridlinesonly="true" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,115"
+       id="guide6202" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,175"
+       id="guide6204" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,55"
+       id="guide6206" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="5,0"
+       id="guide6208" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="35,0"
+       id="guide6210" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,85"
+       id="guide6214" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,145"
+       id="guide6216" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,25"
+       id="guide6218" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="65,0"
+       id="guide6224" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="125,0"
+       id="guide6226" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="95,55"
+       id="guide6264" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,205"
+       id="guide9576" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,235"
+       id="guide9578" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,265"
+       id="guide9580" />
+    <sodipodi:guide
+       orientation="0,1"
+       position="0,295"
+       id="guide9582" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="155,0"
+       id="guide9584" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="185,0"
+       id="guide9586" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="215,0"
+       id="guide9588" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="245,0"
+       id="guide9590" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="275,0"
+       id="guide9594" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="305,0"
+       id="guide9664" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="335,0"
+       id="guide9666" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="365,0"
+       id="guide9668" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="395,0"
+       id="guide9670" />
+    <sodipodi:guide
+       orientation="1,0"
+       position="425,0"
+       id="guide9672" />
+  </sodipodi:namedview>
+  <metadata
+     id="metadata6195">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:groupmode="layer"
+     id="layer15"
+     inkscape:label="core_0"
+     transform="translate(0,40)">
+    <path
+       style="fill:#e9b96e"
+       d="m 5,25 150,0 0,30 -30,30 0,30 0,30 -30,30 -30,30 -30,30 0,30 -30,30 z"
+       id="path10878"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer16"
+     inkscape:label="owned_0"
+     transform="translate(0,40)">
+    <path
+       style="fill:#ef2929"
+       d="m 155,25 0,30 -30,30 0,30 0,30 -90,90 0,30 -30,30 30,0 30,-30 0,-30 90,-90 0,-60 30,-30 0,-30 z"
+       id="path10881"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer17"
+     inkscape:label="exec_0"
+     transform="translate(0,40)">
+    <path
+       style="fill:#fcaf3e"
+       d="m 185,25 0,30 -30,30 0,60 -90,90 0,30 -30,30 30,0 30,-30 0,-30 90,-90 0,-60 30,-30 0,-30 -30,0 z"
+       id="path10884"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer18"
+     inkscape:label="non_exec_0"
+     transform="translate(0,40)">
+    <path
+       style="fill:#729fcf"
+       d="m 215,25 0,30 -30,30 0,60 -90,90 0,30 -30,30 30,0 30,-30 0,-30 90,-90 0,-60 30,-30 0,-30 z"
+       id="path10887"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:label="mesh 0"
+     inkscape:groupmode="layer"
+     id="layer1"
+     style="display:inline"
+     transform="translate(0,-692.36215)">
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 5,757.36218 5,1027.3622"
+       id="path9596"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 35,757.36218 0,270.00002"
+       id="path9598"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 65,1027.3622 65,757.36218"
+       id="path9600"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 95,1027.3622 95,757.36218"
+       id="path9602"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,1027.3622 90,0"
+       id="path9604"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,997.36218 120,0"
+       id="path9606"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,967.36218 120,0"
+       id="path9608"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,937.36218 150,0"
+       id="path9610"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,907.36218 180,0"
+       id="path9614"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,877.36218 210,0"
+       id="path9616"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,847.36218 210,0"
+       id="path9618"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,817.36218 210,0"
+       id="path9620"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,787.36218 240,0"
+       id="path9622"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,757.36218 240,0"
+       id="path9624"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 125,757.36218 0,240"
+       id="path9626"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 155,757.36218 0,180"
+       id="path9628"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 185,757.36218 0,150"
+       id="path9630"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 215,757.36218 0,120"
+       id="path9632"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 245,757.36218 0,30"
+       id="path9634"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,787.36218 30,-30"
+       id="path9636"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,817.36218 60,-60"
+       id="path9638"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,847.36218 90,-90"
+       id="path9640"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,877.36218 120,-120"
+       id="path9642"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,907.36218 150,-150"
+       id="path9644"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,937.36218 180,-180"
+       id="path9646"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,967.36218 210,-210"
+       id="path9648"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 5,997.36218 240,-240"
+       id="path9650"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 35,1027.3622 215,847.36218"
+       id="path9654"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 65,1027.3622 215,877.36218"
+       id="path9658"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 95,1027.3622 30,-30.00002"
+       id="path9660"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 5,1027.3622 245,787.36218"
+       id="path9662"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer5"
+     inkscape:label="core 0"
+     style="display:inline"
+     transform="translate(0,-692.36215)">
+    <path
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero"
+       id="path9742"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(30,0)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-5"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(60,0)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-3"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(90,0)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-6"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(120,0)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-1"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(120,30)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-5"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(90,30)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-57"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(60,30)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-9"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(30,30)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-64"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(0,30)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-13"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(0,60)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-8"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(30,60)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-18"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(60,60)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-80"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(90,60)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-0"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(90,90)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-39"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(60,90)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-4"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(30,90)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-94"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(0,90)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-05"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(0,120)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-54"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(30,120)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-47"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(60,120)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-36"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(90,120)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-7"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(60,150)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-65"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(30,150)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-02"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(0,150)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-07"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(0,180)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-363"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(30,180)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-49"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(0,210)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-37"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(0,240)"
+       sodipodi:type="arc"
+       style="fill:#8f5902;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-5-027"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer9"
+     inkscape:label="boundary 0"
+     style="display:inline"
+     transform="translate(0,-692.36215)">
+    <path
+       transform="translate(150,0)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-51-74"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(150,30)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-6"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(120,60)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-2"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(120,90)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-64"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(120,120)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-1"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(90,150)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-4"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(60,180)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-8"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(30,210)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-0"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(30,240)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-60"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(0,270)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-9"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer6"
+     inkscape:label="owned 0"
+     transform="translate(0,-692.36215)">
+    <path
+       transform="translate(180,0)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-51"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(180,30)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-51-1"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(150,60)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-51-7"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(150,90)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-51-2"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(150,120)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-51-4"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(120,150)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-51-20"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(90,180)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-51-5"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(60,210)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-51-8"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(60,240)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-51-79"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(30,270)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-51-3"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer7"
+     inkscape:label="exec 0"
+     transform="translate(0,-692.36215)">
+    <path
+       transform="translate(210,0)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(210,30)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(180,60)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-2"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(180,90)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-8"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(180,120)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-0"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(150,150)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-27"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(120,180)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-5"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(90,210)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-4"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(90,240)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-02"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(60,270)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-7-8-6"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer8"
+     inkscape:label="non-exec 0"
+     transform="translate(0,-692.36215)">
+    <path
+       transform="translate(240,0)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(240,30)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-1"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(210,60)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-6"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(210,90)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-5"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(210,120)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-2"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(180,150)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-4"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(150,180)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-0"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(120,210)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-21"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(120,240)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-3"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(90,270)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero"
+       id="path9742-8-28"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer19"
+     inkscape:label="non_exec_1"
+     transform="translate(0,40)">
+    <path
+       style="fill:#ef2929"
+       d="m 155,295 30,-30 0,-30 90,-90 0,-60 30,-30 0,-30 30,0 0,30 -30,30 0,60 -90,90 0,30 -30,30 z"
+       id="path10890"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer20"
+     inkscape:label="exec_1"
+     transform="translate(0,40)">
+    <path
+       style="fill:#fcaf3e"
+       d="m 185,295 30,-30 0,-30 90,-90 0,-60 30,-30 0,-30 30,0 0,30 -30,30 0,60 -90,90 0,30 -30,30 z"
+       id="path10893"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer21"
+     inkscape:label="owned_1"
+     transform="translate(0,40)">
+    <path
+       style="fill:#729fcf"
+       d="m 215,295 30,-30 0,-30 90,-90 0,-60 30,-30 0,-30 30,0 0,30 -30,30 0,60 -90,90 0,30 -30,30 z"
+       id="path10896"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer22"
+     inkscape:label="core_1"
+     transform="translate(0,40)">
+    <path
+       style="fill:#8ae234;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 245,295 30,-30 0,-30 90,-90 0,-60 30,-30 0,-30 30,0 0,270 z"
+       id="path10899"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer4"
+     inkscape:label="mesh 1"
+     transform="translate(0,-692.36215)">
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 155,1027.3622 425,757.36218"
+       id="path9681"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 395,757.36218 -210,210 0,60.00002"
+       id="path9683"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 215,937.36218 0,90.00002"
+       id="path9685"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 245,1027.3622 0,-120.00002"
+       id="path9687"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 275,1027.3622 0,-210.00002"
+       id="path9689"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 305,1027.3622 0,-270.00002"
+       id="path9691"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 275,847.36218 90,-90"
+       id="path9693"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 275,817.36218 60,-60"
+       id="path9695"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 335,1027.3622 0,-270.00002"
+       id="path9697"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 365,1027.3622 0,-270.00002"
+       id="path9699"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 395,1027.3622 0,-270.00002"
+       id="path9701"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 425,1027.3622 0,-270.00002"
+       id="path9703"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 185,1027.3622 425,787.36218"
+       id="path9705"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 215,1027.3622 425,817.36218"
+       id="path9707"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 245,1027.3622 425,847.36218"
+       id="path9709"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 275,1027.3622 425,877.36218"
+       id="path9711"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="M 305,1027.3622 425,907.36218"
+       id="path9713"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 335,1027.3622 90,-90.00002"
+       id="path9715"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 365,1027.3622 60,-60.00002"
+       id="path9717"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 395,1027.3622 30,-30.00002"
+       id="path9719"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 305,757.36218 120,0"
+       id="path9721"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 305,787.36218 120,0"
+       id="path9723"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 275,817.36218 150,0"
+       id="path9725"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 275,847.36218 150,0"
+       id="path9727"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 275,877.36218 150,0"
+       id="path9729"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 245,907.36218 180,0"
+       id="path9731"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 215,937.36218 210,0"
+       id="path9733"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 185,967.36218 240,0"
+       id="path9735"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 185,997.36218 240,0"
+       id="path9737"
+       inkscape:connector-curvature="0" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
+       d="m 155,1027.3622 270,0"
+       id="path9739"
+       inkscape:connector-curvature="0" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer10"
+     inkscape:label="core1"
+     transform="translate(0,-692.36215)">
+    <path
+       transform="translate(420,0)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(420,30)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-4"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(390,60)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-9"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(420,60)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-47"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(390,90)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-0"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(420,90)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-2"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(390,120)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-7"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(420,120)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-28"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(360,150)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-8"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(390,150)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-49"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(420,150)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-74"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(330,180)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-79"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(360,180)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-09"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(390,180)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-3"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(420,180)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-5"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(300,210)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-77"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(330,210)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-6"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(360,210)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-69"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(390,210)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-82"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(420,210)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-27"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(300,240)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-04"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(330,240)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-1"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(360,240)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-19"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(390,240)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-91"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(420,240)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-36"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(270,270)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-42"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(300,270)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-68"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(330,270)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-33"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(360,270)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-40"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(390,270)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-44"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(420,270)"
+       sodipodi:type="arc"
+       style="fill:#4e9a06;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-82-17"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer11"
+     inkscape:label="bounary 1"
+     transform="translate(0,-692.36215)">
+    <path
+       transform="translate(390,0)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(390,30)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-2"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(360,60)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-3"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(360,90)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-8"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(360,120)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-4"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(330,150)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-9"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(300,180)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-90"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(270,210)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-1"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(270,240)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-40"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(240,270)"
+       sodipodi:type="arc"
+       style="fill:#5c3566;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-60-7"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer12"
+     inkscape:label="owned 1"
+     transform="translate(0,-692.36215)">
+    <path
+       transform="translate(360,0)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(360,30)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-9"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(330,60)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-8"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(330,90)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-82"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(330,120)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-6"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(300,150)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-0"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(270,180)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-08"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(240,210)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-7"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(240,240)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-96"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(210,270)"
+       sodipodi:type="arc"
+       style="fill:#204a87;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-23-2"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer13"
+     inkscape:label="exec 1"
+     transform="translate(0,-692.36215)">
+    <path
+       transform="translate(330,0)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(330,30)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-9"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(300,60)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-6"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(300,90)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-0"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(300,120)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-5"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(270,150)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-8"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(240,180)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-3"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(210,210)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-2"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(210,240)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-05"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(180,270)"
+       sodipodi:type="arc"
+       style="fill:#ce5c00;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-606-1"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer14"
+     inkscape:label="non-exec 1"
+     transform="translate(0,-692.36215)">
+    <path
+       transform="translate(300,0)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-05"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(300,30)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-66"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(270,60)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-5"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(270,90)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-06"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(270,120)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-08"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(240,150)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-26"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(210,180)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-7"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(180,210)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-53"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(180,240)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-62"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+    <path
+       transform="translate(150,270)"
+       sodipodi:type="arc"
+       style="fill:#a40000;fill-opacity:1;fill-rule:nonzero;display:inline"
+       id="path9742-8-7-8-51-74-07"
+       sodipodi:cx="5"
+       sodipodi:cy="757.36218"
+       sodipodi:rx="5"
+       sodipodi:ry="5"
+       d="m 10,757.36218 c 0,2.76143 -2.2385763,5 -5,5 -2.7614237,0 -5,-2.23857 -5,-5 0,-2.76142 2.2385763,-5 5,-5 2.7614237,0 5,2.23858 5,5 z" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer23"
+     inkscape:label="collab 1"
+     transform="translate(0,40)">
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 3.9887388,295.75 c 30.0000002,25 120.0000012,25 150.0000012,0"
+       id="path10902"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 33.988739,295.85522 c 30,25 120.000001,25 150.000001,0"
+       id="path10902-6"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 244.5,295.75 c -30,25 -120,25 -150,0"
+       id="path10902-8"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#Arrow2Mend)"
+       d="m 215.26178,295.79523 c -30,25 -119.999999,25 -149.999999,0"
+       id="path10902-8-5"
+       inkscape:connector-curvature="0"
+       sodipodi:nodetypes="cc" />
+  </g>
+  <g
+     inkscape:groupmode="layer"
+     id="layer24"
+     inkscape:label="labels"
+     transform="translate(0,40)"
+     style="display:inline">
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="33.029499"
+       y="13.668"
+       id="text11658"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan11660"
+         x="33.029499"
+         y="13.668">processor 0</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="272.86444"
+       y="314.858"
+       id="text11658-0"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan11660-6"
+         x="272.86444"
+         y="314.858">processor 1</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#204a87;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="-20.334688"
+       y="144.46201"
+       id="text11658-1"
+       sodipodi:linespacing="125%"
+       transform="matrix(0,-1,1,0,0,0)"><tspan
+         sodipodi:role="line"
+         id="tspan11660-3"
+         x="-20.334688"
+         y="144.46201">core</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#204a87;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="-20.334688"
+       y="175.341"
+       id="text11658-1-9"
+       sodipodi:linespacing="125%"
+       transform="matrix(0,-1,1,0,0,0)"><tspan
+         sodipodi:role="line"
+         id="tspan11660-3-9"
+         x="-20.334688"
+         y="175.341">owned</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#a40000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="-20.334688"
+       y="203.864"
+       id="text11658-1-9-4"
+       sodipodi:linespacing="125%"
+       transform="matrix(0,-1,1,0,0,0)"><tspan
+         sodipodi:role="line"
+         id="tspan11660-3-9-5"
+         x="-20.334688"
+         y="203.864">exec</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#a40000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="-20.740688"
+       y="234.832"
+       id="text11658-1-9-4-8"
+       sodipodi:linespacing="125%"
+       transform="matrix(0,-1,1,0,0,0)"><tspan
+         sodipodi:role="line"
+         id="tspan11660-3-9-5-4"
+         x="-20.740688"
+         y="234.832">non-exec</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#204a87;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="-20.334688"
+       y="414.81799"
+       id="text11658-1-0"
+       sodipodi:linespacing="125%"
+       transform="matrix(0,-1,1,0,0,0)"><tspan
+         sodipodi:role="line"
+         id="tspan11660-3-2"
+         x="-20.334688"
+         y="414.81799">core</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#204a87;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="-20.334688"
+       y="385.341"
+       id="text11658-1-9-40"
+       sodipodi:linespacing="125%"
+       transform="matrix(0,-1,1,0,0,0)"><tspan
+         sodipodi:role="line"
+         id="tspan11660-3-9-8"
+         x="-20.334688"
+         y="385.341">owned</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#a40000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="-20.334688"
+       y="354.46201"
+       id="text11658-1-9-4-3"
+       sodipodi:linespacing="125%"
+       transform="matrix(0,-1,1,0,0,0)"><tspan
+         sodipodi:role="line"
+         id="tspan11660-3-9-5-3"
+         x="-20.334688"
+         y="354.46201">exec</tspan></text>
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#a40000;fill-opacity:1;stroke:none;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="-20.740688"
+       y="323.64001"
+       id="text11658-1-9-4-8-1"
+       sodipodi:linespacing="125%"
+       transform="matrix(0,-1,1,0,0,0)"><tspan
+         sodipodi:role="line"
+         id="tspan11660-3-9-5-4-4"
+         x="-20.740688"
+         y="323.64001">non-exec</tspan></text>
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;stroke-miterlimit:4;stroke-dasharray:2,2;stroke-dashoffset:0"
+       d="m 185,0 0,65"
+       id="path6648"
+       inkscape:connector-curvature="0"
+       transform="translate(0,-40)" />
+    <path
+       style="fill:none;stroke:#000000;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:2, 2;stroke-dashoffset:0;display:inline"
+       d="m 365.5,-39.5 0,65"
+       id="path6648-2"
+       inkscape:connector-curvature="0" />
+    <text
+       xml:space="preserve"
+       style="font-size:14px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#a40000;fill-opacity:1;stroke:none;display:inline;font-family:Ubuntu;-inkscape-font-specification:Ubuntu"
+       x="257.90546"
+       y="0.34099999"
+       id="text11658-1-9-4-30"
+       sodipodi:linespacing="125%"><tspan
+         sodipodi:role="line"
+         id="tspan11660-3-9-5-2"
+         x="257.90546"
+         y="0.34099999">halos</tspan></text>
+  </g>
+</svg>
diff --git a/_sources/architecture.rst.txt b/_sources/architecture.rst.txt
new file mode 100644
index 000000000..f14a6da10
--- /dev/null
+++ b/_sources/architecture.rst.txt
@@ -0,0 +1,76 @@
+.. _architecture:
+
+PyOP2 Architecture
+==================
+
+As described in :ref:`concepts`, PyOP2 exposes an API that allows users to
+declare the topology of unstructured meshes in the form of :class:`Sets
+<pyop2.Set>` and :class:`Maps <pyop2.Map>` and data in the form of
+:class:`Dats <pyop2.Dat>`, :class:`Mats <pyop2.Mat>`, :class:`Globals
+<pyop2.Global>` and :class:`Consts <pyop2.Const>`. Computations on this data
+are described by :class:`Kernels <pyop2.Kernel>` described in :ref:`kernels`
+and executed by :func:`parallel loops <pyop2.par_loop>`.
+
+The API is the frontend to the PyOP2 runtime compilation architecture, which
+supports the generation and just-in-time (JIT) compilation of low-level code
+for a range of backends described in :doc:`backends` and the efficient
+scheduling of parallel computations. A schematic overview of the PyOP2
+architecture is given below:
+
+.. figure:: images/pyop2_architecture.svg
+  :align: center
+
+  Schematic overview of the PyOP2 architecture
+
+From an outside perspective, PyOP2 is a conventional Python library, with
+performance critical library functions implemented in Cython_. A user's
+application code makes calls to the PyOP2 API, most of which are conventional
+library calls.  The exception are :func:`~pyop2.par_loop` calls, which
+encapsulate PyOP2's runtime core functionality performing backend-specific
+code generation.  Executing a parallel loop comprises the following steps:
+
+1. Compute a parallel execution plan, including information for efficient
+   staging of data and partitioning and colouring of the iteration set for
+   conflict-free parallel execution.  This process is described in :doc:`plan`
+   and does not apply to the sequential backend.
+2. Generate backend-specific code for executing the computation for a given
+   set of :func:`~pyop2.par_loop` arguments as detailed in :doc:`backends`
+   according to the execution plan computed in the previous step.
+3. Pass the generated code to a backend-specific toolchain for just-in-time
+   compilation, producing a shared library callable as a Python module which
+   is dynamically loaded. This module is cached on disk to save recompilation
+   when the same :func:`~pyop2.par_loop` is called again for the same backend.
+4. Build the backend-specific list of arguments to be passed to the generated
+   code, which may initiate host to device data transfer for the CUDA and
+   OpenCL backends.
+5. Call into the generated module to perform the actual computation. For
+   distributed parallel computations this involves separate calls for the
+   regions owned by the current processor and the halo as described in
+   :doc:`mpi`.
+6. Perform any necessary reductions for :class:`Globals <pyop2.Global>`.
+7. Call the backend-specific matrix assembly procedure on any
+   :class:`~pyop2.Mat` arguments.
+
+.. _backend-support:
+
+Multiple Backend Support
+------------------------
+
+The backend is selected by passing the keyword argument ``backend`` to the
+:func:`~pyop2.init` function.  If omitted, the ``sequential`` backend is
+selected by default. This choice can be overridden by exporting the
+environment variable ``PYOP2_BACKEND``, which allows switching backends
+without having to touch the code. Once chosen, the backend cannot be changed
+for the duration of the running Python interpreter session.
+
+PyOP2 provides a single API to the user, regardless of which backend the
+computations are running on. All classes and functions that form the public
+API defined in :mod:`pyop2.op2` are interfaces, whose concrete implementations
+are initialised according to the chosen backend. A metaclass takes care of
+instantiating a backend-specific version of the requested class and setting
+the corresponding docstrings such that this process is entirely transparent to
+the user. The implementation of the PyOP2 backends is completely orthogonal to
+the backend selection process and free to use established practices of
+object-oriented design.
+
+.. _Cython: http://cython.org
diff --git a/_sources/backends.rst.txt b/_sources/backends.rst.txt
new file mode 100644
index 000000000..189e4cf60
--- /dev/null
+++ b/_sources/backends.rst.txt
@@ -0,0 +1,457 @@
+.. _backends:
+
+PyOP2 Backends
+==============
+
+PyOP2 provides a number of different backends to be able to run parallel
+computations on different hardware architectures. The currently supported
+backends are
+
+* ``sequential``: runs sequentially on a single CPU core.
+* ``openmp``: runs multiple threads on an SMP CPU using OpenMP. The number of
+  threads is set with the environment variable ``OMP_NUM_THREADS``.
+* ``cuda``: offloads computation to a NVIDA GPU (requires :ref:`CUDA and pycuda
+  <cuda-installation>`)
+* ``opencl``: offloads computation to an OpenCL device, either a multi-core
+  CPU or a GPU (requires :ref:`OpenCL and pyopencl <opencl-installation>`)
+
+Distributed parallel computations using MPI are supported by PyOP2 and
+described in detail in :doc:`mpi`. Datastructures must be partitioned among
+MPI processes with overlapping regions, so called halos.  The host backends
+``sequential`` and ``openmp`` have full MPI support, the device backends
+``cuda`` and ``opencl`` only support parallel loops on :class:`Dats
+<pyop2.Dat>`. Hybrid parallel computations with OpenMP are possible, where
+``OMP_NUM_THREADS`` threads are launched per MPI rank.
+
+.. _host_backends:
+
+Host backends
+-------------
+
+Any computation in PyOP2 requires the generation of code at runtime specific
+to each individual :func:`~pyop2.par_loop`. The host backends generate code
+which is just-in-time (JIT) compiled into a shared library callable
+via :mod:`ctypes`.  The compilation procedure also takes care of
+caching the compiled library on disk, such that the compilation cost
+is not paid every time.
+
+.. _sequential_backend:
+
+Sequential backend
+~~~~~~~~~~~~~~~~~~
+
+Since there is no parallel computation for the sequential backend, the
+generated code is a C wrapper function with a ``for`` loop calling the kernel
+for the respective :func:`~pyop2.par_loop`.  This wrapper also takes care of
+staging in and out the data as requested by the access descriptors requested
+in the parallel loop.  Both the kernel and the wrapper function are
+just-in-time compiled in a single compilation unit such that the kernel call
+can be inlined and does not incur any function call overhead.
+
+Recall the :func:`~pyop2.par_loop` calling the ``midpoint`` kernel from
+:doc:`kernels`: ::
+
+  op2.par_loop(midpoint, cells,
+               midpoints(op2.WRITE),
+               coordinates(op2.READ, cell2vertex))
+
+.. highlight:: c
+   :linenothreshold: 5
+
+The JIT compiled code for this loop is the kernel followed by the generated
+wrapper code: ::
+
+  inline void midpoint(double p[2], double *coords[2]) {
+    p[0] = (coords[0][0] + coords[1][0] + coords[2][0]) / 3.0;
+    p[1] = (coords[0][1] + coords[1][1] + coords[2][1]) / 3.0;
+  }
+
+  void wrap_midpoint__(PyObject *_start, PyObject *_end,
+                       PyObject *_arg0_0,
+                       PyObject *_arg1_0, PyObject *_arg1_0_map0_0) {
+    int start = (int)PyInt_AsLong(_start);
+    int end = (int)PyInt_AsLong(_end);
+    double *arg0_0 = (double *)(((PyArrayObject *)_arg0_0)->data);
+    double *arg1_0 = (double *)(((PyArrayObject *)_arg1_0)->data);
+    int *arg1_0_map0_0 = (int *)(((PyArrayObject *)_arg1_0_map0_0)->data);
+    double *arg1_0_vec[3];
+    for ( int n = start; n < end; n++ ) {
+      int i = n;
+      arg1_0_vec[0] = arg1_0 + arg1_0_map0_0[i * 3 + 0] * 2;
+      arg1_0_vec[1] = arg1_0 + arg1_0_map0_0[i * 3 + 1] * 2;
+      arg1_0_vec[2] = arg1_0 + arg1_0_map0_0[i * 3 + 2] * 2;
+      midpoint(arg0_0 + i * 2, arg1_0_vec);
+    }
+  }
+
+Note that the wrapper function is called directly from Python and therefore
+all arguments are plain Python objects, which first need to be unwrapped. The
+arguments ``_start`` and ``_end`` define the iteration set indices to iterate
+over. The remaining arguments are :class:`arrays <numpy.ndarray>`
+corresponding to a :class:`~pyop2.Dat` or :class:`~pyop2.Map` passed to the
+:func:`~pyop2.par_loop`. Arguments are consecutively numbered to avoid name
+clashes.
+
+The first :func:`~pyop2.par_loop` argument ``midpoints`` is direct and
+therefore no corresponding :class:`~pyop2.Map` is passed to the wrapper
+function and the data pointer is passed straight to the kernel with an
+appropriate offset. The second argument ``coordinates`` is indirect and hence
+a :class:`~pyop2.Dat`-:class:`~pyop2.Map` pair is passed. Pointers to the data
+are gathered via the :class:`~pyop2.Map` of arity 3 and staged in the array
+``arg1_0_vec``, which is passed to the kernel. The coordinate data can
+therefore be accessed in the kernel via double indirection with the
+:class:`~pyop2.Map` already applied. Note that for both arguments, the
+pointers are to two consecutive double values, since the
+:class:`~pyop2.DataSet` is of dimension two in either case.
+
+.. _openmp_backend:
+
+OpenMP backend
+~~~~~~~~~~~~~~
+
+In contrast to the sequential backend, the outermost ``for`` loop in the
+OpenMP backend is annotated with OpenMP pragmas to execute in parallel with
+multiple threads. To avoid race conditions on data access, the iteration set
+is coloured and a thread safe execution plan is computed as described in
+:ref:`plan-colouring`.
+
+The JIT compiled code for the parallel loop from above changes as follows: ::
+
+  void wrap_midpoint__(PyObject* _boffset,
+                       PyObject* _nblocks,
+                       PyObject* _blkmap,
+                       PyObject* _offset,
+                       PyObject* _nelems,
+                       PyObject *_arg0_0,
+                       PyObject *_arg1_0, PyObject *_arg1_0_map0_0) {
+    int boffset = (int)PyInt_AsLong(_boffset);
+    int nblocks = (int)PyInt_AsLong(_nblocks);
+    int* blkmap = (int *)(((PyArrayObject *)_blkmap)->data);
+    int* offset = (int *)(((PyArrayObject *)_offset)->data);
+    int* nelems = (int *)(((PyArrayObject *)_nelems)->data);
+    double *arg0_0 = (double *)(((PyArrayObject *)_arg0_0)->data);
+    double *arg1_0 = (double *)(((PyArrayObject *)_arg1_0)->data);
+    int *arg1_0_map0_0 = (int *)(((PyArrayObject *)_arg1_0_map0_0)->data);
+    double *arg1_0_vec[32][3];
+    #ifdef _OPENMP
+    int nthread = omp_get_max_threads();
+    #else
+    int nthread = 1;
+    #endif
+    #pragma omp parallel shared(boffset, nblocks, nelems, blkmap)
+    {
+      int tid = omp_get_thread_num();
+      #pragma omp for schedule(static)
+      for (int __b = boffset; __b < boffset + nblocks; __b++)
+      {
+        int bid = blkmap[__b];
+        int nelem = nelems[bid];
+        int efirst = offset[bid];
+        for (int n = efirst; n < efirst+ nelem; n++ )
+        {
+          int i = n;
+          arg1_0_vec[tid][0] = arg1_0 + arg1_0_map0_0[i * 3 + 0] * 2;
+          arg1_0_vec[tid][1] = arg1_0 + arg1_0_map0_0[i * 3 + 1] * 2;
+          arg1_0_vec[tid][2] = arg1_0 + arg1_0_map0_0[i * 3 + 2] * 2;
+          midpoint(arg0_0 + i * 2, arg1_0_vec[tid]);
+        }
+      }
+    }
+  }
+
+Computation is split into ``nblocks`` blocks which start at an initial offset
+``boffset`` and correspond to colours that can be executed conflict free in
+parallel. This loop over colours is therefore wrapped in an OpenMP parallel
+region and is annotated with an ``omp for`` pragma. The block id ``bid`` for
+each of these blocks is given by the block map ``blkmap`` and is the index
+into the arrays ``nelems`` and ``offset`` provided as part of the execution
+plan. These are the number of elements that are part of the given block and
+its starting index. Note that each thread needs its own staging array
+``arg1_0_vec``, which is therefore scoped by the thread id.
+
+.. _device_backends:
+
+Device backends
+---------------
+
+As with the host backends, the device backends have most of the implementation
+in common. The PyOP2 data carriers :class:`~pyop2.Dat`, :class:`~pyop2.Global`
+and :class:`~pyop2.Const` have a data array in host memory and a separate
+array in device memory. Flags indicate the present state of a given data
+carrier:
+
+* ``DEVICE_UNALLOCATED``: no data is allocated on the device
+* ``HOST_UNALLOCATED``: no data is allocated on the host
+* ``DEVICE``: data is up-to-date (valid) on the device, but invalid on the
+  host
+* ``HOST``: data is up-to-date (valid) on the host, but invalid on the device
+* ``BOTH``: data is up-to-date (valid) on both the host and device
+
+When a :func:`~pyop2.par_loop` is called, PyOP2 uses the
+:ref:`access-descriptors` to determine which data needs to be allocated or
+transferred from host to device prior to launching the kernel. Data is only
+transferred if it is out of date at the target location and all data transfer
+is triggered lazily i.e. the actual copy only occurs once the data is
+requested. In particular there is no automatic transfer back of data from
+device to host unless it is accessed on the host.
+
+A newly created device :class:`~pyop2.Dat` has no associated device data and
+starts out in the state ``DEVICE_UNALLOCATED``. The diagram below shows all
+actions that involve a state transition, which can be divided into three
+groups: calling explicit data transfer functions (red), access data on the
+host (black) and using the :class:`~pyop2.Dat` in a :func:`~pyop2.par_loop`
+(blue). There is no need for users to explicitly initiate data transfers and
+the tranfer functions are only given for completeness.
+
+.. figure:: images/pyop2_device_data_state.svg
+  :align: center
+
+  State transitions of a data carrier on PyOP2 device backends
+
+When a device :class:`~pyop2.Dat` is used in a :func:`~pyop2.par_loop` for the
+first time, data is allocated on the device. If the :class:`~pyop2.Dat` is
+only read, the host array is transferred to device if it was in state ``HOST``
+or ``DEVICE_UNALLOCATED`` before the :func:`~pyop2.par_loop` and the
+:class:`~pyop2.Dat` is in the state ``BOTH`` afterwards, unless it was in
+state ``DEVICE`` in which case it remains in that state. If the
+:class:`~pyop2.Dat` is written to, data transfer before the
+:func:`~pyop2.par_loop` is necessary unless the access descriptor is
+:data:`~pyop2.WRITE` and the host data is out of date afterwards and the
+:class:`~pyop2.Dat` is in the state ``DEVICE``. An overview of the state
+transitions and necessary memory allocations and data transfers for the two
+cases is given in the table below:
+
+======================  ==============================  ==================================================
+Initial state           :func:`~pyop2.par_loop` read    :func:`~pyop2.par_loop` written to
+======================  ==============================  ==================================================
+``DEVICE_UNALLOCATED``  ``BOTH`` (alloc, transfer h2d)  ``DEVICE`` (alloc, transfer h2d unless write-only)
+``DEVICE``              ``DEVICE``                      ``DEVICE``
+``HOST``                ``BOTH`` (transfer h2d)         ``DEVICE`` (transfer h2d unless write-only)
+``BOTH``                ``BOTH``                        ``DEVICE``
+======================  ==============================  ==================================================
+
+Accessing data on the host initiates a device to host data transfer if the
+:class:`~pyop2.Dat` is in state ``DEVICE`` and leaves it in state ``HOST``
+when using the :meth:`~pyop2.Dat.data` property and ``BOTH`` when using
+:meth:`~pyop2.Dat.data_ro`.
+
+The state transitions described above apply in the same way to a
+:class:`~pyop2.Global`. A :class:`~pyop2.Const` is read-only, never modified
+on device and therefore never out of date on the host. Hence there is no
+state ``DEVICE`` and it is not necessary to copy back :class:`~pyop2.Const`
+data from device to host.
+
+.. _cuda_backend:
+
+CUDA backend
+~~~~~~~~~~~~
+
+The CUDA backend makes extensive use of PyCUDA_ and its infrastructure for
+just-in-time compilation of CUDA kernels and interfacing them to Python.
+Linear solvers and sparse matrix data structures are implemented on top of the
+`CUSP library`_ and are described in greater detail in :doc:`linear_algebra`.
+Code generation uses a template based approach, where a ``__global__`` stub
+routine to be called from the host is generated, which takes care of data
+marshalling and calling the user kernel as an inline ``__device__`` function.
+
+We consider the same ``midpoint`` kernel as in the previous examples, which
+requires no CUDA-specific modifications and is automatically annotated with a
+``__device__`` qualifier. PyCUDA_ automatically generates a host stub for the
+generated kernel stub ``__midpoint_stub`` given a list of parameter types. It
+takes care of translating Python objects to plain C data types and pointers,
+such that a CUDA kernel can be launched straight from Python. The entire CUDA
+code PyOP2 generates is as follows: ::
+
+  __device__ void midpoint(double p[2], double *coords[2])
+  {
+    p[0] = ((coords[0][0] + coords[1][0]) + coords[2][0]) / 3.0;
+    p[1] = ((coords[0][1] + coords[1][1]) + coords[2][1]) / 3.0;
+  }
+
+  __global__ void __midpoint_stub(int set_size, int set_offset,
+      double *arg0,
+      double *ind_arg1,
+      int *ind_map,
+      short *loc_map,
+      int *ind_sizes,
+      int *ind_offs,
+      int block_offset,
+      int *blkmap,
+      int *offset,
+      int *nelems,
+      int *nthrcol,
+      int *thrcol,
+      int nblocks) {
+    extern __shared__ char shared[];
+    __shared__ int *ind_arg1_map;
+    __shared__ int ind_arg1_size;
+    __shared__ double * ind_arg1_shared;
+    __shared__ int nelem, offset_b, offset_b_abs;
+
+    double *ind_arg1_vec[3];
+
+    if (blockIdx.x + blockIdx.y * gridDim.x >= nblocks) return;
+    if (threadIdx.x == 0) {
+      int blockId = blkmap[blockIdx.x + blockIdx.y * gridDim.x + block_offset];
+      nelem = nelems[blockId];
+      offset_b_abs = offset[blockId];
+      offset_b = offset_b_abs - set_offset;
+
+      ind_arg1_size = ind_sizes[0 + blockId * 1];
+      ind_arg1_map = &ind_map[0 * set_size] + ind_offs[0 + blockId * 1];
+
+      int nbytes = 0;
+      ind_arg1_shared = (double *) &shared[nbytes];
+    }
+
+    __syncthreads();
+
+    // Copy into shared memory
+    for ( int idx = threadIdx.x; idx < ind_arg1_size * 2; idx += blockDim.x ) {
+      ind_arg1_shared[idx] = ind_arg1[idx % 2 + ind_arg1_map[idx / 2] * 2];
+    }
+
+    __syncthreads();
+
+    // process set elements
+    for ( int idx = threadIdx.x; idx < nelem; idx += blockDim.x ) {
+      ind_arg1_vec[0] = ind_arg1_shared + loc_map[0*set_size + idx + offset_b]*2;
+      ind_arg1_vec[1] = ind_arg1_shared + loc_map[1*set_size + idx + offset_b]*2;
+      ind_arg1_vec[2] = ind_arg1_shared + loc_map[2*set_size + idx + offset_b]*2;
+
+      midpoint(arg0 + 2 * (idx + offset_b_abs), ind_arg1_vec);
+    }
+  }
+
+The CUDA kernel ``__midpoint_stub`` is launched on the GPU for a specific
+number of threads in parallel. Each thread is identified inside the kernel by
+its thread id ``threadIdx`` within a block of threads identified by a two
+dimensional block id ``blockIdx`` within a grid of blocks.
+
+As for OpenMP, there is the potential for data races, which are prevented by
+colouring the iteration set and computing a parallel execution plan, where all
+elements of the same colour can be modified simultaneously. Each colour is
+computed by a block of threads in parallel. All threads of a thread block have
+access to a shared memory, which is used as a shared staging area initialised
+by thread 0 of each block, see lines 30-41 above. A call to
+``__syncthreads()`` ensures these initial values are visible to all threads of
+the block. After this barrier, all threads cooperatively gather data from the
+indirectly accessed :class:`~pyop2.Dat` via the :class:`~pyop2.Map`, followed
+by another synchronisation. Following that, each thread loops over the
+elements in the partition with an increment of the block size. In each
+iteration a thread-private array of pointers to coordinate data in shared
+memory is built which is then passed to the ``midpoint`` kernel. As for other
+backends, the first, directly accessed, argument, is passed as a pointer to
+global device memory with a suitable offset.
+
+.. _opencl_backend:
+
+OpenCL backend
+~~~~~~~~~~~~~~
+
+The other device backend OpenCL is structurally very similar to the CUDA
+backend. It uses PyOpenCL_ to interface to the OpenCL drivers and runtime.
+Linear algebra operations are handled by PETSc_ as described in
+:doc:`linear_algebra`. PyOP2 generates a kernel stub from a template similar
+to the CUDA case.
+
+Consider the ``midpoint`` kernel from previous examples, whose parameters in
+the kernel signature are automatically annotated with OpenCL storage
+qualifiers. PyOpenCL_ provides Python wrappers for OpenCL runtime functions to
+build a kernel from a code string, set its arguments and enqueue the kernel
+for execution. It takes care of the necessary conversion from Python objects
+to plain C data types. PyOP2 generates the following code for the ``midpoint``
+example: ::
+
+  #define ROUND_UP(bytes) (((bytes) + 15) & ~15)
+
+  void midpoint(__global double p[2], __local double *coords[2]);
+  void midpoint(__global double p[2], __local double *coords[2])
+  {
+    p[0] = ((coords[0][0] + coords[1][0]) + coords[2][0]) / 3.0;
+    p[1] = ((coords[0][1] + coords[1][1]) + coords[2][1]) / 3.0;
+  }
+
+  __kernel __attribute__((reqd_work_group_size(668, 1, 1)))
+  void __midpoint_stub(
+      __global double* arg0,
+      __global double* ind_arg1,
+      int set_size,
+      int set_offset,
+      __global int* p_ind_map,
+      __global short *p_loc_map,
+      __global int* p_ind_sizes,
+      __global int* p_ind_offsets,
+      __global int* p_blk_map,
+      __global int* p_offset,
+      __global int* p_nelems,
+      __global int* p_nthrcol,
+      __global int* p_thrcol,
+      __private int block_offset) {
+    __local char shared [64] __attribute__((aligned(sizeof(long))));
+    __local int offset_b;
+    __local int offset_b_abs;
+    __local int active_threads_count;
+
+    int nbytes;
+    int block_id;
+
+    int i_1;
+    // shared indirection mappings
+    __global int* __local ind_arg1_map;
+    __local int ind_arg1_size;
+    __local double* __local ind_arg1_shared;
+    __local double* ind_arg1_vec[3];
+
+    if (get_local_id(0) == 0) {
+      block_id = p_blk_map[get_group_id(0) + block_offset];
+      active_threads_count = p_nelems[block_id];
+      offset_b_abs = p_offset[block_id];
+      offset_b = offset_b_abs - set_offset;ind_arg1_size = p_ind_sizes[0 + block_id * 1];
+      ind_arg1_map = &p_ind_map[0 * set_size] + p_ind_offsets[0 + block_id * 1];
+
+      nbytes = 0;
+      ind_arg1_shared = (__local double*) (&shared[nbytes]);
+      nbytes += ROUND_UP(ind_arg1_size * 2 * sizeof(double));
+    }
+    barrier(CLK_LOCAL_MEM_FENCE);
+
+    // staging in of indirect dats
+    for (i_1 = get_local_id(0); i_1 < ind_arg1_size * 2; i_1 += get_local_size(0)) {
+      ind_arg1_shared[i_1] = ind_arg1[i_1 % 2 + ind_arg1_map[i_1 / 2] * 2];
+    }
+    barrier(CLK_LOCAL_MEM_FENCE);
+
+    for (i_1 = get_local_id(0); i_1 < active_threads_count; i_1 += get_local_size(0)) {
+      ind_arg1_vec[0] = ind_arg1_shared + p_loc_map[i_1 + 0*set_size + offset_b] * 2;
+      ind_arg1_vec[1] = ind_arg1_shared + p_loc_map[i_1 + 1*set_size + offset_b] * 2;
+      ind_arg1_vec[2] = ind_arg1_shared + p_loc_map[i_1 + 2*set_size + offset_b] * 2;
+
+      midpoint((__global double* __private)(arg0 + (i_1 + offset_b_abs) * 2), ind_arg1_vec);
+    }
+  }
+
+Parallel computations in OpenCL are executed by *work items* organised into
+*work groups*. OpenCL requires the annotation of all pointer arguments with
+the memory region they point to: ``__global`` memory is visible to any work
+item, ``__local`` memory to any work item within the same work group and
+``__private`` memory is private to a work item. PyOP2 does this annotation
+automatically for the user kernel if the OpenCL backend is used. Local memory
+therefore corresponds to CUDA's shared memory and private memory is called
+local memory in CUDA. The work item id within the work group is accessed via
+the OpenCL runtime call ``get_local_id(0)``, the work group id via
+``get_group_id(0)``. A barrier synchronisation across all work items of a work
+group is enforced with a call to ``barrier(CLK_LOCAL_MEM_FENCE)``. Bearing
+these differences in mind, the OpenCL kernel stub is structurally almost
+identical to the corresponding CUDA version above.
+
+The required local memory size per work group ``reqd_work_group_size`` is
+computed as part of the execution plan. In CUDA this value is a launch
+parameter to the kernel, whereas in OpenCL it needs to be hard coded as a
+kernel attribute.
+
+.. _FEniCS project: http://fenicsproject.org
+.. _PyCUDA: http://mathema.tician.de/software/pycuda/
+.. _CUSP library: http://cusplibrary.github.io
+.. _PyOpenCL: http://mathema.tician.de/software/pyopencl/
+.. _PETSc: http://www.mcs.anl.gov/petsc/petsc-as/
diff --git a/_sources/caching.rst.txt b/_sources/caching.rst.txt
new file mode 100644
index 000000000..6e894ecbb
--- /dev/null
+++ b/_sources/caching.rst.txt
@@ -0,0 +1,112 @@
+.. _caching:
+
+Caching in PyOP2
+================
+
+PyOP2 makes heavy use of caches to ensure performance is not adversely
+affected by too many runtime computations.  The caching in PyOP2 takes
+a number of forms:
+
+1. Disk-based caching of generated code
+
+   Since compiling a generated code module may be an expensive
+   operation, PyOP2 caches the generated code on disk such that
+   subsequent runs of the same simulation will not have to pay a
+   compilation cost.
+
+2. In memory caching of generated code function pointers
+
+   Once code has been generated and loaded into the running PyOP2
+   process, we cache the resulting callable function pointer for the
+   lifetime of the process, such that subsequent calls to the same
+   generated code are fast.
+
+3. In memory caching of expensive to build objects
+
+   Some PyOP2 objects, in particular :class:`~pyop2.Sparsity` objects,
+   can be expensive to construct.  Since a sparsity does not change if
+   it is built again with the same arguments, we only construct the
+   sparsity once for each unique set of arguments.
+
+The caching strategies for PyOP2 follow from two axioms:
+
+1. For PyOP2 :class:`~pyop2.Set`\s and :class:`~pyop2.Map`\s, equality
+   is identity
+2. Caches of generated code should depend on metadata, but not data
+
+The first axiom implies that two :class:`~pyop2.Set`\s or
+:class:`~pyop2.Map`\s compare equal if and only if they are the same
+object.  The second implies that generated code must be *independent*
+of the absolute size of the data the :func:`~pyop2.par_loop` that
+generated it executed over.  For example, the size of the iteration
+set should not be part of the key, but the arity of any maps and size
+and type of every data item should be.
+
+On consequence of these rules is that there are effectively two
+separate types of cache in PyOP2, object and class caches,
+distinguished by where the cache itself lives.
+
+Class caches
+------------
+
+These are used to cache objects that depend on metadata, but not
+object instances, such are generated code.  They are implemented by
+the cacheable class inheriting from :class:`~.Cached`.
+
+.. note::
+
+   There is currently no eviction strategy for class caches, should
+   they grow too large, for example by executing many different parallel
+   loops, an out of memory error can occur
+
+Object caches
+-------------
+
+These are used to cache objects that are built on top of
+:class:`~pyop2.Set`\s and :class:`~pyop2.Map`\s.  They are implemented by the
+cacheable class inheriting from :class:`~.ObjectCached` and the
+caching instance defining a ``_cache`` attribute.
+
+The motivation for these caches is that cache key for objects such as
+sparsities relies on an identical sparsity being built if the
+arguments are identical.  So that users of the API do not have to
+worry too much about carrying around "temporary" objects forever such
+that they will hit caches, PyOP2 builds up a hierarchy of caches of
+transient objects on top of the immutable sets and maps.
+
+So, for example, the user can build and throw away
+:class:`~pyop2.DataSet`\s as normal in their code.  Internally, however,
+these instances are cached on the set they are built on top of.  Thus,
+in the following snippet, we have that ``ds`` and ``ds2`` are the same
+object:
+
+.. code-block:: python
+
+   s = op2.Set(1)
+   ds = op2.DataSet(s, 10)
+   ds2 = op2.DataSet(s, 10)
+   assert ds is ds2
+
+The setup of these caches is such that the lifetime of objects in the
+cache is tied to the lifetime of both the caching and the cached
+object.  In the above example, as long as the user program holds a
+reference to one of ``s``, ``ds`` or ``ds2`` all three objects will
+remain live.  As soon as all references are lost, all three become
+candidates for garbage collection.
+
+.. note::
+
+   The cache eviction strategy for these caches relies on the Python
+   garbage collector, and hence on the user not holding onto
+   references to some of either the cached or the caching objects for
+   too long.  Should the objects on which the caches live persist, an
+   out of memory error may occur.
+
+Debugging cache leaks
+---------------------
+
+To debug potential problems with the cache, PyOP2 can be instructed to
+print the size of both object and class caches at program exit.  This
+can be done by setting the environment variable
+``PYOP2_PRINT_CACHE_SIZE`` to 1 before running a PyOP2 program, or
+passing the ``print_cache_size`` to :func:`~pyop2.init`.
diff --git a/_sources/concepts.rst.txt b/_sources/concepts.rst.txt
new file mode 100644
index 000000000..f62ae0885
--- /dev/null
+++ b/_sources/concepts.rst.txt
@@ -0,0 +1,268 @@
+.. _concepts:
+
+PyOP2 Concepts
+==============
+
+Many numerical algorithms and scientific computations on unstructured meshes
+can be viewed as the *independent application* of a *local operation*
+everywhere on a mesh. This local operation is often called a computational
+*kernel* and its independent application lends itself naturally to parallel
+computation. An unstructured mesh can be described by *sets of entities*
+(vertices, edges, cells) and the connectivity between those sets forming the
+topology of the mesh.
+
+PyOP2 is a domain-specific language (DSL) for the parallel executions of
+computational kernels on unstructured meshes or graphs.
+
+.. _sets:
+
+Sets and mappings
+-----------------
+
+A mesh is defined by :class:`sets <pyop2.Set>` of entities and
+:class:`mappings <pyop2.Map>` between these sets. Sets are used to represent
+entities in the mesh (nodes in the graph) or degrees of freedom of data
+(fields) living "on" the mesh (graph), while maps define the connectivity
+between entities (links in the graph) or degrees of freedom, for example
+associating an edge with its incident vertices. Sets of mesh entities may
+coincide with sets of degrees of freedom, but this is not necessarily the case
+e.g. the set of degrees of freedom for a field may be defined on the vertices
+of the mesh and the midpoints of edges connecting the vertices.
+
+.. note ::
+  There is a requirement for the map to be of *constant arity*, that is each
+  element in the source set must be associated with a constant number of
+  elements in the target set. There is no requirement for the map to be
+  injective or surjective. This restriction excludes certain kinds of mappings
+  e.g. a map from vertices to incident egdes or cells is only possible on a
+  very regular mesh where the multiplicity of any vertex is constant.
+
+In the following we declare a :class:`~pyop2.Set` ``vertices``, a
+:class:`~pyop2.Set` ``edges`` and a :class:`~pyop2.Map` ``edges2vertices``
+between them, which associates the two incident vertices with each edge: ::
+
+    vertices = op2.Set(4)
+    edges = op2.Set(3)
+    edges2vertices = op2.Map(edges, vertices, 2, [[0, 1], [1, 2], [2, 3]])
+
+.. _data:
+
+Data
+----
+
+PyOP2 distinguishes three kinds of user provided data: data that lives on a
+set (often referred to as a field) is represented by a :class:`~pyop2.Dat`,
+data that has no association with a set by a :class:`~pyop2.Global` and data
+that is visible globally and referred to by a unique identifier is declared as
+:class:`~pyop2.Const`. Examples of the use of these data types are given in
+the :ref:`par_loops` section below.
+
+.. _data_dat:
+
+Dat
+~~~
+
+Since a set does not have any type but only a cardinality, data declared on a
+set through a :class:`~pyop2.Dat` needs additional metadata to allow PyOP2 to
+interpret the data and to specify how much memory is required to store it. This
+metadata is the *datatype* and the *shape* of the data associated with any
+given set element. The shape is not associated with the :class:`~pyop2.Dat`
+directly, but with a :class:`~pyop2.DataSet`. One can associate a scalar with
+each element of the set or a one- or higher-dimensional vector. Similar to the
+restriction on maps, the shape and therefore the size of the data associated
+which each element needs to be uniform. PyOP2 supports all common primitive
+data types supported by `NumPy`_.  Custom datatypes are supported insofar as
+the user implements the serialisation and deserialisation of that type into
+primitive data that can be handled by PyOP2.
+
+Declaring coordinate data on the ``vertices`` defined above, where two float
+coordinates are associated with each vertex, is done like this: ::
+
+    dvertices = op2.DataSet(vertices, dim=2)
+    coordinates = op2.Dat(dvertices,
+                          [[0.0, 0.0], [0.0, 1.0], [1.0, 1.0], [1.0, 0.0]],
+                          dtype=float)
+
+.. _data_global:
+
+Global
+~~~~~~
+
+In contrast to a :class:`~pyop2.Dat`, a :class:`~pyop2.Global` has no
+association to a set and the shape and type of the data are declared directly
+on the :class:`~pyop2.Global`. A 2x2 elasticity tensor would be defined as
+follows: ::
+
+    elasticity = op2.Global((2, 2), [[1.0, 0.0], [0.0, 1.0]], dtype=float)
+
+.. _data_const:
+
+Const
+~~~~~
+
+Data that is globally visible and read-only to kernels is declared with a
+:class:`~pyop2.Const` and needs to have a globally unique identifier.  It does
+not need to be declared as an argument to a :func:`~pyop2.par_loop`, but is
+accessible in a kernel by name. A globally visible parameter ``eps`` would be
+declared as follows: ::
+
+    eps = op2.Const(1, 1e-14, name="eps", dtype=float)
+
+.. _data_mat:
+
+Mat
+~~~
+
+In a PyOP2 context, a (sparse) matrix is a linear operator from one set to
+another. In other words, it is a linear function which takes a
+:class:`~pyop2.Dat` on one set :math:`A` and returns the value of a
+:class:`~pyop2.Dat` on another set :math:`B`. Of course, in particular,
+:math:`A` may be the same set as :math:`B`. This makes the operation of at
+least some matrices equivalent to the operation of a particular PyOP2 kernel.
+
+PyOP2 can be used to assemble :class:`matrices <pyop2.Mat>`, which are defined
+on a :class:`sparsity pattern <pyop2.Sparsity>` which is built from a pair of
+:class:`DataSets <pyop2.DataSet>` defining the row and column spaces the
+sparsity maps between and one or more pairs of maps, one for the row and one
+for the column space of the matrix respectively. The sparsity uniquely defines
+the non-zero structure of the sparse matrix and can be constructed purely from
+those mappings. To declare a :class:`~pyop2.Mat` on a :class:`~pyop2.Sparsity`
+only the data type needs to be given.
+
+Since the construction of large sparsity patterns is a very expensive
+operation, the decoupling of :class:`~pyop2.Mat` and :class:`~pyop2.Sparsity`
+allows the reuse of sparsity patterns for a number of matrices without
+recomputation. In fact PyOP2 takes care of caching sparsity patterns on behalf
+of the user, so declaring a sparsity on the same maps as a previously declared
+sparsity yields the cached object instead of building another one.
+
+Defining a matrix of floats on a sparsity which spans from the space of
+vertices to the space of vertices via the edges is done as follows: ::
+
+    sparsity = op2.Sparsity((dvertices, dvertices),
+                            [(edges2vertices, edges2vertices)])
+    matrix = op2.Mat(sparsity, float)
+
+.. _par_loops:
+
+Parallel loops
+--------------
+
+Computations in PyOP2 are executed as :func:`parallel loops <pyop2.par_loop>`
+of a :class:`~pyop2.Kernel` over an *iteration set*. Parallel loops are the
+core construct of PyOP2 and hide most of its complexity such as parallel
+scheduling, partitioning, colouring, data transfer from and to device and
+staging of the data into on chip memory. Computations in a parallel loop must
+be independent of the order in which they are executed over the set to allow
+PyOP2 maximum flexibility to schedule the computation in the most efficient
+way. Kernels are described in more detail in :doc:`kernels`.
+
+.. _loop-invocations:
+
+Loop invocations
+~~~~~~~~~~~~~~~~
+
+A parallel loop invocation requires as arguments, other than the iteration set
+and the kernel to operate on, the data the kernel reads and/or writes. A
+parallel loop argument is constructed by calling the underlying data object
+(i.e. the :class:`~pyop2.Dat` or :class:`~pyop2.Global`) and passing an
+*access descriptor* and the mapping to be used when accessing the data. The
+mapping is required for an *indirectly accessed* :class:`~pyop2.Dat` not
+declared on the same set as the iteration set of the parallel loop. In the
+case of *directly accessed* data defined on the same set as the iteration set
+the map is omitted and only an access descriptor given.
+
+Consider a parallel loop that translates the ``coordinate`` field by a
+constant offset given by the :class:`~pyop2.Const` ``offset``. Note how the
+kernel has access to the local variable ``offset`` even though it has not been
+passed as an argument to the :func:`~pyop2.par_loop`. This loop is direct and
+the argument ``coordinates`` is read and written: ::
+
+    op2.Const(2, [1.0, 1.0], dtype=float, name="offset");
+
+    translate = op2.Kernel("""void translate(double * coords) {
+      coords[0] += offset[0];
+      coords[1] += offset[1];
+    }""", "translate")
+
+    op2.par_loop(translate, vertices, coordinates(op2.RW))
+
+.. _access-descriptors:
+
+Access descriptors
+~~~~~~~~~~~~~~~~~~
+
+Access descriptors define how the data is accessed by the kernel and give
+PyOP2 crucial information as to how the data needs to be treated during
+staging in before and staging out after kernel execution. They must be one of
+:data:`pyop2.READ` (read-only), :data:`pyop2.WRITE` (write-only),
+:data:`pyop2.RW` (read-write), :data:`pyop2.INC` (increment),
+:data:`pyop2.MIN` (minimum reduction) or :data:`pyop2.MAX` (maximum
+reduction).
+
+Not all of these descriptors apply to all PyOP2 data types. A
+:class:`~pyop2.Dat` can have modes :data:`~pyop2.READ`, :data:`~pyop2.WRITE`,
+:data:`~pyop2.RW` and :data:`~pyop2.INC`. For a :class:`~pyop2.Global` the
+valid modes are :data:`~pyop2.READ`, :data:`~pyop2.INC`, :data:`~pyop2.MIN` and
+:data:`~pyop2.MAX` and for a :class:`~pyop2.Mat` only :data:`~pyop2.WRITE` and
+:data:`~pyop2.INC` are allowed.
+
+.. _matrix-loops:
+
+Loops assembling matrices
+~~~~~~~~~~~~~~~~~~~~~~~~~
+
+We declare a parallel loop assembling the ``matrix`` via a given ``kernel``
+which we'll assume has been defined before over the ``edges`` and with
+``coordinates`` as input data. The ``matrix`` is the output argument of this
+parallel loop and therefore has the access descriptor :data:`~pyop2.INC` since
+the assembly accumulates contributions from different vertices via the
+``edges2vertices`` mapping. Note that the mappings are being indexed with the
+:class:`iteration indices <pyop2.base.IterationIndex>` ``op2.i[0]`` and
+``op2.i[1]`` respectively. This means that PyOP2 generates a :ref:`local
+iteration space <local-iteration-spaces>` of size ``arity * arity`` with the
+``arity`` of the :class:`~pyop2.Map` ``edges2vertices`` for any given element
+of the iteration set.  This local iteration space is then iterated over using
+the iteration indices on the maps.  The kernel is assumed to only apply to a
+single point in that local iteration space. The ``coordinates`` are accessed
+via the same mapping, but are a read-only input argument to the kernel and
+therefore use the access descriptor :data:`~pyop2.READ`: ::
+
+    op2.par_loop(kernel, edges,
+                 matrix(op2.INC, (edges2vertices[op2.i[0]],
+                                  edges2vertices[op2.i[1]])),
+                 coordinates(op2.READ, edges2vertices))
+
+You can stack up multiple successive parallel loops that add values to
+a matrix, before you use the resulting values, you must explicitly
+tell PyOP2 that you want to do so, by calling
+:meth:`~pyop2.Mat.assemble` on the matrix.  Note that executing a
+:func:`~pyop2.solve` will do this automatically for you.
+
+.. _reduction-loops:
+
+Loops with global reductions
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+:class:`Globals <pyop2.Global>` are used primarily for reductions where a
+given quantity on a field is reduced to a single number by summation or
+finding the minimum or maximum. Consider a kernel computing the `L2 norm`_ of
+the ``pressure`` field defined on the set of ``vertices`` as ``l2norm``. Note
+that the :class:`~pyop2.Dat` constructor automatically creates an anonymous
+:class:`~pyop2.DataSet` of dimension 1 if a :class:`~pyop2.Set` is passed as
+the first argument. We assume ``pressure`` is the result of some prior
+computation and only give the declaration for context. ::
+
+    pressure = op2.Dat(vertices, [...], dtype=float)
+    l2norm = op2.Global(dim=1, data=[0.0])
+
+    norm = op2.Kernel("""void norm(double * out, double * field) {
+      *out += field[0] * field[0];
+    }""", "norm")
+
+    op2.par_loop(pressure, vertices,
+                 l2norm(op2.INC),
+                 vertices(op2.READ))
+
+.. _NumPy: http://docs.scipy.org/doc/numpy/reference/arrays.dtypes.html
+.. _L2 norm: https://en.wikipedia.org/wiki/L2_norm#Euclidean_norm
diff --git a/_sources/index.rst.txt b/_sources/index.rst.txt
new file mode 100644
index 000000000..50e2f8930
--- /dev/null
+++ b/_sources/index.rst.txt
@@ -0,0 +1,44 @@
+.. PyOP2 documentation master file, created by
+   sphinx-quickstart on Tue Aug 14 10:10:00 2012.
+   You can adapt this file completely to your liking, but it should at least
+   contain the root `toctree` directive.
+
+Welcome to PyOP2's documentation!
+=================================
+
+.. warning::
+   The prose documentation contained here is significantly out-of-date and thus
+   contains many inaccuracies. It is, nevertheless, quite a useful resource for 
+   people new to PyOP2. Please read with care.
+
+   The API documentation, however, is updated regularly and can be considered
+   accurate.
+
+Contents:
+
+.. toctree::
+   :maxdepth: 2
+
+   installation
+   concepts
+   kernels
+   ir
+   architecture
+   backends
+   linear_algebra
+   plan
+   mixed
+   mpi
+   caching
+   profiling
+   user
+   pyop2
+
+
+Indices and tables
+==================
+
+* :ref:`genindex`
+* :ref:`modindex`
+* :ref:`search`
+
diff --git a/_sources/installation.rst.txt b/_sources/installation.rst.txt
new file mode 100644
index 000000000..44dcf0348
--- /dev/null
+++ b/_sources/installation.rst.txt
@@ -0,0 +1,20 @@
+.. image:: https://travis-ci.org/OP2/PyOP2.png?branch=master
+  :target: https://travis-ci.org/OP2/PyOP2
+  :alt: build status
+
+.. contents::
+
+Installing PyOP2
+================
+
+PyOP2 requires Python 3.6 or later.
+
+The main testing platform for PyOP2 is Ubuntu 18.04 64-bit with Python
+3.6. Later Ubuntu versions should also work. Some users successfully
+use PyOP2 on Mac OS X.
+
+Installation of the dependencies is somewhat involved, and therefore
+the recommended way to obtain PyOP2 is by using the `Firedrake
+installation script
+<https://www.firedrakeproject.org/download.html>`__.  This will give
+you a Python 3 venv that contains a working PyOP2 installation.
diff --git a/_sources/ir.rst.txt b/_sources/ir.rst.txt
new file mode 100644
index 000000000..9d9ea13f9
--- /dev/null
+++ b/_sources/ir.rst.txt
@@ -0,0 +1,324 @@
+The PyOP2 Intermediate Representation
+=====================================
+
+The :class:`parallel loop <pyop2.par_loop>` is the main construct of PyOP2.
+It applies a specific :class:`~pyop2.Kernel` to all elements in the iteration
+set of the parallel loop. Here, we describe how to use the PyOP2 API to build
+a kernel and, also, we provide simple guidelines on how to write efficient
+kernels.
+
+Using the Intermediate Representation
+-------------------------------------
+
+In the :doc:`previous section <kernels>`, we described the API for
+PyOP2 kernels in terms of the C code that gets executed.
+Passing in a string of C code is the simplest way of creating a
+:class:`~pyop2.Kernel`.  Another possibility is to use PyOP2 Intermediate
+Representation (IR) objects to express the :class:`~pyop2.Kernel` semantics.
+
+An Abstract Syntax Tree of the kernel code can be manually built using IR
+objects. Since PyOP2 has been primarily thought to be fed by higher layers
+of abstractions, rather than by users, no C-to-AST parser is currently provided.
+The advantage of providing an AST, instead of C code, is that it enables PyOP2
+to inspect and transform the kernel, which is aimed at achieving performance
+portability among different architectures and, more generally, better execution
+times.
+
+For the purposes of exposition, let us consider a simple
+kernel ``init`` which initialises the members of a :class:`~pyop2.Dat`
+to zero.
+
+.. code-block:: python
+
+  from op2 import Kernel
+
+  code = """void init(double* edge_weight) {
+    for (int i = 0; i < 3; i++)
+      edge_weight[i] = 0.0;
+  }"""
+  kernel = Kernel(code, "init")
+
+Here, we describe how we can use PyOP2 IR objects to build an AST for
+the this kernel. For example, the most basic AST one can come up with
+is
+
+.. code-block:: python
+
+  from op2 import Kernel
+  from ir.ast_base import *
+
+  ast = FlatBlock("""void init(double* edge_weight) {
+    for (int i = 0; i < 3; i++)
+      edge_weight[i] = 0.0;
+  }""")
+  kernel = Kernel(ast, "init")
+
+The :class:`~pyop2.ir.ast_base.FlatBlock` object encapsulates a "flat" block
+of code, which is not modified by the IR engine. A
+:class:`~pyop2.ir.ast_base.FlatBlock` is used to represent (possibly large)
+fragments of code for which we are not interested in any kind of
+transformation, so it may be particularly useful to speed up code development
+when writing, for example, test cases or non-expensive kernels.  On the other
+hand, time-demanding kernels should be properly represented using a "real"
+AST. For example, an useful AST for ``init`` could be the following
+
+.. code-block:: python
+
+  from op2 import Kernel
+  from ir.ast_base import *
+
+  ast_body = [FlatBlock("...some code can go here..."),
+              c_for("i", 3, Assign(Symbol("edge_weight", ("i",)), c_sym("0.0")))]
+  ast = FunDecl("void", "init",
+                [Decl("double*", c_sym("edge_weight"))],
+                ast_body)
+  kernel = Kernel(ast, "init")
+
+In this example, we first construct the body of the kernel function. We have
+an initial :class:`~pyop2.ir.ast_base.FlatBlock` that contains, for instance,
+some sort of initialization code. :func:`~pyop2.ir.ast_base.c_for` is a shortcut
+for building a :class:`for loop <pyop2.ir.ast_base.For>`.  It takes an
+iteration variable (``i``), the extent of the loop and its body.  Multiple
+statements in the body can be passed in as a list.
+:func:`~pyop2.ir.ast_base.c_sym` is a shortcut for building :class:`symbols
+<pyop2.ir.ast_base.Symbol>`. You may want to use
+:func:`~pyop2.ir.ast_base.c_sym` when the symbol makes no explicit use of
+iteration variables.
+
+We use :class:`~pyop2.ir.ast_base.Symbol` instead of
+:func:`~pyop2.ir.ast_base.c_sym`,  when ``edge_weight`` accesses a specific
+element using the iteration variable ``i``. This is fundamental to allow the
+IR engine to perform many kind of transformations involving the kernel's
+iteration space(s). Finally, the signature of the function is constructed
+using the :class:`~pyop2.ir.ast_base.FunDecl`.
+
+Other examples on how to build ASTs can be found in the tests folder,
+particularly looking into ``test_matrices.py`` and
+``test_iteration_space_dats.py``.
+
+
+Achieving Performance Portability with the IR
+---------------------------------------------
+
+One of the key objectives of PyOP2 is obtaining performance portability.
+This means that exactly the same program can be executed on a range of
+different platforms, and that the PyOP2 engine will strive to get the best
+performance out of the chosen platform. PyOP2 allows users to write kernels
+by completely abstracting from the underlying machine. This is mainly
+achieved in two steps:
+
+* Given the AST of a kernel, PyOP2 applies a first transformation aimed at
+  mapping the parallelism inherent to the kernel to that available in the
+  backend.
+* Then, PyOP2 applies optimizations to the sequential code, depending on the
+  underlying backend.
+
+To maximize the outcome of the transformation process, it is important that
+kernels are written as simply as possible. That is, premature optimization,
+possibly for a specific backend, might harm performance.
+
+A minimal language, the so-called PyOP2 Kernel Domain-Specific Language, is
+used to trigger specific transformations. If we had had a parser from C
+code to AST, we would have embedded this DSL in C by means of ``pragmas``.
+As we directly build an AST, we achieve the same goal by decorating AST nodes
+with specific attributes, added at node creation-time. An overview of the
+language follows
+
+* ``pragma pyop2 itspace``. This is added to :class:`~pyop2.ir.ast_base.For`
+  nodes (i.e. written on top of for loops). It tells PyOP2 that the following
+  is a fully-parallel loop, that is all of its iterations can be executed in
+  parallel without any sort of synchronization.
+* ``pragma pyop2 assembly(itvar1, itvar2)``. This is added to a statement node,
+  to denote that we are performing a local assembly operation along to the
+  ``itvar1`` and ``itvar2`` dimensions.
+* ``pragma pyop2 simd``. This is added on top of the kernel signature. It is
+  used to suggest PyOP2 to apply SIMD vectorization along the ParLoop's
+  iteration set dimension. This kind of vectorization is also known as
+  *inter-kernel vectorization*. This feature is currently not supported
+  by PyOP2, and will be added only in a future release.
+
+The ``itspace`` pragma tells PyOP2 how to extract parallelism from the kernel.
+Consider again our usual example. To expose a parallel iteration space, one
+one must write
+
+.. code-block:: python
+
+  from op2 import Kernel
+
+  code = """void init(double* edge_weight) {
+    #pragma pyop2 itspace
+    for (int i = 0; i < 3; i++)
+      edge_weight[i] = 0.0;
+  }"""
+  kernel = Kernel(code, "init")
+
+The :func:`~pyop2.ir.ast_base.c_for` shortcut when creating an AST expresses
+the same semantics of a for loop decorated with a ``pragma pyop2 itspace``.
+
+Now, imagine we are executing the ``init`` kernel on a CPU architecture.
+Typically we want a single core to execute the entire kernel, because it is
+very likely that the kernel's iteration space is small and its working set
+fits the L1 cache, and no benefit would be gained by splitting the computation
+between distinct cores. On the other end, if the backend is a GPU or an
+accelerator, a different execution model might give better performance.
+There's a huge amount of parallelism available, for example, in a GPU, so
+delegating the execution of an individual iteration (or a chunk of iterations)
+to a single thread could pay off. If that is the case, the PyOP2 IR engine
+re-structures the kernel code to exploit such parallelism.
+
+Optimizing kernels on CPUs
+--------------------------
+
+So far, some effort has been spent on optimizations for CPU platforms. Being a
+DSL, PyOP2 provides specific support for those (linear algebra) operations that
+are common among unstructured-mesh-based numerical methods. For example, PyOP2
+is capable of aggressively optimizing local assembly codes for applications
+based on the Finite Element Method. We therefore distinguish optimizations in
+two categories:
+
+* Generic optimizations, such as data alignment and support for autovectorization.
+* Domain-specific optimizations (DSO)
+
+To trigger DSOs, statements must be decorated using the kernel DSL. For example,
+if the kernel computes the local assembly of an element in an unstructured mesh,
+then a ``pragma pyop2 assembly(itvar1, itvar2)`` should be added on top of the
+corresponding statement. When constructing the AST of a kernel, this can be
+simply achieved by
+
+.. code-block:: python
+
+  from ir.ast_base import *
+
+  s1 = Symbol("X", ("i",))
+  s2 = Symbol("Y", ("j",))
+  tensor = Symbol("A", ("i", "j"))
+  pragma = "#pragma pyop2 outerproduct(j,k)"
+  code = c_for("i", 3, c_for("j", 3, Incr(tensor, Prod(s1, s2), pragma)))
+
+That, conceptually, corresponds to
+
+.. code-block:: c
+
+  #pragma pyop2 itspace
+  for (int i = 0; i < 3; i++)
+    #pragma pyop2 itspace
+    for (int j = 0; j < 3; j++)
+      #pragma pyop2 assembly(i, j)
+      A[i][j] += X[i]*Y[j]
+
+Visiting the AST, PyOP2 finds a 2-dimensional iteration space and an assembly
+statement. Currently, ``#pragma pyop2 itspace`` is ignored when the backend is
+a CPU. The ``#pragma pyop2 assembly(i, j)`` can trigger multiple DSOs.
+PyOP2 currently lacks an autotuning system that automatically finds out the
+best possible kernel implementation; that is, the optimizations that minimize
+the kernel run-time. To drive the optimization process, the user (or the
+higher layer) can specify which optimizations should be applied. Currently,
+PyOP2 can automate:
+
+* Alignment and padding of data structures: for issuing aligned loads and stores.
+* Loop trip count adjustment according to padding: useful for autovectorization
+  when the trip count is not a multiple of the vector length
+* Loop-invariant code motion and autovectorization of invariant code: this is
+  particularly useful since trip counts are typically small, and hoisted code
+  can still represent a significant proportion of the execution time
+* Register tiling for rectangular iteration spaces
+* (DSO for pragma assembly): Outer-product vectorization + unroll-and-jam of
+  outer loops to improve register re-use or to mitigate register pressure
+
+How to select specific kernel optimizations
+-------------------------------------------
+
+When constructing a :class:`~pyop2.Kernel`, it is possible to specify the set
+of optimizations we want PyOP2 to apply. The IR engine will analyse the kernel
+AST and will try to apply, incrementally, such optimizations. The PyOP2's FFC
+interface, which build a :class:`~pyop2.Kernel` object given an AST provided
+by FFC, makes already use of the available optimizations. Here, we take the
+emblematic case of the FFC interface and describe how to play with the various
+optimizations through a series of examples.
+
+.. code-block:: python
+
+  ast = ...
+  opts = {'licm': False,
+          'tile': None,
+          'ap': False,
+          'vect': None}
+  kernel = Kernel(ast, 'my_kernel', opts)
+
+In this example, we have an AST ``ast`` and we specify optimizations through
+the dictionary ``opts``; then, we build the :class:`~pyop2.Kernel`, passing in
+the optional argument ``opts``. No optimizations are enabled here. The
+possible options are:
+
+* ``licm``: Loop-Invariant Code Motion.
+* ``tile``: Register Tiling (of rectangular iteration spaces)
+* ``ap``: Data alignment, padding. Trip count adjustment.
+* ``vect``: SIMD intra-kernel vectorization.
+
+If we wanted to apply both loop-invariant code motion and data alignment, we
+would simply write
+
+.. code-block:: python
+
+  ast = ...
+  opts = {'licm': True,
+          'ap': True}
+  kernel = Kernel(ast, 'my_kernel', opts)
+
+Now, let's assume we know the kernel has a rectangular iteration space. We want
+to try register tiling, with a particular tile size. The way to get it is
+
+.. code-block:: python
+
+  ast = ...
+  opts = {'tile': (True, 8)}
+  kernel = Kernel(ast, 'my_kernel', opts)
+
+In this case, the iteration space is sliced into tiles of size 8x8. If the
+iteration space is smaller than the slice, then the transformation is not
+applied. By specifying ``-1`` instead of ``8``, we leave PyOP2 free to choose
+automatically a certain tile size.
+
+A fundamental optimization for any PyOP2 kernel is SIMD vectorization. This is
+because almost always kernels fit the L1 cache and are likely to be compute-
+bound. Backend compilers' AutoVectorization (AV) is therefore an opportunity.
+By enforcing data alignment and padding, we can increase the chance AV is
+successful. To try AV, one should write
+
+.. code-block:: python
+
+  import ir.ast_plan as ap
+
+  ast = ...
+  opts = {'ap': True,
+          'vect': (ap.AUTOVECT, -1)}
+  kernel = Kernel(ast, 'my_kernel', opts)
+
+The ``vect``'s second parameter (-1) is ignored when AV is requested.
+If our kernel is computing an assembly-like operation, then we can ask PyOP2
+to optimize for register locality and register pressure, by resorting to a
+different vectorization technique. Early experiments show that this approach
+can be particularly useful when the amount of data movement in the assembly
+loops is "significant". Of course, this depends on kernel parameters (e.g.
+size of assembly loop, number and size of arrays involved in the assembly) as
+well as on architecture parameters (e.g. size of L1 cache, number of available
+registers). This strategy takes the name of *Outer-Product Vectorization*
+(OP), and can be activated in the following way (again, we suggest to use it
+along with data alignment and padding).
+
+.. code-block:: python
+
+  import ir.ast_plan as ap
+
+  ast = ...
+  opts = {'ap': True,
+          'vect': (ap.V_OP_UAJ, 1)}
+  kernel = Kernel(ast, 'my_kernel', opts)
+
+``UAJ`` in ``V_OP_UAJ`` stands for ``Unroll-and-Jam``. It has been proved that
+OP shows a much better performance when used in combination with unrolling the
+outer assembly loop and incorporating (*jamming*) the unrolled iterations
+within the inner loop. The second parameter, therefore, specifies the unroll-
+and-jam factor: the higher it is, the larger is the number of iterations
+unrolled. A factor 1 means that no unroll-and-jam is performed. The optimal
+factor highly depends on the computational characteristics of the kernel.
diff --git a/_sources/kernels.rst.txt b/_sources/kernels.rst.txt
new file mode 100644
index 000000000..23dcc7307
--- /dev/null
+++ b/_sources/kernels.rst.txt
@@ -0,0 +1,234 @@
+.. _kernels:
+
+PyOP2 Kernels
+=============
+
+Kernels in PyOP2 define the local operations that are to be performed for each
+element of the iteration set the kernel is executed over. There must be a one
+to one match between the arguments declared in the kernel signature and the
+actual arguments passed to the parallel loop executing this kernel. As
+described in :doc:`concepts`, data is accessed directly on the iteration set
+or via mappings passed in the :func:`~pyop2.par_loop` call.
+
+The kernel only sees data corresponding to the current element of the
+iteration set it is invoked for. Any data read by the kernel i.e. accessed as
+:data:`~pyop2.READ`, :data:`~pyop2.RW` or :data:`~pyop2.INC` is automatically
+gathered via the mapping relationship in the *staging in* phase and the kernel
+is passed pointers to the staging memory. Similarly, after the kernel has been
+invoked, any modified data i.e. accessed as :data:`~pyop2.WRITE`,
+:data:`~pyop2.RW` or :data:`~pyop2.INC` is scattered back out via the
+:class:`~pyop2.Map` in the *staging out* phase. It is only safe for a kernel
+to manipulate data in the way declared via the access descriptor in the
+parallel loop call. Any modifications to an argument accessed read-only would
+not be written back since the staging out phase is skipped for this argument.
+Similarly, the result of reading an argument declared as write-only is
+undefined since the data has not been staged in.
+
+.. _kernel-api:
+
+Kernel API
+----------
+
+Consider a :func:`~pyop2.par_loop` computing the midpoint of a triangle given
+the three vertex coordinates. Note that we make use of a covenience in the
+PyOP2 syntax, which allow declaring an anonymous :class:`~pyop2.DataSet` of a
+dimension greater one by using the ``**`` operator. We omit the actual data in
+the declaration of the :class:`~pyop2.Map` ``cell2vertex`` and
+:class:`~pyop2.Dat` ``coordinates``. ::
+
+  vertices = op2.Set(num_vertices)
+  cells = op2.Set(num_cells)
+
+  cell2vertex = op2.Map(cells, vertices, 3, [...])
+
+  coordinates = op2.Dat(vertices ** 2, [...], dtype=float)
+  midpoints = op2.Dat(cells ** 2, dtype=float)
+
+  op2.par_loop(midpoint, cells,
+               midpoints(op2.WRITE),
+               coordinates(op2.READ, cell2vertex))
+
+Kernels are implemented in a restricted subset of C99 and are declared by
+passing a *C code string* and the *kernel function name*, which must match the
+name in the C kernel signature, to the :class:`~pyop2.Kernel` constructor: ::
+
+  midpoint = op2.Kernel("""
+  void midpoint(double p[2], double *coords[2]) {
+    p[0] = (coords[0][0] + coords[1][0] + coords[2][0]) / 3.0;
+    p[1] = (coords[0][1] + coords[1][1] + coords[2][1]) / 3.0;
+  }""", "midpoint")
+
+Since kernels cannot return any value, the return type is always ``void``. The
+kernel argument ``p`` corresponds to the third :func:`~pyop2.par_loop`
+argument ``midpoints`` and ``coords`` to the fourth argument ``coordinates``
+respectively. Argument names need not agree, the matching is by position.
+
+Data types of kernel arguments must match the type of data passed to the
+parallel loop. The Python types :class:`float` and :class:`numpy.float64`
+correspond to a C :class:`double`, :class:`numpy.float32` to a C
+:class:`float`, :class:`int` or :class:`numpy.int64` to a C :class:`long` and
+:class:`numpy.int32` to a C :class:`int`.
+
+Direct :func:`~pyop2.par_loop` arguments such as ``midpoints`` are passed to
+the kernel as a ``double *``, indirect arguments such as ``coordinates`` as a
+``double **`` with the first indirection due to the map and the second
+indirection due the data dimension. The kernel signature above uses arrays
+with explicit sizes to draw attention to the fact that these are known. We
+could have interchangibly used a kernel signature with plain pointers:
+
+.. code-block:: c
+
+  void midpoint(double * p, double ** coords)
+
+Argument creation supports an optional flag ``flatten``, which is used
+for kernels which expect data to be laid out by component: ::
+
+  midpoint = op2.Kernel("""
+  void midpoint(double p[2], double *coords[1]) {
+    p[0] = (coords[0][0] + coords[1][0] + coords[2][0]) / 3.0;
+    p[1] = (coords[3][0] + coords[4][0] + coords[5][0]) / 3.0;
+  }""", "midpoint")
+
+  op2.par_loop(midpoint, cells,
+               midpoints(op2.WRITE),
+               coordinates(op2.READ, cell2vertex, flatten=True))
+
+.. _data-layout:
+
+Data layout
+-----------
+
+Data for a :class:`~pyop2.Dat` declared on a :class:`~pyop2.Set` is
+stored contiguously for all elements of the set. For each element,
+this is a contiguous chunk of data of a shape given by the
+:class:`~pyop2.DataSet` ``dim`` and the datatype of the
+:class:`~pyop2.Dat`.  The size of this chunk is the product of the
+extents of the ``dim`` tuple times the size of the datatype.
+
+During execution of the :func:`~pyop2.par_loop`, the kernel is called
+for each element of the iteration set and passed data for each of its
+arguments corresponding to the current set element ``i`` only.
+
+For a directly accessed argument such as ``midpoints`` above, the
+kernel is passed a pointer to the beginning of the chunk of data for
+the element ``i`` the kernel is currently called for. In CUDA/OpenCL
+``i`` is the global thread id since the kernel is launched in parallel
+for all elements.
+
+.. figure:: images/direct_arg.svg
+  :align: center
+
+  Data layout for a directly accessed :class:`~pyop2.Dat` argument with
+  ``dim`` 2
+
+For an indirectly accessed argument such as ``coordinates`` above,
+PyOP2 gathers pointers to the data via the :class:`~pyop2.Map`
+``cell2vertex`` used for the indirection. The kernel is passed a list
+of pointers of length corresponding to the *arity* of the
+:class:`~pyop2.Map`, in the example above 3. Each of these points to
+the data chunk for the element in the target :class:`~pyop2.Set` given
+by :class:`~pyop2.Map` entries ``(i, 0)``, ``(i, 1)`` and ``(i, 2)``.
+
+.. figure:: images/indirect_arg.svg
+  :align: center
+
+  Data layout for a :class:`~pyop2.Dat` argument with ``dim`` 2 indirectly
+  accessed through a :class:`~pyop2.Map` of ``arity`` 3
+
+If the argument is created with the keyword argument ``flatten`` set
+to ``True``, a flattened vector of pointers is passed to the kernel.
+This vector is of length ``dim * arity`` (where ``dim`` is the product
+of the extents of the ``dim`` tuple), which is 6 in the example above.
+Each entry points to a single data value of the :class:`~pyop2.Dat`.
+The ordering is by component of ``dim`` i.e. the first component of
+each data item for each element in the target set pointed to by the
+map followed by the second component etc.
+
+.. figure:: images/indirect_arg_flattened.svg
+  :align: center
+
+  Data layout for a flattened :class:`~pyop2.Dat` argument with ``dim`` 2
+  indirectly accessed through a :class:`~pyop2.Map` of ``arity`` 3
+
+.. _local-iteration-spaces:
+
+Local iteration spaces
+----------------------
+
+PyOP2 supports complex kernels with large local working set sizes, which may
+not run very efficiently on architectures with a limited amount of registers
+and on-chip resources. In many cases the resource usage is proportional to the
+size of the *local iteration space* the kernel operates on.
+
+Consider a finite-element local assembly kernel for vector-valued basis
+functions of second order on triangles.  There are kernels more complex and
+computing considerably larger local tensors commonly found in finite-element
+computations, in particular for higher-order basis functions, and this kernel
+only serves to illustrate the concept. For each element in the iteration set,
+this kernel computes a 12x12 local tensor:
+
+.. code-block:: c
+
+  void kernel(double A[12][12], ...) {
+    ...
+    // loops over the local iteration space
+    for (int j = 0; j < 12; j++) {
+      for (int k = 0; k < 12; k++) {
+        A[j][k] += ...
+      }
+    }
+  }
+
+PyOP2 invokes this kernel for each element in the iteration set:
+
+.. code-block:: c
+
+  for (int ele = 0; ele < nele; ++ele) {
+    double A[12][12];
+    ...
+    kernel(A, ...);
+  }
+
+To improve the efficiency of executing complex kernels on manycore
+platforms, their operation can be distributed among several threads
+which each compute a single point in this local iteration space to
+increase the level of parallelism and to lower the amount of resources
+required per thread. In the case of the kernel above we obtain:
+
+.. code-block:: c
+
+  void mass(double A[1][1], ..., int j, int k) {
+    ...
+    A[0][0] += ...
+  }
+
+Note how the doubly nested loop over basis function is hoisted out of the
+kernel, which receives its position in the local iteration space to compute as
+additional arguments ``j`` and ``k``. PyOP2 then calls the kernel for
+each element of the local iteration space for each set element:
+
+.. code-block:: c
+
+  for (int ele = 0; ele < nele; ++ele) {
+    double A[1][1];
+    ...
+    for (int j = 0; j < 12; j++) {
+      for (int k = 0; k < 12; k++) {
+        kernel(A, ..., j, k);
+      }
+    }
+  }
+
+On manycore platforms, the local iteration space does not translate into a
+loop nest, but rather into a larger number of threads being launched to
+compute each of its elements:
+
+.. figure:: images/iteration_spaces.svg
+  :align: center
+
+  Local iteration space for a kernel computing a 12x12 local tensor
+
+PyOP2 needs to be told to loop over this local iteration space by
+indexing the corresponding maps with an
+:class:`~pyop2.base.IterationIndex` :data:`~pyop2.i` in the
+:func:`~pyop2.par_loop` call.
diff --git a/_sources/linear_algebra.rst.txt b/_sources/linear_algebra.rst.txt
new file mode 100644
index 000000000..176f15498
--- /dev/null
+++ b/_sources/linear_algebra.rst.txt
@@ -0,0 +1,304 @@
+.. _linear_algebra:
+
+PyOP2 Linear Algebra Interface
+==============================
+
+PyOP2 supports linear algebra operations on sparse matrices using a thin
+wrapper around the PETSc_ library harnessed via its petsc4py_ interface.
+
+As described in :doc:`concepts`, a sparse matrix is a linear operator that
+maps a :class:`~pyop2.DataSet` representing its row space to a
+:class:`~pyop2.DataSet` representing its column space and vice versa. These
+two spaces are commonly the same, in which case the resulting matrix is
+square. A sparse matrix is represented by a :class:`~pyop2.Mat`, which is
+declared on a :class:`~pyop2.Sparsity`, representing its non-zero structure.
+
+.. _matrix_storage:
+
+Sparse Matrix Storage Formats
+-----------------------------
+
+PETSc_ uses the popular Compressed Sparse Row (CSR) format to only store the
+non-zero entries of a sparse matrix. In CSR, a matrix is stored as three
+one-dimensional arrays of *row pointers*, *column indices* and *values*, where
+the two former are of integer type and the latter of float type, usually
+double. As the name suggests, non-zero entries are stored per row, where each
+non-zero is defined by a pair of column index and corresponding value. The
+column indices and values arrays therefore have a length equal to the total
+number of non-zero entries. Row indices are given implicitly by the row
+pointer array, which contains the starting index in the column index and
+values arrays for the non-zero entries of each row. In other words, the
+non-zeros for row ``i`` are at positions ``row_ptr[i]`` up to but not
+including ``row_ptr[i+1]`` in the column index and values arrays. For each
+row, entries are sorted by column index to allow for faster lookups using a
+binary search.
+
+.. figure:: images/csr.svg
+  :align: center
+
+  A sparse matrix and its corresponding CSR row pointer, column indices and
+  values arrays
+
+For distributed parallel storage with MPI, the rows of the matrix are
+distribued evenly among the processors. Each row is then again divided into a
+*diagonal* and an *off-diagonal* part, where the diagonal part comprises
+columns ``i`` to ``j`` if ``i`` and ``j`` are the first and last row owned by
+a given processor, and the off-diagonal part all other rows.
+
+.. figure:: images/mpi_matrix.svg
+  :align: center
+
+  Distribution of a sparse matrix among 3 MPI processes
+
+.. _matrix_assembly:
+
+Matrix assembly
+---------------
+
+Sparse matrices are assembled by adding up local contributions which are
+mapped to global matrix entries via a local-to-global mapping represented by a
+pair of :class:`Maps <pyop2.Map>` for the row and column space. 
+
+.. figure:: images/assembly.svg
+  :align: center
+
+  Assembly of a local tensor :math:`A^K` into a global matrix :math:`A` using
+  the local-to-global mapping :math:`\iota_K^1` for rows and :math:`\iota_K^2`
+  for columns
+
+For each :func:`~pyop2.par_loop` that assembles a matrix, PyOP2 generates a
+call to PETSc_'s MatSetValues_ function for each element of the iteration set,
+adding the local contributions computed by the user kernel to the global
+matrix using the given :class:`Maps <pyop2.Map>`. At the end of the
+:func:`~pyop2.par_loop` PyOP2 automatically calls MatAssemblyBegin_ and
+MatAssemblyEnd_ to finalise matrix assembly.
+
+Consider assembling a :class:`~pyop2.Mat` on a :class:`~pyop2.Sparsity` built
+from a :class:`~pyop2.Map` from ``elements`` to ``nodes``. The assembly is
+done in a :func:`~pyop2.par_loop` over ``elements``, where the
+:class:`~pyop2.Mat` ``A`` is accssed indirectly via the ``elem_node``
+:class:`~pyop2.Map` using the :class:`~pyop2.base.IterationIndex`
+:class:`~pyop2.i`:
+
+.. code-block:: python
+
+  nodes = op2.Set(NUM_NODES, "nodes")
+  elements = op2.Set(NUM_ELE, "elements")
+
+  elem_node = op2.Map(elements, nodes, 3, ...)
+
+  sparsity = op2.Sparsity((nodes, nodes), (elem_node, elem_node))
+  A = op2.Mat(sparsity, np.float64)
+
+  b = op2.Dat(nodes, dtype=np.float64)
+
+  # Assemble the matrix mat
+  op2.par_loop(mat_kernel, elements,
+               A(op2.INC, (elem_node[op2.i[0]], elem_node[op2.i[1]])),
+               ...)
+
+  # Assemble the right-hand side vector b
+  op2.par_loop(rhs_kernel, elements,
+               b(op2.INC, elem_node[op2.i[0]]),
+               ...)
+
+The code generated for the :func:`~pyop2.par_loop` assembling the
+:class:`~pyop2.Mat` for the sequential backend is similar to the following,
+where initialisation and staging code described in :ref:`sequential_backend`
+have been omitted for brevity. For each element of the iteration
+:class:`~pyop2.Set` a buffer for the local tensor is initialised to zero and
+passed to the user kernel performing the local assembly operation. The
+``addto_vector`` call subsequently adds this local contribution to the global
+sparse matrix.
+
+.. code-block:: c
+
+  void wrap_mat_kernel__(...) {
+    ...
+    for ( int n = start; n < end; n++ ) {
+      int i = n;
+      ...
+      double buffer_arg0_0[3][3] = {{0}};     // local tensor initialised to 0
+      mat_kernel(buffer_arg0_0, ...);         // local assembly kernel
+      addto_vector(arg0_0_0, buffer_arg0_0,   // Mat objet, local tensor
+                   3, arg0_0_map0_0 + i * 3,  // # rows, global row indices
+                   3, arg0_0_map1_0 + i * 3,  // # cols, global column indices
+                   0);                        // mode: 0 add, 1 insert
+    }
+  }
+
+.. _sparsity_pattern:
+
+Building a sparsity pattern
+---------------------------
+
+The sparsity pattern of a matrix is uniquely defined by the dimensions of the
+:class:`DataSets <pyop2.DataSet>` forming its row and column space, and one or
+more pairs of :class:`Maps <pyop2.Map>` defining its non-zero structure. This
+is exploited in PyOP2 by caching sparsity patterns with these unique
+attributes as the cache key to save expensive recomputation. Whenever a
+:class:`Sparsity` is initialised, an already computed pattern with the same
+unique key is returned if it exists.
+
+For a valid sparsity, each row :class:`~pyop2.Map` must map to the set of the
+row :class:`~pyop2.DataSet`, each column :class:`~pyop2.Map` to that of the
+column :class:`~pyop2.DataSet` and the from sets of each pair must match. A
+matrix on a sparsity pattern built from more than one pair of maps is
+assembled by multiple parallel loops iterating over the corresponding
+iteration set for each pair.
+
+Sparsity construction proceeds by iterating each :class:`~pyop2.Map` pair and
+building a set of indices of the non-zero columns for each row. Each pair of
+entries in the row and column maps gives the row and column index of a
+non-zero entry in the matrix and therefore the column index is added to the
+set of non-zero entries for that particular row. The array of non-zero entries
+per row is then determined as the size of the set for each row and its
+exclusive scan yields the row pointer array. The column index array is the
+concatenation of all the sets. An algorithm for the sequential case is given
+below: ::
+
+  for rowmap, colmap in maps:
+      for e in range(rowmap.from_size):
+          for i in range(rowmap.arity):
+              row = rowmap.values[i + e*rowmap.arity]
+              for d in range(colmap.arity):
+                  diag[row].insert(colmap.values[d + e * colmap.arity])
+
+For the MPI parallel case a minor modification is required, since for each row
+a set of diagonal and off-diagonal column indices needs to be built as
+described in :ref:`matrix_storage`: ::
+
+  for rowmap, colmap in maps:
+      for e in range(rowmap.from_size):
+          for i in range(rowmap.arity):
+              row = rowmap.values[i + e*rowmap.arity]
+              if row < nrows:
+                  for d in range(colmap.arity):
+                      if col < ncols:
+                          diag[row].insert(colmap.values[d + e*colmap.arity])
+                      else:
+                          odiag[row].insert(colmap.values[d + e*colmap.arity])
+
+.. _solving:
+
+Solving a linear system
+-----------------------
+
+PyOP2 provides a :class:`~pyop2.Solver`, wrapping the PETSc_ KSP_ Krylov
+solvers which support various iterative methods such as Conjugate Gradients
+(CG), Generalized Minimal Residual (GMRES), a stabilized version of
+BiConjugate Gradient Squared (BiCGStab) and others. The solvers are
+complemented with a range of preconditioners from PETSc_'s PC_ collection,
+which includes Jacobi, incomplete Cholesky and LU decompositions and various
+multigrid based preconditioners.
+
+The choice of solver and preconditioner type and other parameters uses
+PETSc_'s configuration mechanism documented in the `PETSc manual`_. Options
+are pased to the :class:`~pyop2.Solver` via the keyword argument
+``parameters`` taking a dictionary of arguments or directly via keyword
+arguments. The solver type is chosen as ``ksp_type``, the preconditioner as
+``pc_type`` with the defaults ``cg`` and ``jacobi``.
+
+Solving a linear system of the matrix ``A`` assembled above and the right-hand
+side vector ``b`` for a solution vector ``x`` is done with a call to
+:meth:`~pyop2.Solver.solve`, where solver and preconditioner are chosen as
+``gmres`` and ``ilu``: ::
+
+  x = op2.Dat(nodes, dtype=np.float64)
+
+  solver = op2.Solver(ksp_type='gmres', pc_type='ilu')
+  solver.solve(A, x, b)
+
+.. _gpu_assembly:
+
+GPU matrix assembly
+-------------------
+
+In a :func:`~pyop2.par_loop` assembling a :class:`~pyop2.Mat` on the GPU, the
+local contributions are first computed for all elements of the iteration set
+and stored in global memory in a structure-of-arrays (SoA) data layout such
+that all threads can write the data out in a coalesced manner. For the example
+above, the generated CUDA wrapper code is as follows, again omitting
+initialisation and staging code described in :ref:`cuda_backend`.  The user
+kernel only computes a single element in the local iteration space as detailed
+in :ref:`local-iteration-spaces`.
+
+.. code-block:: c
+
+  __global__ void __mat_kernel_stub(...,
+                                    double *arg0,    // local matrix data array
+                                    int arg0_offset, // offset into the array
+                                    ... ) {
+    ... // omitted initialisation and shared memory staging code
+    for ( int idx = threadIdx.x; idx < nelem; idx += blockDim.x ) {
+      ... // omitted staging code
+      for ( int i0 = 0; i0 < 3; ++i0 ) {
+        for ( int i1 = 0; i1 < 3; ++i1 ) {
+          mass_cell_integral_0_otherwise(
+            (double (*)[1])(arg0 + arg0_offset + idx * 9 + i0 * 3 + i1 * 1),
+            ..., i0, i1);
+        }
+      }
+    }
+  }
+
+A separate CUDA kernel given below is launched afterwards to compress the data
+into a sparse matrix in CSR storage format. Only the values array needs to be
+computed, since the row pointer and column indices have already been computed
+when building the sparsity on the host and subsequently transferred to GPU
+memory. Memory for the local contributions and the values array only needs to
+be allocated on the GPU.
+
+.. code-block:: c
+
+  __global__ void __lma_to_csr(double *lmadata,  // local matrix data array
+                               double *csrdata,  // CSR values array
+                               int *rowptr,      // CSR row pointer array
+                               int *colidx,      // CSR column indices array
+                               int *rowmap,      // row map array
+                               int rowmapdim,    // row map arity
+                               int *colmap,      // column map array
+                               int colmapdim,    // column map arity
+                               int nelems) {
+    int nentries_per_ele = rowmapdim * colmapdim;
+    int n = threadIdx.x + blockIdx.x * blockDim.x;
+    if ( n >= nelems * nentries_per_ele ) return;
+
+    int e = n / nentries_per_ele;                        // set element
+    int i = (n - e * nentries_per_ele) / rowmapdim;      // local row
+    int j = (n - e * nentries_per_ele - i * colmapdim);  // local column
+
+    // Compute position in values array
+    int offset = pos(rowmap[e * rowmapdim + i], colmap[e * colmapdim + j],
+                     rowptr, colidx);
+    __atomic_add(csrdata + offset, lmadata[n]);
+  }
+
+.. _gpu_solve:
+
+GPU linear algebra
+------------------
+
+Linear algebra on the GPU with the ``cuda`` backend uses the Cusp_ library,
+which does not support all solvers and preconditioners provided by PETSc_. The
+interface to the user is the same as for the ``sequential`` and ``openmp``
+backends. Supported solver types are CG (``cg``), GMRES (``gmres``) and
+BiCGStab (``bicgstab``), with preconditioners of types Jacobi (``jacobi``),
+Bridson approximate inverse (``ainv``) and asymptotic multigrid (``amg``). An
+exception is raised if an unsupported solver or preconditioner type is
+requested.  A Cusp_ solver with the chosen parameters is automatically
+generated when :func:`~pyop2.solve` is called.
+
+.. note ::
+  Distributed parallel linear algebra operations with MPI are currently not
+  supported by the ``cuda`` backend.
+
+.. _PETSc: http://www.mcs.anl.gov/petsc/
+.. _petsc4py: http://pythonhosted.org/petsc4py/
+.. _MatSetValues: http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/Mat/MatSetValues.html
+.. _MatAssemblyBegin: http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/Mat/MatAssemblyBegin.html
+.. _MatAssemblyEnd: http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/Mat/MatAssemblyEnd.html
+.. _KSP: http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/KSP/
+.. _PC: http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/PC/
+.. _PETSc manual: http://www.mcs.anl.gov/petsc/petsc-dev/docs/manual.pdf
+.. _Cusp: http://cusplibrary.github.io
diff --git a/_sources/mixed.rst.txt b/_sources/mixed.rst.txt
new file mode 100644
index 000000000..2227dcf69
--- /dev/null
+++ b/_sources/mixed.rst.txt
@@ -0,0 +1,144 @@
+.. _mixed:
+
+Mixed Types
+===========
+
+When solving linear systems of equations as they arise for instance in the
+finite-element method (FEM), one is often interested in *coupled* solutions of
+more than one quantity. In fluid dynamics, a common example is solving a
+coupled system of velocity and pressure as it occurs in some formulations of
+the Navier-Stokes equations.
+
+Mixed Set, DataSet, Map and Dat
+-------------------------------
+
+PyOP2 provides the mixed types :class:`~pyop2.MixedSet`
+:class:`~pyop2.MixedDataSet`, :class:`~pyop2.MixedMap` and
+:class:`~pyop2.MixedDat` for a :class:`~pyop2.Set`, :class:`~pyop2.DataSet`,
+:class:`~pyop2.Map` and :class:`~pyop2.Dat` respectively. A mixed type is
+constructed from a list or other iterable of its base type and provides the
+same attributes and methods. Under most circumstances types and mixed types
+behave the same way and can be treated uniformly. Mixed types allow iteration
+over their constituent parts and for convenience the base types are also
+iterable, yielding themselves.
+
+A :class:`~pyop2.MixedSet` is defined from a list of sets: ::
+
+  s1, s2 = op2.Set(N), op2.Set(M)
+  ms = op2.MixedSet([s1, s2])
+
+There are a number of equivalent ways of defining a
+:class:`~pyop2.MixedDataSet`: ::
+
+  mds = op2.MixedDataSet([s1, s2], (1, 2))
+  mds = op2.MixedDataSet([s1**1, s2**2])
+  mds = op2.MixedDataSet(ms, (1, 2))
+  mds = ms**(1, 2)
+
+A :class:`~pyop2.MixedDat` with no associated data is defined in one of the
+following ways: ::
+
+  md = op2.MixedDat(mds)
+  md = op2.MixedDat([s1**1, s2**2])
+  md = op2.MixedDat([op2.Dat(s1**1), op2.Dat(s2**2)])
+
+Finally, a :class:`~pyop2.MixedMap` is defined from a list of maps, all of
+which must share the same source :class:`~pyop2.Set`: ::
+
+  it = op2.Set(S)
+  mm = op2.MixedMap([op2.Map(it, s1, 2), op2.Map(it, s2, 3)])
+
+Block Sparsity and Mat
+----------------------
+
+When declaring a :class:`~pyop2.Sparsity` on pairs of mixed maps, the
+resulting sparsity pattern has a square block structure with as many block
+rows and columns as there are components in the :class:`~pyop2.MixedDataSet`
+forming its row and column space. In the most general case a
+:class:`~pyop2.Sparsity` is constructed as follows: ::
+
+  it = op2.Set(...)  # Iteration set
+  sr0, sr1 = op2.Set(...), op2.Set(...)  # Sets for row spaces
+  sc0, sc1 = op2.Set(...), op2.Set(...)  # Sets for column spaces
+  # MixedMaps for the row and column spaces
+  mr = op2.MixedMap([op2.Map(it, sr0, ...), op2.Map(it, sr1, ...)])
+  mc = op2.MixedMap([op2.Map(it, sc0, ...), op2.Map(it, sc1, ...)])
+  # MixedDataSets for the row and column spaces
+  dsr = op2.MixedDataSet([sr0**1, sr1**1])
+  dsc = op2.MixedDataSet([sc0**1, sc1**1])
+  # Blocked sparsity
+  sparsity = op2.Sparsity((dsr, dsc), [(mr, mc), ...])
+
+The relationships of each component of the mixed maps and datasets to the
+blocks of the :class:`~pyop2.Sparsity` is shown in the following diagram:
+
+.. figure:: images/mixed_sparsity.svg
+  :align: center
+
+  The contribution of sets, maps and datasets to the blocked sparsity. 
+
+Block sparsity patterns are computed separately for each block as described in
+:ref:`sparsity_pattern` and the same validity rules apply. A
+:class:`~pyop2.Mat` defined on a block :class:`~pyop2.Sparsity` has the same
+block structure, which is implemented using a PETSc_ MATNEST_.
+
+Mixed Assembly
+--------------
+
+When assembling into a :class:`~pyop2.MixedDat` or a block
+:class:`~pyop2.Mat`, the :class:`~pyop2.Kernel` produces a local tensor of the
+same block structure, which is a combination of :ref:`local-iteration-spaces`
+of all its subblocks. This is entirely transparent to the kernel however,
+which sees the combined local iteration space.  PyOP2 ensures that indirectly
+accessed data is gathered and scattered via the correct maps and packed
+together into a contiguous vector to be passed to the kernel. Contributions
+from the local tensor are assembled into the correct blocks of the
+:class:`~pyop2.MixedDat` or :class:`~pyop2.Mat`.
+
+Consider the following example :func:`~pyop2.par_loop` assembling a block
+:class:`~pyop2.Mat`:
+
+.. code-block:: python
+
+  it, cells, nodes = op2.Set(...), op2.Set(...), op2.Set(...)
+  mds = op2.MixedDataSet([nodes, cells])
+  mmap = op2.MixedMap([op2.Map(it, nodes, 2, ...), op2.Map(it, cells, 1, ...)])
+  mat = op2.Mat(op2.Sparsity(mds, mmap))
+  d = op2.MixedDat(mds)
+
+  op2.par_loop(kernel, it,
+               mat(op2.INC, (mmap[op2.i[0]], mmap[op2.i[1]])),
+               d(op2.read, mmap))
+
+The ``kernel`` for this :func:`~pyop2.par_loop` assembles a 3x3 local tensor
+and is passed an input vector of length 3 for each iteration set element:
+
+.. code-block:: c
+
+  void kernel(double v[3][3] , double **d ) {
+    for (int i = 0; i<3; i++)
+      for (int j = 0; j<3; j++)
+        v[i][j] += d[i][0] * d[j][0];
+  }
+
+The top-left 2x2 block of the local tensor is assembled into the (0,0) block
+of the matrix, the top-right 2x1 block into (0,1), the bottom-left 1x2 block
+into (1,0) and finally the bottom-right 1x1 block into (1,1). Note that for
+the (0,0) block only the first component of the :class:`~pyop2.MixedDat` is
+read and for the (1,1) block only the second component. For the (0,1) and
+(1,0) blocks, both components of the :class:`~pyop2.MixedDat` are accessed.
+
+This diagram illustrates the assembly of the block :class:`~pyop2.Mat`:
+
+.. figure:: images/mixed_assembly.svg
+  :align: center
+
+  Assembling into the blocks of a global matrix :math:`A`: block
+  :math:`A^{0,0}` uses maps :math:`\iota^{1,0}` and :math:`\iota^{2,0}`,
+  :math:`A^{0,1}` uses :math:`\iota^{1,0}` and :math:`\iota^{2,1}`,
+  :math:`A^{1,0}` uses :math:`\iota^{1,1}` and :math:`\iota^{2,0}` and finally
+  :math:`A^{1,1}` uses :math:`\iota^{1,1}` and :math:`\iota^{2,1}` for the row
+  and column spaces respectively.
+
+.. _PETSc: http://www.mcs.anl.gov/petsc/
+.. _MATNEST: http://www.mcs.anl.gov/petsc/petsc-current/docs/manualpages/Mat/MATNEST.html
diff --git a/_sources/mpi.rst.txt b/_sources/mpi.rst.txt
new file mode 100644
index 000000000..360253cda
--- /dev/null
+++ b/_sources/mpi.rst.txt
@@ -0,0 +1,125 @@
+.. _mpi:
+
+MPI
+===
+
+Distributed parallel computations with MPI in PyOP2 require the mesh to be
+partitioned among the processors. To be able to compute over entities on their
+boundaries, partitions need to access data owned by neighboring processors.
+This region, called the *halo*, needs to be kept up to date and is therefore
+exchanged between the processors as required.
+
+Local Numbering
+---------------
+
+The partition of each :class:`~pyop2.Set` local to each process consists of
+entities *owned* by the process and the *halo*, which are entities owned by
+other processes but required to compute on the boundary of the owned entities.
+Each of these sections is again divided into two sections required to
+efficiently overlap communication and computation and avoid communication
+during matrix assembly as described below. Each locally stored
+:class:`~pyop2.Set` entitity therefore belongs to one of four categories:
+
+* **Core**: Entities owned by this processor which can be processed without
+  accessing halo data.
+* **Owned**: Entities owned by this processor which access halo data when
+  processed.
+* **Exec halo**: Off-processor entities which are redundantly executed over
+  because they touch owned entities.
+* **Non-exec halo**: Off-processor entities which are not processed, but read
+  when computing the exec halo.
+
+The following diagram illustrates the four sections for a mesh distributed
+among two processors:
+
+.. figure:: images/pyop2_mpi_mesh.svg
+  :align: center
+
+  A mesh distributed among two processors with the entities of each mesh
+  partition divided into *core*, *owned*, *exec halo* and *non-exec halo*.
+  Matching halo sections are highlighted in matching colours. The owned
+  section of process 0 correspondonds to the non-exec section of process 1.
+
+For data defined on the :class:`~pyop2.Set` to be stored contiguously per
+section, local :class:`~pyop2.Set` entities must be numbered such that core
+entities are first, followed by owned, exec halo and non-exec halo in that
+order. A good partitioning maximises the size of the core section and
+minimises the halo regions. We can therefore assume that the vast majority of
+local :class:`~pyop2.Set` entities are in the core section. 
+
+Computation-communication Overlap
+---------------------------------
+
+The ordering of :class:`~pyop2.Set` entities into four sections allow for a
+very efficient overlap of computation and communication. Core entities that do
+not access any halo data can be processed entirely without access to halo data
+immediately after the halo exchange has been initiated. Execution over the
+owned and exec halo regions requires up to date halo data and can only start
+once the halo exchange is completed.  Depending on the latency and bandwidth
+of communication and the size of the core section relative to the halo, the
+halo exchange may complete before the computation on the core section.
+
+The entire process is given below: ::
+
+  halo_exchange_begin()                      # Initiate halo exchange
+  maybe_set_dat_dirty()                      # Mark Dats as modified
+  compute_if_not_empty(itset.core_part)      # Compute core region
+  halo_exchange_end()                        # Wait for halo exchange
+  compute_if_not_empty(itset.owned_part)     # Compute owned region
+  reduction_begin()                          # Initiate reductions
+  if needs_exec_halo:                        # Any indirect Dat not READ?
+      compute_if_not_empty(itset.exec_part)  # Compute exec halo region
+  reduction_end()                            # Wait for reductions
+  maybe_set_halo_update_needed()             # Mark halos as out of date
+  assemble()                                 # Finalise matrix assembly
+
+Any reductions depend on data from the core and owned sections and are
+initiated as soon as the owned section has been processed and execute
+concurrently with computation on the exec halo. Similar to
+`halo_exchange_begin` and `halo_exchange_end`, `reduction_begin` and
+`reduction_end` do no work at all if none of the :func:`~pyop2.par_loop`
+arguments requires a reduction. If the :func:`~pyop2.par_loop` assembles a
+:class:`~pyop2.Mat`, the matrix assembly is finalised at the end.
+
+By dividing entities into sections according to their relation to the halo,
+there is no need to check whether or not a given entity touches the halo or
+not during computations on each section. This avoids branching in kernels or
+wrapper code and allows launching separate kernels for GPU execution of each
+section. The :func:`~pyop2.par_loop` execution therefore has the above
+structure for all backends.
+
+Halo exchange
+-------------
+
+Exchanging halo data is only required if the halo data is actually read, which
+is the case for :class:`~pyop2.Dat` arguments to a :func:`~pyop2.par_loop`
+used in :data:`pyop2.READ` or :data:`pyop2.RW` mode.  PyOP2 keeps track
+whether or not the halo region may have been modified. This is the case for
+:class:`Dats <pyop2.Dat>` used in :data:`pyop2.INC`, :data:`pyop2.WRITE` or
+:data:`pyop2.RW` mode or when a :class:`~pyop2.Solver` or a user requests
+access to the data. A halo exchange is triggered only for halos marked as out
+of date.
+
+Distributed Assembly
+--------------------
+
+For an MPI distributed matrix or vector, assembling owned entities at the
+boundary can contribute to off-process degrees of freedom and vice versa.
+
+There are different ways of accounting for these off-process contributions.
+PETSc_ supports insertion and subsequent communication of off-process matrix
+and vector entries, however its implementation is not thread safe. Concurrent
+insertion into PETSc_ MPI matrices *is* thread safe if off-process insertions
+are not cached and concurrent writes to rows are avoided, which is done
+through colouring as described in :ref:`plan-colouring`.
+
+PyOP2 therefore disables PETSc_'s off-process insertion feature and instead
+redundantly computes over all off process entities that touch local dofs,
+which is the *exec halo* section described above. The price for this is
+maintaining a larger halo, since we also need halo data, the *non-exec halo*
+section, to perform the redundant computation. Halos grow by about a factor
+two, however in practice this is still small compared to the interior region
+of a partition and the main cost of halo exchange is the latency, which is
+independent of the exchanged data volume.
+
+.. _PETSc: http://www.mcs.anl.gov/petsc/
diff --git a/_sources/plan.rst.txt b/_sources/plan.rst.txt
new file mode 100644
index 000000000..613ca8ae2
--- /dev/null
+++ b/_sources/plan.rst.txt
@@ -0,0 +1,80 @@
+.. _plan:
+
+Parallel Execution Plan
+=======================
+
+For all PyOP2 backends with the exception of sequential, a parallel execution
+plan is computed for each :func:`~pyop2.par_loop`. It contains information
+guiding the code generator on how to partition, stage and colour the data for
+efficient parallel processing.
+
+.. _plan-partitioning:
+
+Partitioning
+------------
+
+The iteration set is split into a number of equally sized and contiguous
+mini-partitions such that the working set of each mini-partition fits into
+shared memory or last level cache. This is unrelated to the partitioning
+required for MPI as described in :ref:`mpi`.
+
+.. _plan-renumbering:
+
+Local Renumbering and Staging
+-----------------------------
+
+While a mini-partition is a contiguous chunk of the iteration set, the
+indirectly accessed data it references is not necessarily contiguous. For each
+mini-partition and unique :class:`~pyop2.Dat`-:class:`~pyop2.Map` pair, a
+mapping from local indices within the partition to global indices is
+constructed as the sorted array of unique :class:`~pyop2.Map` indices accessed
+by this partition. At the same time, a global-to-local mapping is constructed
+as its inverse.
+
+Data for indirectly accessed :class:`~pyop2.Dat` arguments is staged in shared
+device memory as described in :ref:`backends`. For each partition, the
+local-to-global mapping indicates where data to be staged in is read from and
+the global-to-local mapping gives the location in shared memory data has been
+staged at. The amount of shared memory required is computed from the size of
+the local-to-global mapping.
+
+.. _plan-colouring:
+
+Colouring
+---------
+
+A two-level colouring is used to avoid race conditions. Partitions are
+coloured such that partitions of the same colour can be executed concurrently
+and threads executing on a partition in parallel are coloured such that no two
+threads indirectly reference the same data. Only :func:`~pyop2.par_loop`
+arguments performing an indirect reduction or assembling a matrix require
+colouring. Matrices are coloured per row.
+
+For each element of a :class:`~pyop2.Set` indirectly accessed in a
+:func:`~pyop2.par_loop`, a bit vector is used to record which colours
+indirectly reference it. To colour each thread within a partition, the
+algorithm proceeds as follows:
+
+1. Loop over all indirectly accessed arguments and collect the colours of all
+   :class:`~pyop2.Set` elements referenced by the current thread in a bit mask.
+2. Choose the next available colour as the colour of the current thread.
+3. Loop over all :class:`~pyop2.Set` elements indirectly accessed by the
+   current thread again and set the new colour in their colour mask.
+
+Since the bit mask is a 32-bit integer, up to 32 colours can be processed in a
+single pass, which is sufficient for most applications. If not all threads can
+be coloured with 32 distinct colours, the mask is reset and another pass is
+made, where each newly allocated colour is offset by 32. Should another pass
+be required, the offset is increased to 64 and so on until all threads are
+coloured.
+
+.. figure:: images/pyop2_colouring.svg
+  :align: center
+
+  Thread colouring within a mini-partition for a :class:`~pyop2.Dat` on
+  vertices indirectly accessed in a computation over the edges. The edges are
+  coloured such that no two edges touch the same vertex within the partition.
+
+The colouring of mini-partitions is done in the same way, except that all
+:class:`~pyop2.Set` elements indirectly accessed by the entire partition are
+referenced, not only those accessed by a single thread.
diff --git a/_sources/profiling.rst.txt b/_sources/profiling.rst.txt
new file mode 100644
index 000000000..aa7cc2baf
--- /dev/null
+++ b/_sources/profiling.rst.txt
@@ -0,0 +1,170 @@
+Profiling
+=========
+
+Profiling PyOP2 programs
+------------------------
+
+Profiling a PyOP2 program is as simple as profiling any other Python
+code. You can profile the jacobi demo in the PyOP2 ``demo`` folder as
+follows: ::
+
+  python -m cProfile -o jacobi.dat jacobi.py
+
+This will run the entire program under cProfile_ and write the profiling
+data to ``jacobi.dat``. Omitting ``-o`` will print a summary to stdout,
+which is not very helpful in most cases.
+
+Creating a graph
+................
+
+There is a much more intuitive way of representing the profiling data
+using the excellent gprof2dot_ to generate a graph. Install from `PyPI
+<http://pypi.python.org/pypi/gprof2dot/>`__ with ::
+
+  sudo pip install gprof2dot
+
+Use as follows to create a PDF: ::
+
+  gprof2dot -f pstats -n 1 jacobi.dat | dot -Tpdf -o jacobi.pdf
+
+``-f pstats`` tells ``gprof2dot`` that it is dealing with Python
+cProfile_ data (and not actual *gprof* data) and ``-n 1`` ignores
+everything that makes up less than 1% of the total runtime - most likely
+you are not interested in that (the default is 0.5).
+
+Consolidating profiles from different runs
+..........................................
+
+To aggregate profiling data from different runs, save the following as
+``concat.py``: ::
+
+  """Usage: concat.py PATTERN FILE"""
+
+  import sys
+  from glob import glob
+  from pstats import Stats
+
+  if len(sys.argv) != 3:
+      print __doc__
+      sys.exit(1)
+  files = glob(sys.argv[1])
+  s = Stats(files[0])
+  for f in files[1:]: s.add(f)
+  s.dump_stats(sys.argv[2])
+
+With profiles from different runs named ``<basename>.*.part``, use it
+as ::
+
+  python concat.py '<basename>.*.part' <basename>.dat
+
+and then call ``gprof2dot`` as before.
+
+Using PyOP2's internal timers
+-----------------------------
+
+PyOP2 automatically times the execution of certain regions:
+
+* Sparsity building
+* Plan construction
+* Parallel loop kernel execution
+* Halo exchange
+* Reductions
+* PETSc Krylov solver
+
+To output those timings, call :func:`~pyop2.profiling.summary` in your
+PyOP2 program or run with the environment variable
+``PYOP2_PRINT_SUMMARY`` set to 1.
+
+To query e.g. the timer for parallel loop execution programatically,
+use the :func:`~pyop2.profiling.timing` helper: ::
+
+  from pyop2 import timing
+  timing("ParLoop compute")               # get total time
+  timing("ParLoop compute", total=False)  # get average time per call
+
+To add additional timers to your own code, you can use the
+:func:`~pyop2.profiling.timed_region` and
+:func:`~pyop2.profiling.timed_function` helpers: ::
+
+  from pyop2.profiling import timed_region, timed_function
+
+  with timed_region("my code"):
+      # my code
+
+  @timed_function("my function")
+  def my_func():
+      # my func
+
+Line-by-line profiling
+----------------------
+
+To get a line-by-line profile of a given function, install Robert Kern's
+`line profiler`_ and:
+
+1. Import the :func:`~pyop2.profiling.profile` decorator: ::
+
+     from pyop2.profiling import profile
+
+2. Decorate the function to profile with ``@profile``
+3. Run your script with ``kernprof.py -l <script.py>``
+4. Generate an annotated source file with ::
+
+     python -m line_profiler <script.py.lprof>
+
+Note that ``kernprof.py`` injects the ``@profile`` decorator into the
+Python builtins namespace. PyOP2 provides a passthrough version of this
+decorator which does nothing if ``profile`` is not found in
+``__builtins__``. This means you can run your script regularly without
+having to remove the decorators again.
+
+The :func:`~pyop2.profiling.profile` decorator also works with the
+memory profiler (see below). PyOP2 therefore provides the
+:func:`~pyop2.profiling.lineprof` decorator which is only enabled when
+running with ``kernprof.py``.
+
+A number of PyOP2 internal functions are decorated such that running
+your PyOP2 application with ``kernprof.py`` will produce a line-by-line
+profile of the parallel loop computation (but not the generated code!).
+
+Memory profiling
+----------------
+
+To profile the memory usage of your application, install Fabian
+Pedregosa's `memory profiler`_ and:
+
+1. Import the :func:`~pyop2.profiling.profile` decorator: ::
+
+     from pyop2.profiling import profile
+
+2. Decorate the function to profile with ``@profile``.
+3. Run your script with ::
+
+      python -m memory_profiler <script.py>
+
+   to get a line-by-line memory profile of your function.
+4. Run your script with ::
+   
+      memprof run --python <script.py>
+
+   to record memory usage of your program over time.
+5. Generate a plot of the memory profile with ``memprof plot``.
+
+Note that ``memprof`` and ``python -m memory_profiler`` inject the
+``@profile`` decorator into the Python builtins namespace. PyOP2
+provides a passthrough version of this decorator which does nothing if
+``profile`` is not found in ``__builtins__``. This means you can run
+your script regularly without having to remove the decorators again.
+
+The :func:`~pyop2.profiling.profile` decorator also works with the line
+profiler (see below). PyOP2 therefore provides the
+:func:`~pyop2.profiling.memprof` decorator which is only enabled when
+running with ``memprof``.
+
+A number of PyOP2 internal functions are decorated such that running
+your PyOP2 application with ``memprof run`` will produce a memory
+profile of the parallel loop computation (but not the generated code!).
+
+.. _cProfile: https://docs.python.org/2/library/profile.html#cProfile
+.. _gprof2dot: https://code.google.com/p/jrfonseca/wiki/Gprof2Dot
+.. _line profiler: https://pythonhosted.org/line_profiler/
+.. _memory profiler: https://github.com/fabianp/memory_profiler
diff --git a/_sources/pyop2.codegen.rst.txt b/_sources/pyop2.codegen.rst.txt
new file mode 100644
index 000000000..53e8253dd
--- /dev/null
+++ b/_sources/pyop2.codegen.rst.txt
@@ -0,0 +1,61 @@
+pyop2.codegen package
+=====================
+
+Submodules
+----------
+
+pyop2.codegen.builder module
+----------------------------
+
+.. automodule:: pyop2.codegen.builder
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.codegen.loopycompat module
+--------------------------------
+
+.. automodule:: pyop2.codegen.loopycompat
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.codegen.node module
+-------------------------
+
+.. automodule:: pyop2.codegen.node
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.codegen.optimise module
+-----------------------------
+
+.. automodule:: pyop2.codegen.optimise
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.codegen.rep2loopy module
+------------------------------
+
+.. automodule:: pyop2.codegen.rep2loopy
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.codegen.representation module
+-----------------------------------
+
+.. automodule:: pyop2.codegen.representation
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+Module contents
+---------------
+
+.. automodule:: pyop2.codegen
+   :members:
+   :undoc-members:
+   :show-inheritance:
diff --git a/_sources/pyop2.rst.txt b/_sources/pyop2.rst.txt
new file mode 100644
index 000000000..0078f2f33
--- /dev/null
+++ b/_sources/pyop2.rst.txt
@@ -0,0 +1,142 @@
+pyop2 package
+=============
+
+Subpackages
+-----------
+
+.. toctree::
+   :maxdepth: 4
+
+   pyop2.codegen
+   pyop2.types
+
+Submodules
+----------
+
+pyop2.caching module
+--------------------
+
+.. automodule:: pyop2.caching
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.compilation module
+------------------------
+
+.. automodule:: pyop2.compilation
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.configuration module
+--------------------------
+
+.. automodule:: pyop2.configuration
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.datatypes module
+----------------------
+
+.. automodule:: pyop2.datatypes
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.exceptions module
+-----------------------
+
+.. automodule:: pyop2.exceptions
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.global\_kernel module
+---------------------------
+
+.. automodule:: pyop2.global_kernel
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.local\_kernel module
+--------------------------
+
+.. automodule:: pyop2.local_kernel
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.logger module
+-------------------
+
+.. automodule:: pyop2.logger
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.mpi module
+----------------
+
+.. automodule:: pyop2.mpi
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.op2 module
+----------------
+
+.. automodule:: pyop2.op2
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.parloop module
+--------------------
+
+.. automodule:: pyop2.parloop
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.profiling module
+----------------------
+
+.. automodule:: pyop2.profiling
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.sparsity module
+---------------------
+
+.. automodule:: pyop2.sparsity
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.utils module
+------------------
+
+.. automodule:: pyop2.utils
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.version module
+--------------------
+
+.. automodule:: pyop2.version
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+Module contents
+---------------
+
+.. automodule:: pyop2
+   :members:
+   :undoc-members:
+   :show-inheritance:
diff --git a/_sources/pyop2.types.rst.txt b/_sources/pyop2.types.rst.txt
new file mode 100644
index 000000000..543b170e0
--- /dev/null
+++ b/_sources/pyop2.types.rst.txt
@@ -0,0 +1,85 @@
+pyop2.types package
+===================
+
+Submodules
+----------
+
+pyop2.types.access module
+-------------------------
+
+.. automodule:: pyop2.types.access
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.types.dat module
+----------------------
+
+.. automodule:: pyop2.types.dat
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.types.data\_carrier module
+--------------------------------
+
+.. automodule:: pyop2.types.data_carrier
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.types.dataset module
+--------------------------
+
+.. automodule:: pyop2.types.dataset
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.types.glob module
+-----------------------
+
+.. automodule:: pyop2.types.glob
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.types.halo module
+-----------------------
+
+.. automodule:: pyop2.types.halo
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.types.map module
+----------------------
+
+.. automodule:: pyop2.types.map
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.types.mat module
+----------------------
+
+.. automodule:: pyop2.types.mat
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+pyop2.types.set module
+----------------------
+
+.. automodule:: pyop2.types.set
+   :members:
+   :undoc-members:
+   :show-inheritance:
+
+Module contents
+---------------
+
+.. automodule:: pyop2.types
+   :members:
+   :undoc-members:
+   :show-inheritance:
diff --git a/_sources/user.rst.txt b/_sources/user.rst.txt
new file mode 100644
index 000000000..c44b4d4c1
--- /dev/null
+++ b/_sources/user.rst.txt
@@ -0,0 +1,68 @@
+pyop2 user documentation
+========================
+
+:mod:`pyop2` Package
+--------------------
+
+.. automodule:: pyop2
+    :members:
+    :show-inheritance:
+    :inherited-members:
+
+    Initialization and finalization
+    ...............................
+
+    .. autofunction:: init
+    .. autofunction:: exit
+
+    Data structures
+    ...............
+
+    .. autoclass:: Set
+       :inherited-members:
+    .. autoclass:: ExtrudedSet
+       :inherited-members:
+    .. autoclass:: Subset
+       :inherited-members:
+    .. autoclass:: MixedSet
+       :inherited-members:
+    .. autoclass:: DataSet
+       :inherited-members:
+    .. autoclass:: MixedDataSet
+       :inherited-members:
+    .. autoclass:: Map
+       :inherited-members:
+    .. autoclass:: MixedMap
+       :inherited-members:
+    .. autoclass:: Sparsity
+       :inherited-members:
+
+    .. autoclass:: Const
+       :inherited-members:
+    .. autoclass:: Global
+       :inherited-members:
+    .. autoclass:: Dat
+       :inherited-members:
+    .. autoclass:: MixedDat
+       :inherited-members:
+    .. autoclass:: Mat
+       :inherited-members:
+
+    Parallel loops, kernels and linear solves
+    .........................................
+
+    .. autofunction:: par_loop
+    .. autofunction:: solve
+
+    .. autoclass:: Kernel
+       :inherited-members:
+    .. autoclass:: Solver
+       :inherited-members:
+
+    .. autodata:: i
+    .. autodata:: READ
+    .. autodata:: WRITE
+    .. autodata:: RW
+    .. autodata:: INC
+    .. autodata:: MIN
+    .. autodata:: MAX
diff --git a/_static/basic.css b/_static/basic.css
new file mode 100644
index 000000000..30fee9d0f
--- /dev/null
+++ b/_static/basic.css
@@ -0,0 +1,925 @@
+/*
+ * basic.css
+ * ~~~~~~~~~
+ *
+ * Sphinx stylesheet -- basic theme.
+ *
+ * :copyright: Copyright 2007-2023 by the Sphinx team, see AUTHORS.
+ * :license: BSD, see LICENSE for details.
+ *
+ */
+
+/* -- main layout ----------------------------------------------------------- */
+
+div.clearer {
+    clear: both;
+}
+
+div.section::after {
+    display: block;
+    content: '';
+    clear: left;
+}
+
+/* -- relbar ---------------------------------------------------------------- */
+
+div.related {
+    width: 100%;
+    font-size: 90%;
+}
+
+div.related h3 {
+    display: none;
+}
+
+div.related ul {
+    margin: 0;
+    padding: 0 0 0 10px;
+    list-style: none;
+}
+
+div.related li {
+    display: inline;
+}
+
+div.related li.right {
+    float: right;
+    margin-right: 5px;
+}
+
+/* -- sidebar --------------------------------------------------------------- */
+
+div.sphinxsidebarwrapper {
+    padding: 10px 5px 0 10px;
+}
+
+div.sphinxsidebar {
+    float: left;
+    width: 230px;
+    margin-left: -100%;
+    font-size: 90%;
+    word-wrap: break-word;
+    overflow-wrap : break-word;
+}
+
+div.sphinxsidebar ul {
+    list-style: none;
+}
+
+div.sphinxsidebar ul ul,
+div.sphinxsidebar ul.want-points {
+    margin-left: 20px;
+    list-style: square;
+}
+
+div.sphinxsidebar ul ul {
+    margin-top: 0;
+    margin-bottom: 0;
+}
+
+div.sphinxsidebar form {
+    margin-top: 10px;
+}
+
+div.sphinxsidebar input {
+    border: 1px solid #98dbcc;
+    font-family: sans-serif;
+    font-size: 1em;
+}
+
+div.sphinxsidebar #searchbox form.search {
+    overflow: hidden;
+}
+
+div.sphinxsidebar #searchbox input[type="text"] {
+    float: left;
+    width: 80%;
+    padding: 0.25em;
+    box-sizing: border-box;
+}
+
+div.sphinxsidebar #searchbox input[type="submit"] {
+    float: left;
+    width: 20%;
+    border-left: none;
+    padding: 0.25em;
+    box-sizing: border-box;
+}
+
+
+img {
+    border: 0;
+    max-width: 100%;
+}
+
+/* -- search page ----------------------------------------------------------- */
+
+ul.search {
+    margin: 10px 0 0 20px;
+    padding: 0;
+}
+
+ul.search li {
+    padding: 5px 0 5px 20px;
+    background-image: url(file.png);
+    background-repeat: no-repeat;
+    background-position: 0 7px;
+}
+
+ul.search li a {
+    font-weight: bold;
+}
+
+ul.search li p.context {
+    color: #888;
+    margin: 2px 0 0 30px;
+    text-align: left;
+}
+
+ul.keywordmatches li.goodmatch a {
+    font-weight: bold;
+}
+
+/* -- index page ------------------------------------------------------------ */
+
+table.contentstable {
+    width: 90%;
+    margin-left: auto;
+    margin-right: auto;
+}
+
+table.contentstable p.biglink {
+    line-height: 150%;
+}
+
+a.biglink {
+    font-size: 1.3em;
+}
+
+span.linkdescr {
+    font-style: italic;
+    padding-top: 5px;
+    font-size: 90%;
+}
+
+/* -- general index --------------------------------------------------------- */
+
+table.indextable {
+    width: 100%;
+}
+
+table.indextable td {
+    text-align: left;
+    vertical-align: top;
+}
+
+table.indextable ul {
+    margin-top: 0;
+    margin-bottom: 0;
+    list-style-type: none;
+}
+
+table.indextable > tbody > tr > td > ul {
+    padding-left: 0em;
+}
+
+table.indextable tr.pcap {
+    height: 10px;
+}
+
+table.indextable tr.cap {
+    margin-top: 10px;
+    background-color: #f2f2f2;
+}
+
+img.toggler {
+    margin-right: 3px;
+    margin-top: 3px;
+    cursor: pointer;
+}
+
+div.modindex-jumpbox {
+    border-top: 1px solid #ddd;
+    border-bottom: 1px solid #ddd;
+    margin: 1em 0 1em 0;
+    padding: 0.4em;
+}
+
+div.genindex-jumpbox {
+    border-top: 1px solid #ddd;
+    border-bottom: 1px solid #ddd;
+    margin: 1em 0 1em 0;
+    padding: 0.4em;
+}
+
+/* -- domain module index --------------------------------------------------- */
+
+table.modindextable td {
+    padding: 2px;
+    border-collapse: collapse;
+}
+
+/* -- general body styles --------------------------------------------------- */
+
+div.body {
+    min-width: 360px;
+    max-width: 800px;
+}
+
+div.body p, div.body dd, div.body li, div.body blockquote {
+    -moz-hyphens: auto;
+    -ms-hyphens: auto;
+    -webkit-hyphens: auto;
+    hyphens: auto;
+}
+
+a.headerlink {
+    visibility: hidden;
+}
+
+a:visited {
+    color: #551A8B;
+}
+
+h1:hover > a.headerlink,
+h2:hover > a.headerlink,
+h3:hover > a.headerlink,
+h4:hover > a.headerlink,
+h5:hover > a.headerlink,
+h6:hover > a.headerlink,
+dt:hover > a.headerlink,
+caption:hover > a.headerlink,
+p.caption:hover > a.headerlink,
+div.code-block-caption:hover > a.headerlink {
+    visibility: visible;
+}
+
+div.body p.caption {
+    text-align: inherit;
+}
+
+div.body td {
+    text-align: left;
+}
+
+.first {
+    margin-top: 0 !important;
+}
+
+p.rubric {
+    margin-top: 30px;
+    font-weight: bold;
+}
+
+img.align-left, figure.align-left, .figure.align-left, object.align-left {
+    clear: left;
+    float: left;
+    margin-right: 1em;
+}
+
+img.align-right, figure.align-right, .figure.align-right, object.align-right {
+    clear: right;
+    float: right;
+    margin-left: 1em;
+}
+
+img.align-center, figure.align-center, .figure.align-center, object.align-center {
+  display: block;
+  margin-left: auto;
+  margin-right: auto;
+}
+
+img.align-default, figure.align-default, .figure.align-default {
+  display: block;
+  margin-left: auto;
+  margin-right: auto;
+}
+
+.align-left {
+    text-align: left;
+}
+
+.align-center {
+    text-align: center;
+}
+
+.align-default {
+    text-align: center;
+}
+
+.align-right {
+    text-align: right;
+}
+
+/* -- sidebars -------------------------------------------------------------- */
+
+div.sidebar,
+aside.sidebar {
+    margin: 0 0 0.5em 1em;
+    border: 1px solid #ddb;
+    padding: 7px;
+    background-color: #ffe;
+    width: 40%;
+    float: right;
+    clear: right;
+    overflow-x: auto;
+}
+
+p.sidebar-title {
+    font-weight: bold;
+}
+
+nav.contents,
+aside.topic,
+div.admonition, div.topic, blockquote {
+    clear: left;
+}
+
+/* -- topics ---------------------------------------------------------------- */
+
+nav.contents,
+aside.topic,
+div.topic {
+    border: 1px solid #ccc;
+    padding: 7px;
+    margin: 10px 0 10px 0;
+}
+
+p.topic-title {
+    font-size: 1.1em;
+    font-weight: bold;
+    margin-top: 10px;
+}
+
+/* -- admonitions ----------------------------------------------------------- */
+
+div.admonition {
+    margin-top: 10px;
+    margin-bottom: 10px;
+    padding: 7px;
+}
+
+div.admonition dt {
+    font-weight: bold;
+}
+
+p.admonition-title {
+    margin: 0px 10px 5px 0px;
+    font-weight: bold;
+}
+
+div.body p.centered {
+    text-align: center;
+    margin-top: 25px;
+}
+
+/* -- content of sidebars/topics/admonitions -------------------------------- */
+
+div.sidebar > :last-child,
+aside.sidebar > :last-child,
+nav.contents > :last-child,
+aside.topic > :last-child,
+div.topic > :last-child,
+div.admonition > :last-child {
+    margin-bottom: 0;
+}
+
+div.sidebar::after,
+aside.sidebar::after,
+nav.contents::after,
+aside.topic::after,
+div.topic::after,
+div.admonition::after,
+blockquote::after {
+    display: block;
+    content: '';
+    clear: both;
+}
+
+/* -- tables ---------------------------------------------------------------- */
+
+table.docutils {
+    margin-top: 10px;
+    margin-bottom: 10px;
+    border: 0;
+    border-collapse: collapse;
+}
+
+table.align-center {
+    margin-left: auto;
+    margin-right: auto;
+}
+
+table.align-default {
+    margin-left: auto;
+    margin-right: auto;
+}
+
+table caption span.caption-number {
+    font-style: italic;
+}
+
+table caption span.caption-text {
+}
+
+table.docutils td, table.docutils th {
+    padding: 1px 8px 1px 5px;
+    border-top: 0;
+    border-left: 0;
+    border-right: 0;
+    border-bottom: 1px solid #aaa;
+}
+
+th {
+    text-align: left;
+    padding-right: 5px;
+}
+
+table.citation {
+    border-left: solid 1px gray;
+    margin-left: 1px;
+}
+
+table.citation td {
+    border-bottom: none;
+}
+
+th > :first-child,
+td > :first-child {
+    margin-top: 0px;
+}
+
+th > :last-child,
+td > :last-child {
+    margin-bottom: 0px;
+}
+
+/* -- figures --------------------------------------------------------------- */
+
+div.figure, figure {
+    margin: 0.5em;
+    padding: 0.5em;
+}
+
+div.figure p.caption, figcaption {
+    padding: 0.3em;
+}
+
+div.figure p.caption span.caption-number,
+figcaption span.caption-number {
+    font-style: italic;
+}
+
+div.figure p.caption span.caption-text,
+figcaption span.caption-text {
+}
+
+/* -- field list styles ----------------------------------------------------- */
+
+table.field-list td, table.field-list th {
+    border: 0 !important;
+}
+
+.field-list ul {
+    margin: 0;
+    padding-left: 1em;
+}
+
+.field-list p {
+    margin: 0;
+}
+
+.field-name {
+    -moz-hyphens: manual;
+    -ms-hyphens: manual;
+    -webkit-hyphens: manual;
+    hyphens: manual;
+}
+
+/* -- hlist styles ---------------------------------------------------------- */
+
+table.hlist {
+    margin: 1em 0;
+}
+
+table.hlist td {
+    vertical-align: top;
+}
+
+/* -- object description styles --------------------------------------------- */
+
+.sig {
+	font-family: 'Consolas', 'Menlo', 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', monospace;
+}
+
+.sig-name, code.descname {
+    background-color: transparent;
+    font-weight: bold;
+}
+
+.sig-name {
+	font-size: 1.1em;
+}
+
+code.descname {
+    font-size: 1.2em;
+}
+
+.sig-prename, code.descclassname {
+    background-color: transparent;
+}
+
+.optional {
+    font-size: 1.3em;
+}
+
+.sig-paren {
+    font-size: larger;
+}
+
+.sig-param.n {
+	font-style: italic;
+}
+
+/* C++ specific styling */
+
+.sig-inline.c-texpr,
+.sig-inline.cpp-texpr {
+	font-family: unset;
+}
+
+.sig.c   .k, .sig.c   .kt,
+.sig.cpp .k, .sig.cpp .kt {
+	color: #0033B3;
+}
+
+.sig.c   .m,
+.sig.cpp .m {
+	color: #1750EB;
+}
+
+.sig.c   .s, .sig.c   .sc,
+.sig.cpp .s, .sig.cpp .sc {
+	color: #067D17;
+}
+
+
+/* -- other body styles ----------------------------------------------------- */
+
+ol.arabic {
+    list-style: decimal;
+}
+
+ol.loweralpha {
+    list-style: lower-alpha;
+}
+
+ol.upperalpha {
+    list-style: upper-alpha;
+}
+
+ol.lowerroman {
+    list-style: lower-roman;
+}
+
+ol.upperroman {
+    list-style: upper-roman;
+}
+
+:not(li) > ol > li:first-child > :first-child,
+:not(li) > ul > li:first-child > :first-child {
+    margin-top: 0px;
+}
+
+:not(li) > ol > li:last-child > :last-child,
+:not(li) > ul > li:last-child > :last-child {
+    margin-bottom: 0px;
+}
+
+ol.simple ol p,
+ol.simple ul p,
+ul.simple ol p,
+ul.simple ul p {
+    margin-top: 0;
+}
+
+ol.simple > li:not(:first-child) > p,
+ul.simple > li:not(:first-child) > p {
+    margin-top: 0;
+}
+
+ol.simple p,
+ul.simple p {
+    margin-bottom: 0;
+}
+
+aside.footnote > span,
+div.citation > span {
+    float: left;
+}
+aside.footnote > span:last-of-type,
+div.citation > span:last-of-type {
+  padding-right: 0.5em;
+}
+aside.footnote > p {
+  margin-left: 2em;
+}
+div.citation > p {
+  margin-left: 4em;
+}
+aside.footnote > p:last-of-type,
+div.citation > p:last-of-type {
+    margin-bottom: 0em;
+}
+aside.footnote > p:last-of-type:after,
+div.citation > p:last-of-type:after {
+    content: "";
+    clear: both;
+}
+
+dl.field-list {
+    display: grid;
+    grid-template-columns: fit-content(30%) auto;
+}
+
+dl.field-list > dt {
+    font-weight: bold;
+    word-break: break-word;
+    padding-left: 0.5em;
+    padding-right: 5px;
+}
+
+dl.field-list > dd {
+    padding-left: 0.5em;
+    margin-top: 0em;
+    margin-left: 0em;
+    margin-bottom: 0em;
+}
+
+dl {
+    margin-bottom: 15px;
+}
+
+dd > :first-child {
+    margin-top: 0px;
+}
+
+dd ul, dd table {
+    margin-bottom: 10px;
+}
+
+dd {
+    margin-top: 3px;
+    margin-bottom: 10px;
+    margin-left: 30px;
+}
+
+.sig dd {
+    margin-top: 0px;
+    margin-bottom: 0px;
+}
+
+.sig dl {
+    margin-top: 0px;
+    margin-bottom: 0px;
+}
+
+dl > dd:last-child,
+dl > dd:last-child > :last-child {
+    margin-bottom: 0;
+}
+
+dt:target, span.highlighted {
+    background-color: #fbe54e;
+}
+
+rect.highlighted {
+    fill: #fbe54e;
+}
+
+dl.glossary dt {
+    font-weight: bold;
+    font-size: 1.1em;
+}
+
+.versionmodified {
+    font-style: italic;
+}
+
+.system-message {
+    background-color: #fda;
+    padding: 5px;
+    border: 3px solid red;
+}
+
+.footnote:target  {
+    background-color: #ffa;
+}
+
+.line-block {
+    display: block;
+    margin-top: 1em;
+    margin-bottom: 1em;
+}
+
+.line-block .line-block {
+    margin-top: 0;
+    margin-bottom: 0;
+    margin-left: 1.5em;
+}
+
+.guilabel, .menuselection {
+    font-family: sans-serif;
+}
+
+.accelerator {
+    text-decoration: underline;
+}
+
+.classifier {
+    font-style: oblique;
+}
+
+.classifier:before {
+    font-style: normal;
+    margin: 0 0.5em;
+    content: ":";
+    display: inline-block;
+}
+
+abbr, acronym {
+    border-bottom: dotted 1px;
+    cursor: help;
+}
+
+.translated {
+    background-color: rgba(207, 255, 207, 0.2)
+}
+
+.untranslated {
+    background-color: rgba(255, 207, 207, 0.2)
+}
+
+/* -- code displays --------------------------------------------------------- */
+
+pre {
+    overflow: auto;
+    overflow-y: hidden;  /* fixes display issues on Chrome browsers */
+}
+
+pre, div[class*="highlight-"] {
+    clear: both;
+}
+
+span.pre {
+    -moz-hyphens: none;
+    -ms-hyphens: none;
+    -webkit-hyphens: none;
+    hyphens: none;
+    white-space: nowrap;
+}
+
+div[class*="highlight-"] {
+    margin: 1em 0;
+}
+
+td.linenos pre {
+    border: 0;
+    background-color: transparent;
+    color: #aaa;
+}
+
+table.highlighttable {
+    display: block;
+}
+
+table.highlighttable tbody {
+    display: block;
+}
+
+table.highlighttable tr {
+    display: flex;
+}
+
+table.highlighttable td {
+    margin: 0;
+    padding: 0;
+}
+
+table.highlighttable td.linenos {
+    padding-right: 0.5em;
+}
+
+table.highlighttable td.code {
+    flex: 1;
+    overflow: hidden;
+}
+
+.highlight .hll {
+    display: block;
+}
+
+div.highlight pre,
+table.highlighttable pre {
+    margin: 0;
+}
+
+div.code-block-caption + div {
+    margin-top: 0;
+}
+
+div.code-block-caption {
+    margin-top: 1em;
+    padding: 2px 5px;
+    font-size: small;
+}
+
+div.code-block-caption code {
+    background-color: transparent;
+}
+
+table.highlighttable td.linenos,
+span.linenos,
+div.highlight span.gp {  /* gp: Generic.Prompt */
+  user-select: none;
+  -webkit-user-select: text; /* Safari fallback only */
+  -webkit-user-select: none; /* Chrome/Safari */
+  -moz-user-select: none; /* Firefox */
+  -ms-user-select: none; /* IE10+ */
+}
+
+div.code-block-caption span.caption-number {
+    padding: 0.1em 0.3em;
+    font-style: italic;
+}
+
+div.code-block-caption span.caption-text {
+}
+
+div.literal-block-wrapper {
+    margin: 1em 0;
+}
+
+code.xref, a code {
+    background-color: transparent;
+    font-weight: bold;
+}
+
+h1 code, h2 code, h3 code, h4 code, h5 code, h6 code {
+    background-color: transparent;
+}
+
+.viewcode-link {
+    float: right;
+}
+
+.viewcode-back {
+    float: right;
+    font-family: sans-serif;
+}
+
+div.viewcode-block:target {
+    margin: -1px -10px;
+    padding: 0 10px;
+}
+
+/* -- math display ---------------------------------------------------------- */
+
+img.math {
+    vertical-align: middle;
+}
+
+div.body div.math p {
+    text-align: center;
+}
+
+span.eqno {
+    float: right;
+}
+
+span.eqno a.headerlink {
+    position: absolute;
+    z-index: 1;
+}
+
+div.math:hover a.headerlink {
+    visibility: visible;
+}
+
+/* -- printout stylesheet --------------------------------------------------- */
+
+@media print {
+    div.document,
+    div.documentwrapper,
+    div.bodywrapper {
+        margin: 0 !important;
+        width: 100%;
+    }
+
+    div.sphinxsidebar,
+    div.related,
+    div.footer,
+    #top-link {
+        display: none;
+    }
+}
\ No newline at end of file
diff --git a/_static/classic.css b/_static/classic.css
new file mode 100644
index 000000000..9ad992b8a
--- /dev/null
+++ b/_static/classic.css
@@ -0,0 +1,269 @@
+/*
+ * classic.css_t
+ * ~~~~~~~~~~~~~
+ *
+ * Sphinx stylesheet -- classic theme.
+ *
+ * :copyright: Copyright 2007-2023 by the Sphinx team, see AUTHORS.
+ * :license: BSD, see LICENSE for details.
+ *
+ */
+
+@import url("basic.css");
+
+/* -- page layout ----------------------------------------------------------- */
+
+html {
+    /* CSS hack for macOS's scrollbar (see #1125) */
+    background-color: #FFFFFF;
+}
+
+body {
+    font-family: sans-serif;
+    font-size: 100%;
+    background-color: #11303d;
+    color: #000;
+    margin: 0;
+    padding: 0;
+}
+
+div.document {
+    display: flex;
+    background-color: #1c4e63;
+}
+
+div.documentwrapper {
+    float: left;
+    width: 100%;
+}
+
+div.bodywrapper {
+    margin: 0 0 0 230px;
+}
+
+div.body {
+    background-color: #ffffff;
+    color: #000000;
+    padding: 0 20px 30px 20px;
+}
+
+div.footer {
+    color: #ffffff;
+    width: 100%;
+    padding: 9px 0 9px 0;
+    text-align: center;
+    font-size: 75%;
+}
+
+div.footer a {
+    color: #ffffff;
+    text-decoration: underline;
+}
+
+div.related {
+    background-color: #133f52;
+    line-height: 30px;
+    color: #ffffff;
+}
+
+div.related a {
+    color: #ffffff;
+}
+
+div.sphinxsidebar {
+}
+
+div.sphinxsidebar h3 {
+    font-family: 'Trebuchet MS', sans-serif;
+    color: #ffffff;
+    font-size: 1.4em;
+    font-weight: normal;
+    margin: 0;
+    padding: 0;
+}
+
+div.sphinxsidebar h3 a {
+    color: #ffffff;
+}
+
+div.sphinxsidebar h4 {
+    font-family: 'Trebuchet MS', sans-serif;
+    color: #ffffff;
+    font-size: 1.3em;
+    font-weight: normal;
+    margin: 5px 0 0 0;
+    padding: 0;
+}
+
+div.sphinxsidebar p {
+    color: #ffffff;
+}
+
+div.sphinxsidebar p.topless {
+    margin: 5px 10px 10px 10px;
+}
+
+div.sphinxsidebar ul {
+    margin: 10px;
+    padding: 0;
+    color: #ffffff;
+}
+
+div.sphinxsidebar a {
+    color: #98dbcc;
+}
+
+div.sphinxsidebar input {
+    border: 1px solid #98dbcc;
+    font-family: sans-serif;
+    font-size: 1em;
+}
+
+
+
+/* -- hyperlink styles ------------------------------------------------------ */
+
+a {
+    color: #355f7c;
+    text-decoration: none;
+}
+
+a:visited {
+    color: #551a8b;
+    text-decoration: none;
+}
+
+a:hover {
+    text-decoration: underline;
+}
+
+
+
+/* -- body styles ----------------------------------------------------------- */
+
+div.body h1,
+div.body h2,
+div.body h3,
+div.body h4,
+div.body h5,
+div.body h6 {
+    font-family: 'Trebuchet MS', sans-serif;
+    background-color: #f2f2f2;
+    font-weight: normal;
+    color: #20435c;
+    border-bottom: 1px solid #ccc;
+    margin: 20px -20px 10px -20px;
+    padding: 3px 0 3px 10px;
+}
+
+div.body h1 { margin-top: 0; font-size: 200%; }
+div.body h2 { font-size: 160%; }
+div.body h3 { font-size: 140%; }
+div.body h4 { font-size: 120%; }
+div.body h5 { font-size: 110%; }
+div.body h6 { font-size: 100%; }
+
+a.headerlink {
+    color: #c60f0f;
+    font-size: 0.8em;
+    padding: 0 4px 0 4px;
+    text-decoration: none;
+}
+
+a.headerlink:hover {
+    background-color: #c60f0f;
+    color: white;
+}
+
+div.body p, div.body dd, div.body li, div.body blockquote {
+    text-align: justify;
+    line-height: 130%;
+}
+
+div.admonition p.admonition-title + p {
+    display: inline;
+}
+
+div.admonition p {
+    margin-bottom: 5px;
+}
+
+div.admonition pre {
+    margin-bottom: 5px;
+}
+
+div.admonition ul, div.admonition ol {
+    margin-bottom: 5px;
+}
+
+div.note {
+    background-color: #eee;
+    border: 1px solid #ccc;
+}
+
+div.seealso {
+    background-color: #ffc;
+    border: 1px solid #ff6;
+}
+
+nav.contents,
+aside.topic,
+div.topic {
+    background-color: #eee;
+}
+
+div.warning {
+    background-color: #ffe4e4;
+    border: 1px solid #f66;
+}
+
+p.admonition-title {
+    display: inline;
+}
+
+p.admonition-title:after {
+    content: ":";
+}
+
+pre {
+    padding: 5px;
+    background-color: unset;
+    color: unset;
+    line-height: 120%;
+    border: 1px solid #ac9;
+    border-left: none;
+    border-right: none;
+}
+
+code {
+    background-color: #ecf0f3;
+    padding: 0 1px 0 1px;
+    font-size: 0.95em;
+}
+
+th, dl.field-list > dt {
+    background-color: #ede;
+}
+
+.warning code {
+    background: #efc2c2;
+}
+
+.note code {
+    background: #d6d6d6;
+}
+
+.viewcode-back {
+    font-family: sans-serif;
+}
+
+div.viewcode-block:target {
+    background-color: #f4debf;
+    border-top: 1px solid #ac9;
+    border-bottom: 1px solid #ac9;
+}
+
+div.code-block-caption {
+    color: #efefef;
+    background-color: #1c4e63;
+}
\ No newline at end of file
diff --git a/_static/default.css b/_static/default.css
new file mode 100644
index 000000000..81b936363
--- /dev/null
+++ b/_static/default.css
@@ -0,0 +1 @@
+@import url("classic.css");
diff --git a/_static/doctools.js b/_static/doctools.js
new file mode 100644
index 000000000..d06a71d75
--- /dev/null
+++ b/_static/doctools.js
@@ -0,0 +1,156 @@
+/*
+ * doctools.js
+ * ~~~~~~~~~~~
+ *
+ * Base JavaScript utilities for all Sphinx HTML documentation.
+ *
+ * :copyright: Copyright 2007-2023 by the Sphinx team, see AUTHORS.
+ * :license: BSD, see LICENSE for details.
+ *
+ */
+"use strict";
+
+const BLACKLISTED_KEY_CONTROL_ELEMENTS = new Set([
+  "TEXTAREA",
+  "INPUT",
+  "SELECT",
+  "BUTTON",
+]);
+
+const _ready = (callback) => {
+  if (document.readyState !== "loading") {
+    callback();
+  } else {
+    document.addEventListener("DOMContentLoaded", callback);
+  }
+};
+
+/**
+ * Small JavaScript module for the documentation.
+ */
+const Documentation = {
+  init: () => {
+    Documentation.initDomainIndexTable();
+    Documentation.initOnKeyListeners();
+  },
+
+  /**
+   * i18n support
+   */
+  TRANSLATIONS: {},
+  PLURAL_EXPR: (n) => (n === 1 ? 0 : 1),
+  LOCALE: "unknown",
+
+  // gettext and ngettext don't access this so that the functions
+  // can safely bound to a different name (_ = Documentation.gettext)
+  gettext: (string) => {
+    const translated = Documentation.TRANSLATIONS[string];
+    switch (typeof translated) {
+      case "undefined":
+        return string; // no translation
+      case "string":
+        return translated; // translation exists
+      default:
+        return translated[0]; // (singular, plural) translation tuple exists
+    }
+  },
+
+  ngettext: (singular, plural, n) => {
+    const translated = Documentation.TRANSLATIONS[singular];
+    if (typeof translated !== "undefined")
+      return translated[Documentation.PLURAL_EXPR(n)];
+    return n === 1 ? singular : plural;
+  },
+
+  addTranslations: (catalog) => {
+    Object.assign(Documentation.TRANSLATIONS, catalog.messages);
+    Documentation.PLURAL_EXPR = new Function(
+      "n",
+      `return (${catalog.plural_expr})`
+    );
+    Documentation.LOCALE = catalog.locale;
+  },
+
+  /**
+   * helper function to focus on search bar
+   */
+  focusSearchBar: () => {
+    document.querySelectorAll("input[name=q]")[0]?.focus();
+  },
+
+  /**
+   * Initialise the domain index toggle buttons
+   */
+  initDomainIndexTable: () => {
+    const toggler = (el) => {
+      const idNumber = el.id.substr(7);
+      const toggledRows = document.querySelectorAll(`tr.cg-${idNumber}`);
+      if (el.src.substr(-9) === "minus.png") {
+        el.src = `${el.src.substr(0, el.src.length - 9)}plus.png`;
+        toggledRows.forEach((el) => (el.style.display = "none"));
+      } else {
+        el.src = `${el.src.substr(0, el.src.length - 8)}minus.png`;
+        toggledRows.forEach((el) => (el.style.display = ""));
+      }
+    };
+
+    const togglerElements = document.querySelectorAll("img.toggler");
+    togglerElements.forEach((el) =>
+      el.addEventListener("click", (event) => toggler(event.currentTarget))
+    );
+    togglerElements.forEach((el) => (el.style.display = ""));
+    if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) togglerElements.forEach(toggler);
+  },
+
+  initOnKeyListeners: () => {
+    // only install a listener if it is really needed
+    if (
+      !DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS &&
+      !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS
+    )
+      return;
+
+    document.addEventListener("keydown", (event) => {
+      // bail for input elements
+      if (BLACKLISTED_KEY_CONTROL_ELEMENTS.has(document.activeElement.tagName)) return;
+      // bail with special keys
+      if (event.altKey || event.ctrlKey || event.metaKey) return;
+
+      if (!event.shiftKey) {
+        switch (event.key) {
+          case "ArrowLeft":
+            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break;
+
+            const prevLink = document.querySelector('link[rel="prev"]');
+            if (prevLink && prevLink.href) {
+              window.location.href = prevLink.href;
+              event.preventDefault();
+            }
+            break;
+          case "ArrowRight":
+            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break;
+
+            const nextLink = document.querySelector('link[rel="next"]');
+            if (nextLink && nextLink.href) {
+              window.location.href = nextLink.href;
+              event.preventDefault();
+            }
+            break;
+        }
+      }
+
+      // some keyboard layouts may need Shift to get /
+      switch (event.key) {
+        case "/":
+          if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break;
+          Documentation.focusSearchBar();
+          event.preventDefault();
+      }
+    });
+  },
+};
+
+// quick alias for translations
+const _ = Documentation.gettext;
+
+_ready(Documentation.init);
diff --git a/_static/documentation_options.js b/_static/documentation_options.js
new file mode 100644
index 000000000..91676b19b
--- /dev/null
+++ b/_static/documentation_options.js
@@ -0,0 +1,13 @@
+const DOCUMENTATION_OPTIONS = {
+    VERSION: '2020.0',
+    LANGUAGE: 'en',
+    COLLAPSE_INDEX: false,
+    BUILDER: 'html',
+    FILE_SUFFIX: '.html',
+    LINK_SUFFIX: '.html',
+    HAS_SOURCE: true,
+    SOURCELINK_SUFFIX: '.txt',
+    NAVIGATION_WITH_KEYS: false,
+    SHOW_SEARCH_SUMMARY: true,
+    ENABLE_SEARCH_SHORTCUTS: true,
+};
\ No newline at end of file
diff --git a/_static/file.png b/_static/file.png
new file mode 100644
index 000000000..a858a410e
Binary files /dev/null and b/_static/file.png differ
diff --git a/_static/language_data.js b/_static/language_data.js
new file mode 100644
index 000000000..250f5665f
--- /dev/null
+++ b/_static/language_data.js
@@ -0,0 +1,199 @@
+/*
+ * language_data.js
+ * ~~~~~~~~~~~~~~~~
+ *
+ * This script contains the language-specific data used by searchtools.js,
+ * namely the list of stopwords, stemmer, scorer and splitter.
+ *
+ * :copyright: Copyright 2007-2023 by the Sphinx team, see AUTHORS.
+ * :license: BSD, see LICENSE for details.
+ *
+ */
+
+var stopwords = ["a", "and", "are", "as", "at", "be", "but", "by", "for", "if", "in", "into", "is", "it", "near", "no", "not", "of", "on", "or", "such", "that", "the", "their", "then", "there", "these", "they", "this", "to", "was", "will", "with"];
+
+
+/* Non-minified version is copied as a separate JS file, is available */
+
+/**
+ * Porter Stemmer
+ */
+var Stemmer = function() {
+
+  var step2list = {
+    ational: 'ate',
+    tional: 'tion',
+    enci: 'ence',
+    anci: 'ance',
+    izer: 'ize',
+    bli: 'ble',
+    alli: 'al',
+    entli: 'ent',
+    eli: 'e',
+    ousli: 'ous',
+    ization: 'ize',
+    ation: 'ate',
+    ator: 'ate',
+    alism: 'al',
+    iveness: 'ive',
+    fulness: 'ful',
+    ousness: 'ous',
+    aliti: 'al',
+    iviti: 'ive',
+    biliti: 'ble',
+    logi: 'log'
+  };
+
+  var step3list = {
+    icate: 'ic',
+    ative: '',
+    alize: 'al',
+    iciti: 'ic',
+    ical: 'ic',
+    ful: '',
+    ness: ''
+  };
+
+  var c = "[^aeiou]";          // consonant
+  var v = "[aeiouy]";          // vowel
+  var C = c + "[^aeiouy]*";    // consonant sequence
+  var V = v + "[aeiou]*";      // vowel sequence
+
+  var mgr0 = "^(" + C + ")?" + V + C;                      // [C]VC... is m>0
+  var meq1 = "^(" + C + ")?" + V + C + "(" + V + ")?$";    // [C]VC[V] is m=1
+  var mgr1 = "^(" + C + ")?" + V + C + V + C;              // [C]VCVC... is m>1
+  var s_v   = "^(" + C + ")?" + v;                         // vowel in stem
+
+  this.stemWord = function (w) {
+    var stem;
+    var suffix;
+    var firstch;
+    var origword = w;
+
+    if (w.length < 3)
+      return w;
+
+    var re;
+    var re2;
+    var re3;
+    var re4;
+
+    firstch = w.substr(0,1);
+    if (firstch == "y")
+      w = firstch.toUpperCase() + w.substr(1);
+
+    // Step 1a
+    re = /^(.+?)(ss|i)es$/;
+    re2 = /^(.+?)([^s])s$/;
+
+    if (re.test(w))
+      w = w.replace(re,"$1$2");
+    else if (re2.test(w))
+      w = w.replace(re2,"$1$2");
+
+    // Step 1b
+    re = /^(.+?)eed$/;
+    re2 = /^(.+?)(ed|ing)$/;
+    if (re.test(w)) {
+      var fp = re.exec(w);
+      re = new RegExp(mgr0);
+      if (re.test(fp[1])) {
+        re = /.$/;
+        w = w.replace(re,"");
+      }
+    }
+    else if (re2.test(w)) {
+      var fp = re2.exec(w);
+      stem = fp[1];
+      re2 = new RegExp(s_v);
+      if (re2.test(stem)) {
+        w = stem;
+        re2 = /(at|bl|iz)$/;
+        re3 = new RegExp("([^aeiouylsz])\\1$");
+        re4 = new RegExp("^" + C + v + "[^aeiouwxy]$");
+        if (re2.test(w))
+          w = w + "e";
+        else if (re3.test(w)) {
+          re = /.$/;
+          w = w.replace(re,"");
+        }
+        else if (re4.test(w))
+          w = w + "e";
+      }
+    }
+
+    // Step 1c
+    re = /^(.+?)y$/;
+    if (re.test(w)) {
+      var fp = re.exec(w);
+      stem = fp[1];
+      re = new RegExp(s_v);
+      if (re.test(stem))
+        w = stem + "i";
+    }
+
+    // Step 2
+    re = /^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/;
+    if (re.test(w)) {
+      var fp = re.exec(w);
+      stem = fp[1];
+      suffix = fp[2];
+      re = new RegExp(mgr0);
+      if (re.test(stem))
+        w = stem + step2list[suffix];
+    }
+
+    // Step 3
+    re = /^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/;
+    if (re.test(w)) {
+      var fp = re.exec(w);
+      stem = fp[1];
+      suffix = fp[2];
+      re = new RegExp(mgr0);
+      if (re.test(stem))
+        w = stem + step3list[suffix];
+    }
+
+    // Step 4
+    re = /^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/;
+    re2 = /^(.+?)(s|t)(ion)$/;
+    if (re.test(w)) {
+      var fp = re.exec(w);
+      stem = fp[1];
+      re = new RegExp(mgr1);
+      if (re.test(stem))
+        w = stem;
+    }
+    else if (re2.test(w)) {
+      var fp = re2.exec(w);
+      stem = fp[1] + fp[2];
+      re2 = new RegExp(mgr1);
+      if (re2.test(stem))
+        w = stem;
+    }
+
+    // Step 5
+    re = /^(.+?)e$/;
+    if (re.test(w)) {
+      var fp = re.exec(w);
+      stem = fp[1];
+      re = new RegExp(mgr1);
+      re2 = new RegExp(meq1);
+      re3 = new RegExp("^" + C + v + "[^aeiouwxy]$");
+      if (re.test(stem) || (re2.test(stem) && !(re3.test(stem))))
+        w = stem;
+    }
+    re = /ll$/;
+    re2 = new RegExp(mgr1);
+    if (re.test(w) && re2.test(w)) {
+      re = /.$/;
+      w = w.replace(re,"");
+    }
+
+    // and turn initial Y back to y
+    if (firstch == "y")
+      w = firstch.toLowerCase() + w.substr(1);
+    return w;
+  }
+}
+
diff --git a/_static/minus.png b/_static/minus.png
new file mode 100644
index 000000000..d96755fda
Binary files /dev/null and b/_static/minus.png differ
diff --git a/_static/plus.png b/_static/plus.png
new file mode 100644
index 000000000..7107cec93
Binary files /dev/null and b/_static/plus.png differ
diff --git a/_static/pygments.css b/_static/pygments.css
new file mode 100644
index 000000000..0d49244ed
--- /dev/null
+++ b/_static/pygments.css
@@ -0,0 +1,75 @@
+pre { line-height: 125%; }
+td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
+span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
+td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
+span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
+.highlight .hll { background-color: #ffffcc }
+.highlight { background: #eeffcc; }
+.highlight .c { color: #408090; font-style: italic } /* Comment */
+.highlight .err { border: 1px solid #FF0000 } /* Error */
+.highlight .k { color: #007020; font-weight: bold } /* Keyword */
+.highlight .o { color: #666666 } /* Operator */
+.highlight .ch { color: #408090; font-style: italic } /* Comment.Hashbang */
+.highlight .cm { color: #408090; font-style: italic } /* Comment.Multiline */
+.highlight .cp { color: #007020 } /* Comment.Preproc */
+.highlight .cpf { color: #408090; font-style: italic } /* Comment.PreprocFile */
+.highlight .c1 { color: #408090; font-style: italic } /* Comment.Single */
+.highlight .cs { color: #408090; background-color: #fff0f0 } /* Comment.Special */
+.highlight .gd { color: #A00000 } /* Generic.Deleted */
+.highlight .ge { font-style: italic } /* Generic.Emph */
+.highlight .ges { font-weight: bold; font-style: italic } /* Generic.EmphStrong */
+.highlight .gr { color: #FF0000 } /* Generic.Error */
+.highlight .gh { color: #000080; font-weight: bold } /* Generic.Heading */
+.highlight .gi { color: #00A000 } /* Generic.Inserted */
+.highlight .go { color: #333333 } /* Generic.Output */
+.highlight .gp { color: #c65d09; font-weight: bold } /* Generic.Prompt */
+.highlight .gs { font-weight: bold } /* Generic.Strong */
+.highlight .gu { color: #800080; font-weight: bold } /* Generic.Subheading */
+.highlight .gt { color: #0044DD } /* Generic.Traceback */
+.highlight .kc { color: #007020; font-weight: bold } /* Keyword.Constant */
+.highlight .kd { color: #007020; font-weight: bold } /* Keyword.Declaration */
+.highlight .kn { color: #007020; font-weight: bold } /* Keyword.Namespace */
+.highlight .kp { color: #007020 } /* Keyword.Pseudo */
+.highlight .kr { color: #007020; font-weight: bold } /* Keyword.Reserved */
+.highlight .kt { color: #902000 } /* Keyword.Type */
+.highlight .m { color: #208050 } /* Literal.Number */
+.highlight .s { color: #4070a0 } /* Literal.String */
+.highlight .na { color: #4070a0 } /* Name.Attribute */
+.highlight .nb { color: #007020 } /* Name.Builtin */
+.highlight .nc { color: #0e84b5; font-weight: bold } /* Name.Class */
+.highlight .no { color: #60add5 } /* Name.Constant */
+.highlight .nd { color: #555555; font-weight: bold } /* Name.Decorator */
+.highlight .ni { color: #d55537; font-weight: bold } /* Name.Entity */
+.highlight .ne { color: #007020 } /* Name.Exception */
+.highlight .nf { color: #06287e } /* Name.Function */
+.highlight .nl { color: #002070; font-weight: bold } /* Name.Label */
+.highlight .nn { color: #0e84b5; font-weight: bold } /* Name.Namespace */
+.highlight .nt { color: #062873; font-weight: bold } /* Name.Tag */
+.highlight .nv { color: #bb60d5 } /* Name.Variable */
+.highlight .ow { color: #007020; font-weight: bold } /* Operator.Word */
+.highlight .w { color: #bbbbbb } /* Text.Whitespace */
+.highlight .mb { color: #208050 } /* Literal.Number.Bin */
+.highlight .mf { color: #208050 } /* Literal.Number.Float */
+.highlight .mh { color: #208050 } /* Literal.Number.Hex */
+.highlight .mi { color: #208050 } /* Literal.Number.Integer */
+.highlight .mo { color: #208050 } /* Literal.Number.Oct */
+.highlight .sa { color: #4070a0 } /* Literal.String.Affix */
+.highlight .sb { color: #4070a0 } /* Literal.String.Backtick */
+.highlight .sc { color: #4070a0 } /* Literal.String.Char */
+.highlight .dl { color: #4070a0 } /* Literal.String.Delimiter */
+.highlight .sd { color: #4070a0; font-style: italic } /* Literal.String.Doc */
+.highlight .s2 { color: #4070a0 } /* Literal.String.Double */
+.highlight .se { color: #4070a0; font-weight: bold } /* Literal.String.Escape */
+.highlight .sh { color: #4070a0 } /* Literal.String.Heredoc */
+.highlight .si { color: #70a0d0; font-style: italic } /* Literal.String.Interpol */
+.highlight .sx { color: #c65d09 } /* Literal.String.Other */
+.highlight .sr { color: #235388 } /* Literal.String.Regex */
+.highlight .s1 { color: #4070a0 } /* Literal.String.Single */
+.highlight .ss { color: #517918 } /* Literal.String.Symbol */
+.highlight .bp { color: #007020 } /* Name.Builtin.Pseudo */
+.highlight .fm { color: #06287e } /* Name.Function.Magic */
+.highlight .vc { color: #bb60d5 } /* Name.Variable.Class */
+.highlight .vg { color: #bb60d5 } /* Name.Variable.Global */
+.highlight .vi { color: #bb60d5 } /* Name.Variable.Instance */
+.highlight .vm { color: #bb60d5 } /* Name.Variable.Magic */
+.highlight .il { color: #208050 } /* Literal.Number.Integer.Long */
\ No newline at end of file
diff --git a/_static/searchtools.js b/_static/searchtools.js
new file mode 100644
index 000000000..7918c3fab
--- /dev/null
+++ b/_static/searchtools.js
@@ -0,0 +1,574 @@
+/*
+ * searchtools.js
+ * ~~~~~~~~~~~~~~~~
+ *
+ * Sphinx JavaScript utilities for the full-text search.
+ *
+ * :copyright: Copyright 2007-2023 by the Sphinx team, see AUTHORS.
+ * :license: BSD, see LICENSE for details.
+ *
+ */
+"use strict";
+
+/**
+ * Simple result scoring code.
+ */
+if (typeof Scorer === "undefined") {
+  var Scorer = {
+    // Implement the following function to further tweak the score for each result
+    // The function takes a result array [docname, title, anchor, descr, score, filename]
+    // and returns the new score.
+    /*
+    score: result => {
+      const [docname, title, anchor, descr, score, filename] = result
+      return score
+    },
+    */
+
+    // query matches the full name of an object
+    objNameMatch: 11,
+    // or matches in the last dotted part of the object name
+    objPartialMatch: 6,
+    // Additive scores depending on the priority of the object
+    objPrio: {
+      0: 15, // used to be importantResults
+      1: 5, // used to be objectResults
+      2: -5, // used to be unimportantResults
+    },
+    //  Used when the priority is not in the mapping.
+    objPrioDefault: 0,
+
+    // query found in title
+    title: 15,
+    partialTitle: 7,
+    // query found in terms
+    term: 5,
+    partialTerm: 2,
+  };
+}
+
+const _removeChildren = (element) => {
+  while (element && element.lastChild) element.removeChild(element.lastChild);
+};
+
+/**
+ * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#escaping
+ */
+const _escapeRegExp = (string) =>
+  string.replace(/[.*+\-?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string
+
+const _displayItem = (item, searchTerms, highlightTerms) => {
+  const docBuilder = DOCUMENTATION_OPTIONS.BUILDER;
+  const docFileSuffix = DOCUMENTATION_OPTIONS.FILE_SUFFIX;
+  const docLinkSuffix = DOCUMENTATION_OPTIONS.LINK_SUFFIX;
+  const showSearchSummary = DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY;
+  const contentRoot = document.documentElement.dataset.content_root;
+
+  const [docName, title, anchor, descr, score, _filename] = item;
+
+  let listItem = document.createElement("li");
+  let requestUrl;
+  let linkUrl;
+  if (docBuilder === "dirhtml") {
+    // dirhtml builder
+    let dirname = docName + "/";
+    if (dirname.match(/\/index\/$/))
+      dirname = dirname.substring(0, dirname.length - 6);
+    else if (dirname === "index/") dirname = "";
+    requestUrl = contentRoot + dirname;
+    linkUrl = requestUrl;
+  } else {
+    // normal html builders
+    requestUrl = contentRoot + docName + docFileSuffix;
+    linkUrl = docName + docLinkSuffix;
+  }
+  let linkEl = listItem.appendChild(document.createElement("a"));
+  linkEl.href = linkUrl + anchor;
+  linkEl.dataset.score = score;
+  linkEl.innerHTML = title;
+  if (descr) {
+    listItem.appendChild(document.createElement("span")).innerHTML =
+      " (" + descr + ")";
+    // highlight search terms in the description
+    if (SPHINX_HIGHLIGHT_ENABLED)  // set in sphinx_highlight.js
+      highlightTerms.forEach((term) => _highlightText(listItem, term, "highlighted"));
+  }
+  else if (showSearchSummary)
+    fetch(requestUrl)
+      .then((responseData) => responseData.text())
+      .then((data) => {
+        if (data)
+          listItem.appendChild(
+            Search.makeSearchSummary(data, searchTerms)
+          );
+        // highlight search terms in the summary
+        if (SPHINX_HIGHLIGHT_ENABLED)  // set in sphinx_highlight.js
+          highlightTerms.forEach((term) => _highlightText(listItem, term, "highlighted"));
+      });
+  Search.output.appendChild(listItem);
+};
+const _finishSearch = (resultCount) => {
+  Search.stopPulse();
+  Search.title.innerText = _("Search Results");
+  if (!resultCount)
+    Search.status.innerText = Documentation.gettext(
+      "Your search did not match any documents. Please make sure that all words are spelled correctly and that you've selected enough categories."
+    );
+  else
+    Search.status.innerText = _(
+      `Search finished, found ${resultCount} page(s) matching the search query.`
+    );
+};
+const _displayNextItem = (
+  results,
+  resultCount,
+  searchTerms,
+  highlightTerms,
+) => {
+  // results left, load the summary and display it
+  // this is intended to be dynamic (don't sub resultsCount)
+  if (results.length) {
+    _displayItem(results.pop(), searchTerms, highlightTerms);
+    setTimeout(
+      () => _displayNextItem(results, resultCount, searchTerms, highlightTerms),
+      5
+    );
+  }
+  // search finished, update title and status message
+  else _finishSearch(resultCount);
+};
+
+/**
+ * Default splitQuery function. Can be overridden in ``sphinx.search`` with a
+ * custom function per language.
+ *
+ * The regular expression works by splitting the string on consecutive characters
+ * that are not Unicode letters, numbers, underscores, or emoji characters.
+ * This is the same as ``\W+`` in Python, preserving the surrogate pair area.
+ */
+if (typeof splitQuery === "undefined") {
+  var splitQuery = (query) => query
+      .split(/[^\p{Letter}\p{Number}_\p{Emoji_Presentation}]+/gu)
+      .filter(term => term)  // remove remaining empty strings
+}
+
+/**
+ * Search Module
+ */
+const Search = {
+  _index: null,
+  _queued_query: null,
+  _pulse_status: -1,
+
+  htmlToText: (htmlString) => {
+    const htmlElement = new DOMParser().parseFromString(htmlString, 'text/html');
+    htmlElement.querySelectorAll(".headerlink").forEach((el) => { el.remove() });
+    const docContent = htmlElement.querySelector('[role="main"]');
+    if (docContent !== undefined) return docContent.textContent;
+    console.warn(
+      "Content block not found. Sphinx search tries to obtain it via '[role=main]'. Could you check your theme or template."
+    );
+    return "";
+  },
+
+  init: () => {
+    const query = new URLSearchParams(window.location.search).get("q");
+    document
+      .querySelectorAll('input[name="q"]')
+      .forEach((el) => (el.value = query));
+    if (query) Search.performSearch(query);
+  },
+
+  loadIndex: (url) =>
+    (document.body.appendChild(document.createElement("script")).src = url),
+
+  setIndex: (index) => {
+    Search._index = index;
+    if (Search._queued_query !== null) {
+      const query = Search._queued_query;
+      Search._queued_query = null;
+      Search.query(query);
+    }
+  },
+
+  hasIndex: () => Search._index !== null,
+
+  deferQuery: (query) => (Search._queued_query = query),
+
+  stopPulse: () => (Search._pulse_status = -1),
+
+  startPulse: () => {
+    if (Search._pulse_status >= 0) return;
+
+    const pulse = () => {
+      Search._pulse_status = (Search._pulse_status + 1) % 4;
+      Search.dots.innerText = ".".repeat(Search._pulse_status);
+      if (Search._pulse_status >= 0) window.setTimeout(pulse, 500);
+    };
+    pulse();
+  },
+
+  /**
+   * perform a search for something (or wait until index is loaded)
+   */
+  performSearch: (query) => {
+    // create the required interface elements
+    const searchText = document.createElement("h2");
+    searchText.textContent = _("Searching");
+    const searchSummary = document.createElement("p");
+    searchSummary.classList.add("search-summary");
+    searchSummary.innerText = "";
+    const searchList = document.createElement("ul");
+    searchList.classList.add("search");
+
+    const out = document.getElementById("search-results");
+    Search.title = out.appendChild(searchText);
+    Search.dots = Search.title.appendChild(document.createElement("span"));
+    Search.status = out.appendChild(searchSummary);
+    Search.output = out.appendChild(searchList);
+
+    const searchProgress = document.getElementById("search-progress");
+    // Some themes don't use the search progress node
+    if (searchProgress) {
+      searchProgress.innerText = _("Preparing search...");
+    }
+    Search.startPulse();
+
+    // index already loaded, the browser was quick!
+    if (Search.hasIndex()) Search.query(query);
+    else Search.deferQuery(query);
+  },
+
+  /**
+   * execute search (requires search index to be loaded)
+   */
+  query: (query) => {
+    const filenames = Search._index.filenames;
+    const docNames = Search._index.docnames;
+    const titles = Search._index.titles;
+    const allTitles = Search._index.alltitles;
+    const indexEntries = Search._index.indexentries;
+
+    // stem the search terms and add them to the correct list
+    const stemmer = new Stemmer();
+    const searchTerms = new Set();
+    const excludedTerms = new Set();
+    const highlightTerms = new Set();
+    const objectTerms = new Set(splitQuery(query.toLowerCase().trim()));
+    splitQuery(query.trim()).forEach((queryTerm) => {
+      const queryTermLower = queryTerm.toLowerCase();
+
+      // maybe skip this "word"
+      // stopwords array is from language_data.js
+      if (
+        stopwords.indexOf(queryTermLower) !== -1 ||
+        queryTerm.match(/^\d+$/)
+      )
+        return;
+
+      // stem the word
+      let word = stemmer.stemWord(queryTermLower);
+      // select the correct list
+      if (word[0] === "-") excludedTerms.add(word.substr(1));
+      else {
+        searchTerms.add(word);
+        highlightTerms.add(queryTermLower);
+      }
+    });
+
+    if (SPHINX_HIGHLIGHT_ENABLED) {  // set in sphinx_highlight.js
+      localStorage.setItem("sphinx_highlight_terms", [...highlightTerms].join(" "))
+    }
+
+    // console.debug("SEARCH: searching for:");
+    // console.info("required: ", [...searchTerms]);
+    // console.info("excluded: ", [...excludedTerms]);
+
+    // array of [docname, title, anchor, descr, score, filename]
+    let results = [];
+    _removeChildren(document.getElementById("search-progress"));
+
+    const queryLower = query.toLowerCase();
+    for (const [title, foundTitles] of Object.entries(allTitles)) {
+      if (title.toLowerCase().includes(queryLower) && (queryLower.length >= title.length/2)) {
+        for (const [file, id] of foundTitles) {
+          let score = Math.round(100 * queryLower.length / title.length)
+          results.push([
+            docNames[file],
+            titles[file] !== title ? `${titles[file]} > ${title}` : title,
+            id !== null ? "#" + id : "",
+            null,
+            score,
+            filenames[file],
+          ]);
+        }
+      }
+    }
+
+    // search for explicit entries in index directives
+    for (const [entry, foundEntries] of Object.entries(indexEntries)) {
+      if (entry.includes(queryLower) && (queryLower.length >= entry.length/2)) {
+        for (const [file, id] of foundEntries) {
+          let score = Math.round(100 * queryLower.length / entry.length)
+          results.push([
+            docNames[file],
+            titles[file],
+            id ? "#" + id : "",
+            null,
+            score,
+            filenames[file],
+          ]);
+        }
+      }
+    }
+
+    // lookup as object
+    objectTerms.forEach((term) =>
+      results.push(...Search.performObjectSearch(term, objectTerms))
+    );
+
+    // lookup as search terms in fulltext
+    results.push(...Search.performTermsSearch(searchTerms, excludedTerms));
+
+    // let the scorer override scores with a custom scoring function
+    if (Scorer.score) results.forEach((item) => (item[4] = Scorer.score(item)));
+
+    // now sort the results by score (in opposite order of appearance, since the
+    // display function below uses pop() to retrieve items) and then
+    // alphabetically
+    results.sort((a, b) => {
+      const leftScore = a[4];
+      const rightScore = b[4];
+      if (leftScore === rightScore) {
+        // same score: sort alphabetically
+        const leftTitle = a[1].toLowerCase();
+        const rightTitle = b[1].toLowerCase();
+        if (leftTitle === rightTitle) return 0;
+        return leftTitle > rightTitle ? -1 : 1; // inverted is intentional
+      }
+      return leftScore > rightScore ? 1 : -1;
+    });
+
+    // remove duplicate search results
+    // note the reversing of results, so that in the case of duplicates, the highest-scoring entry is kept
+    let seen = new Set();
+    results = results.reverse().reduce((acc, result) => {
+      let resultStr = result.slice(0, 4).concat([result[5]]).map(v => String(v)).join(',');
+      if (!seen.has(resultStr)) {
+        acc.push(result);
+        seen.add(resultStr);
+      }
+      return acc;
+    }, []);
+
+    results = results.reverse();
+
+    // for debugging
+    //Search.lastresults = results.slice();  // a copy
+    // console.info("search results:", Search.lastresults);
+
+    // print the results
+    _displayNextItem(results, results.length, searchTerms, highlightTerms);
+  },
+
+  /**
+   * search for object names
+   */
+  performObjectSearch: (object, objectTerms) => {
+    const filenames = Search._index.filenames;
+    const docNames = Search._index.docnames;
+    const objects = Search._index.objects;
+    const objNames = Search._index.objnames;
+    const titles = Search._index.titles;
+
+    const results = [];
+
+    const objectSearchCallback = (prefix, match) => {
+      const name = match[4]
+      const fullname = (prefix ? prefix + "." : "") + name;
+      const fullnameLower = fullname.toLowerCase();
+      if (fullnameLower.indexOf(object) < 0) return;
+
+      let score = 0;
+      const parts = fullnameLower.split(".");
+
+      // check for different match types: exact matches of full name or
+      // "last name" (i.e. last dotted part)
+      if (fullnameLower === object || parts.slice(-1)[0] === object)
+        score += Scorer.objNameMatch;
+      else if (parts.slice(-1)[0].indexOf(object) > -1)
+        score += Scorer.objPartialMatch; // matches in last name
+
+      const objName = objNames[match[1]][2];
+      const title = titles[match[0]];
+
+      // If more than one term searched for, we require other words to be
+      // found in the name/title/description
+      const otherTerms = new Set(objectTerms);
+      otherTerms.delete(object);
+      if (otherTerms.size > 0) {
+        const haystack = `${prefix} ${name} ${objName} ${title}`.toLowerCase();
+        if (
+          [...otherTerms].some((otherTerm) => haystack.indexOf(otherTerm) < 0)
+        )
+          return;
+      }
+
+      let anchor = match[3];
+      if (anchor === "") anchor = fullname;
+      else if (anchor === "-") anchor = objNames[match[1]][1] + "-" + fullname;
+
+      const descr = objName + _(", in ") + title;
+
+      // add custom score for some objects according to scorer
+      if (Scorer.objPrio.hasOwnProperty(match[2]))
+        score += Scorer.objPrio[match[2]];
+      else score += Scorer.objPrioDefault;
+
+      results.push([
+        docNames[match[0]],
+        fullname,
+        "#" + anchor,
+        descr,
+        score,
+        filenames[match[0]],
+      ]);
+    };
+    Object.keys(objects).forEach((prefix) =>
+      objects[prefix].forEach((array) =>
+        objectSearchCallback(prefix, array)
+      )
+    );
+    return results;
+  },
+
+  /**
+   * search for full-text terms in the index
+   */
+  performTermsSearch: (searchTerms, excludedTerms) => {
+    // prepare search
+    const terms = Search._index.terms;
+    const titleTerms = Search._index.titleterms;
+    const filenames = Search._index.filenames;
+    const docNames = Search._index.docnames;
+    const titles = Search._index.titles;
+
+    const scoreMap = new Map();
+    const fileMap = new Map();
+
+    // perform the search on the required terms
+    searchTerms.forEach((word) => {
+      const files = [];
+      const arr = [
+        { files: terms[word], score: Scorer.term },
+        { files: titleTerms[word], score: Scorer.title },
+      ];
+      // add support for partial matches
+      if (word.length > 2) {
+        const escapedWord = _escapeRegExp(word);
+        Object.keys(terms).forEach((term) => {
+          if (term.match(escapedWord) && !terms[word])
+            arr.push({ files: terms[term], score: Scorer.partialTerm });
+        });
+        Object.keys(titleTerms).forEach((term) => {
+          if (term.match(escapedWord) && !titleTerms[word])
+            arr.push({ files: titleTerms[word], score: Scorer.partialTitle });
+        });
+      }
+
+      // no match but word was a required one
+      if (arr.every((record) => record.files === undefined)) return;
+
+      // found search word in contents
+      arr.forEach((record) => {
+        if (record.files === undefined) return;
+
+        let recordFiles = record.files;
+        if (recordFiles.length === undefined) recordFiles = [recordFiles];
+        files.push(...recordFiles);
+
+        // set score for the word in each file
+        recordFiles.forEach((file) => {
+          if (!scoreMap.has(file)) scoreMap.set(file, {});
+          scoreMap.get(file)[word] = record.score;
+        });
+      });
+
+      // create the mapping
+      files.forEach((file) => {
+        if (fileMap.has(file) && fileMap.get(file).indexOf(word) === -1)
+          fileMap.get(file).push(word);
+        else fileMap.set(file, [word]);
+      });
+    });
+
+    // now check if the files don't contain excluded terms
+    const results = [];
+    for (const [file, wordList] of fileMap) {
+      // check if all requirements are matched
+
+      // as search terms with length < 3 are discarded
+      const filteredTermCount = [...searchTerms].filter(
+        (term) => term.length > 2
+      ).length;
+      if (
+        wordList.length !== searchTerms.size &&
+        wordList.length !== filteredTermCount
+      )
+        continue;
+
+      // ensure that none of the excluded terms is in the search result
+      if (
+        [...excludedTerms].some(
+          (term) =>
+            terms[term] === file ||
+            titleTerms[term] === file ||
+            (terms[term] || []).includes(file) ||
+            (titleTerms[term] || []).includes(file)
+        )
+      )
+        break;
+
+      // select one (max) score for the file.
+      const score = Math.max(...wordList.map((w) => scoreMap.get(file)[w]));
+      // add result to the result list
+      results.push([
+        docNames[file],
+        titles[file],
+        "",
+        null,
+        score,
+        filenames[file],
+      ]);
+    }
+    return results;
+  },
+
+  /**
+   * helper function to return a node containing the
+   * search summary for a given text. keywords is a list
+   * of stemmed words.
+   */
+  makeSearchSummary: (htmlText, keywords) => {
+    const text = Search.htmlToText(htmlText);
+    if (text === "") return null;
+
+    const textLower = text.toLowerCase();
+    const actualStartPosition = [...keywords]
+      .map((k) => textLower.indexOf(k.toLowerCase()))
+      .filter((i) => i > -1)
+      .slice(-1)[0];
+    const startWithContext = Math.max(actualStartPosition - 120, 0);
+
+    const top = startWithContext === 0 ? "" : "...";
+    const tail = startWithContext + 240 < text.length ? "..." : "";
+
+    let summary = document.createElement("p");
+    summary.classList.add("context");
+    summary.textContent = top + text.substr(startWithContext, 240).trim() + tail;
+
+    return summary;
+  },
+};
+
+_ready(Search.init);
diff --git a/_static/sidebar.js b/_static/sidebar.js
new file mode 100644
index 000000000..c5e2692c4
--- /dev/null
+++ b/_static/sidebar.js
@@ -0,0 +1,70 @@
+/*
+ * sidebar.js
+ * ~~~~~~~~~~
+ *
+ * This script makes the Sphinx sidebar collapsible.
+ *
+ * .sphinxsidebar contains .sphinxsidebarwrapper.  This script adds
+ * in .sphixsidebar, after .sphinxsidebarwrapper, the #sidebarbutton
+ * used to collapse and expand the sidebar.
+ *
+ * When the sidebar is collapsed the .sphinxsidebarwrapper is hidden
+ * and the width of the sidebar and the margin-left of the document
+ * are decreased. When the sidebar is expanded the opposite happens.
+ * This script saves a per-browser/per-session cookie used to
+ * remember the position of the sidebar among the pages.
+ * Once the browser is closed the cookie is deleted and the position
+ * reset to the default (expanded).
+ *
+ * :copyright: Copyright 2007-2023 by the Sphinx team, see AUTHORS.
+ * :license: BSD, see LICENSE for details.
+ *
+ */
+
+const initialiseSidebar = () => {
+  
+    
+  
+
+  // global elements used by the functions.
+  const bodyWrapper = document.getElementsByClassName("bodywrapper")[0]
+  const sidebar = document.getElementsByClassName("sphinxsidebar")[0]
+  const sidebarWrapper = document.getElementsByClassName('sphinxsidebarwrapper')[0]
+  const sidebarButton = document.getElementById("sidebarbutton")
+  const sidebarArrow = sidebarButton.querySelector('span')
+
+  // for some reason, the document has no sidebar; do not run into errors
+  if (typeof sidebar === "undefined") return;
+
+  const flipArrow = element => element.innerText = (element.innerText === "»") ? "«" : "»"
+
+  const collapse_sidebar = () => {
+    bodyWrapper.style.marginLeft = ".8em";
+    sidebar.style.width = ".8em"
+    sidebarWrapper.style.display = "none"
+    flipArrow(sidebarArrow)
+    sidebarButton.title = _('Expand sidebar')
+    window.localStorage.setItem("sidebar", "collapsed")
+  }
+
+  const expand_sidebar = () => {
+    bodyWrapper.style.marginLeft = ""
+    sidebar.style.removeProperty("width")
+    sidebarWrapper.style.display = ""
+    flipArrow(sidebarArrow)
+    sidebarButton.title = _('Collapse sidebar')
+    window.localStorage.setItem("sidebar", "expanded")
+  }
+
+  sidebarButton.addEventListener("click", () => {
+    (sidebarWrapper.style.display === "none") ? expand_sidebar() : collapse_sidebar()
+  })
+
+  if (!window.localStorage.getItem("sidebar")) return
+  const value = window.localStorage.getItem("sidebar")
+  if (value === "collapsed") collapse_sidebar();
+  else if (value === "expanded") expand_sidebar();
+}
+
+if (document.readyState !== "loading") initialiseSidebar()
+else document.addEventListener("DOMContentLoaded", initialiseSidebar)
\ No newline at end of file
diff --git a/_static/sphinx_highlight.js b/_static/sphinx_highlight.js
new file mode 100644
index 000000000..8a96c69a1
--- /dev/null
+++ b/_static/sphinx_highlight.js
@@ -0,0 +1,154 @@
+/* Highlighting utilities for Sphinx HTML documentation. */
+"use strict";
+
+const SPHINX_HIGHLIGHT_ENABLED = true
+
+/**
+ * highlight a given string on a node by wrapping it in
+ * span elements with the given class name.
+ */
+const _highlight = (node, addItems, text, className) => {
+  if (node.nodeType === Node.TEXT_NODE) {
+    const val = node.nodeValue;
+    const parent = node.parentNode;
+    const pos = val.toLowerCase().indexOf(text);
+    if (
+      pos >= 0 &&
+      !parent.classList.contains(className) &&
+      !parent.classList.contains("nohighlight")
+    ) {
+      let span;
+
+      const closestNode = parent.closest("body, svg, foreignObject");
+      const isInSVG = closestNode && closestNode.matches("svg");
+      if (isInSVG) {
+        span = document.createElementNS("http://www.w3.org/2000/svg", "tspan");
+      } else {
+        span = document.createElement("span");
+        span.classList.add(className);
+      }
+
+      span.appendChild(document.createTextNode(val.substr(pos, text.length)));
+      const rest = document.createTextNode(val.substr(pos + text.length));
+      parent.insertBefore(
+        span,
+        parent.insertBefore(
+          rest,
+          node.nextSibling
+        )
+      );
+      node.nodeValue = val.substr(0, pos);
+      /* There may be more occurrences of search term in this node. So call this
+       * function recursively on the remaining fragment.
+       */
+      _highlight(rest, addItems, text, className);
+
+      if (isInSVG) {
+        const rect = document.createElementNS(
+          "http://www.w3.org/2000/svg",
+          "rect"
+        );
+        const bbox = parent.getBBox();
+        rect.x.baseVal.value = bbox.x;
+        rect.y.baseVal.value = bbox.y;
+        rect.width.baseVal.value = bbox.width;
+        rect.height.baseVal.value = bbox.height;
+        rect.setAttribute("class", className);
+        addItems.push({ parent: parent, target: rect });
+      }
+    }
+  } else if (node.matches && !node.matches("button, select, textarea")) {
+    node.childNodes.forEach((el) => _highlight(el, addItems, text, className));
+  }
+};
+const _highlightText = (thisNode, text, className) => {
+  let addItems = [];
+  _highlight(thisNode, addItems, text, className);
+  addItems.forEach((obj) =>
+    obj.parent.insertAdjacentElement("beforebegin", obj.target)
+  );
+};
+
+/**
+ * Small JavaScript module for the documentation.
+ */
+const SphinxHighlight = {
+
+  /**
+   * highlight the search words provided in localstorage in the text
+   */
+  highlightSearchWords: () => {
+    if (!SPHINX_HIGHLIGHT_ENABLED) return;  // bail if no highlight
+
+    // get and clear terms from localstorage
+    const url = new URL(window.location);
+    const highlight =
+        localStorage.getItem("sphinx_highlight_terms")
+        || url.searchParams.get("highlight")
+        || "";
+    localStorage.removeItem("sphinx_highlight_terms")
+    url.searchParams.delete("highlight");
+    window.history.replaceState({}, "", url);
+
+    // get individual terms from highlight string
+    const terms = highlight.toLowerCase().split(/\s+/).filter(x => x);
+    if (terms.length === 0) return; // nothing to do
+
+    // There should never be more than one element matching "div.body"
+    const divBody = document.querySelectorAll("div.body");
+    const body = divBody.length ? divBody[0] : document.querySelector("body");
+    window.setTimeout(() => {
+      terms.forEach((term) => _highlightText(body, term, "highlighted"));
+    }, 10);
+
+    const searchBox = document.getElementById("searchbox");
+    if (searchBox === null) return;
+    searchBox.appendChild(
+      document
+        .createRange()
+        .createContextualFragment(
+          '<p class="highlight-link">' +
+            '<a href="javascript:SphinxHighlight.hideSearchWords()">' +
+            _("Hide Search Matches") +
+            "</a></p>"
+        )
+    );
+  },
+
+  /**
+   * helper function to hide the search marks again
+   */
+  hideSearchWords: () => {
+    document
+      .querySelectorAll("#searchbox .highlight-link")
+      .forEach((el) => el.remove());
+    document
+      .querySelectorAll("span.highlighted")
+      .forEach((el) => el.classList.remove("highlighted"));
+    localStorage.removeItem("sphinx_highlight_terms")
+  },
+
+  initEscapeListener: () => {
+    // only install a listener if it is really needed
+    if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) return;
+
+    document.addEventListener("keydown", (event) => {
+      // bail for input elements
+      if (BLACKLISTED_KEY_CONTROL_ELEMENTS.has(document.activeElement.tagName)) return;
+      // bail with special keys
+      if (event.shiftKey || event.altKey || event.ctrlKey || event.metaKey) return;
+      if (DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS && (event.key === "Escape")) {
+        SphinxHighlight.hideSearchWords();
+        event.preventDefault();
+      }
+    });
+  },
+};
+
+_ready(() => {
+  /* Do not call highlightSearchWords() when we are on the search page.
+   * It will highlight words from the *previous* search query.
+   */
+  if (typeof Search === "undefined") SphinxHighlight.highlightSearchWords();
+  SphinxHighlight.initEscapeListener();
+});
diff --git a/architecture.html b/architecture.html
new file mode 100644
index 000000000..0f13649ef
--- /dev/null
+++ b/architecture.html
@@ -0,0 +1,184 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>PyOP2 Architecture &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="PyOP2 Backends" href="backends.html" />
+    <link rel="prev" title="The PyOP2 Intermediate Representation" href="ir.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="backends.html" title="PyOP2 Backends"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="ir.html" title="The PyOP2 Intermediate Representation"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">PyOP2 Architecture</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="pyop2-architecture">
+<span id="architecture"></span><h1>PyOP2 Architecture<a class="headerlink" href="#pyop2-architecture" title="Link to this heading">¶</a></h1>
+<p>As described in <a class="reference internal" href="concepts.html#concepts"><span class="std std-ref">PyOP2 Concepts</span></a>, PyOP2 exposes an API that allows users to
+declare the topology of unstructured meshes in the form of <code class="xref py py-class docutils literal notranslate"><span class="pre">Sets</span></code> and <code class="xref py py-class docutils literal notranslate"><span class="pre">Maps</span></code> and data in the form of
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Dats</span></code>, <code class="xref py py-class docutils literal notranslate"><span class="pre">Mats</span></code>, <code class="xref py py-class docutils literal notranslate"><span class="pre">Globals</span></code> and <code class="xref py py-class docutils literal notranslate"><span class="pre">Consts</span></code>. Computations on this data
+are described by <code class="xref py py-class docutils literal notranslate"><span class="pre">Kernels</span></code> described in <a class="reference internal" href="kernels.html#kernels"><span class="std std-ref">PyOP2 Kernels</span></a>
+and executed by <code class="xref py py-func docutils literal notranslate"><span class="pre">parallel</span> <span class="pre">loops</span></code>.</p>
+<p>The API is the frontend to the PyOP2 runtime compilation architecture, which
+supports the generation and just-in-time (JIT) compilation of low-level code
+for a range of backends described in <a class="reference internal" href="backends.html"><span class="doc">PyOP2 Backends</span></a> and the efficient
+scheduling of parallel computations. A schematic overview of the PyOP2
+architecture is given below:</p>
+<figure class="align-center" id="id1">
+<img alt="_images/pyop2_architecture.svg" src="_images/pyop2_architecture.svg" /><figcaption>
+<p><span class="caption-text">Schematic overview of the PyOP2 architecture</span><a class="headerlink" href="#id1" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+<p>From an outside perspective, PyOP2 is a conventional Python library, with
+performance critical library functions implemented in <a class="reference external" href="http://cython.org">Cython</a>. A user’s
+application code makes calls to the PyOP2 API, most of which are conventional
+library calls.  The exception are <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> calls, which
+encapsulate PyOP2’s runtime core functionality performing backend-specific
+code generation.  Executing a parallel loop comprises the following steps:</p>
+<ol class="arabic simple">
+<li><p>Compute a parallel execution plan, including information for efficient
+staging of data and partitioning and colouring of the iteration set for
+conflict-free parallel execution.  This process is described in <a class="reference internal" href="plan.html"><span class="doc">Parallel Execution Plan</span></a>
+and does not apply to the sequential backend.</p></li>
+<li><p>Generate backend-specific code for executing the computation for a given
+set of <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> arguments as detailed in <a class="reference internal" href="backends.html"><span class="doc">PyOP2 Backends</span></a>
+according to the execution plan computed in the previous step.</p></li>
+<li><p>Pass the generated code to a backend-specific toolchain for just-in-time
+compilation, producing a shared library callable as a Python module which
+is dynamically loaded. This module is cached on disk to save recompilation
+when the same <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> is called again for the same backend.</p></li>
+<li><p>Build the backend-specific list of arguments to be passed to the generated
+code, which may initiate host to device data transfer for the CUDA and
+OpenCL backends.</p></li>
+<li><p>Call into the generated module to perform the actual computation. For
+distributed parallel computations this involves separate calls for the
+regions owned by the current processor and the halo as described in
+<a class="reference internal" href="mpi.html"><span class="doc">MPI</span></a>.</p></li>
+<li><p>Perform any necessary reductions for <code class="xref py py-class docutils literal notranslate"><span class="pre">Globals</span></code>.</p></li>
+<li><p>Call the backend-specific matrix assembly procedure on any
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code> arguments.</p></li>
+</ol>
+<section id="multiple-backend-support">
+<span id="backend-support"></span><h2>Multiple Backend Support<a class="headerlink" href="#multiple-backend-support" title="Link to this heading">¶</a></h2>
+<p>The backend is selected by passing the keyword argument <code class="docutils literal notranslate"><span class="pre">backend</span></code> to the
+<code class="xref py py-func docutils literal notranslate"><span class="pre">init()</span></code> function.  If omitted, the <code class="docutils literal notranslate"><span class="pre">sequential</span></code> backend is
+selected by default. This choice can be overridden by exporting the
+environment variable <code class="docutils literal notranslate"><span class="pre">PYOP2_BACKEND</span></code>, which allows switching backends
+without having to touch the code. Once chosen, the backend cannot be changed
+for the duration of the running Python interpreter session.</p>
+<p>PyOP2 provides a single API to the user, regardless of which backend the
+computations are running on. All classes and functions that form the public
+API defined in <code class="xref py py-mod docutils literal notranslate"><span class="pre">pyop2.op2</span></code> are interfaces, whose concrete implementations
+are initialised according to the chosen backend. A metaclass takes care of
+instantiating a backend-specific version of the requested class and setting
+the corresponding docstrings such that this process is entirely transparent to
+the user. The implementation of the PyOP2 backends is completely orthogonal to
+the backend selection process and free to use established practices of
+object-oriented design.</p>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">PyOP2 Architecture</a><ul>
+<li><a class="reference internal" href="#multiple-backend-support">Multiple Backend Support</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="ir.html"
+                          title="previous chapter">The PyOP2 Intermediate Representation</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="backends.html"
+                          title="next chapter">PyOP2 Backends</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/architecture.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="backends.html" title="PyOP2 Backends"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="ir.html" title="The PyOP2 Intermediate Representation"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">PyOP2 Architecture</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/backends.html b/backends.html
new file mode 100644
index 000000000..1733508ce
--- /dev/null
+++ b/backends.html
@@ -0,0 +1,560 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>PyOP2 Backends &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="PyOP2 Linear Algebra Interface" href="linear_algebra.html" />
+    <link rel="prev" title="PyOP2 Architecture" href="architecture.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="linear_algebra.html" title="PyOP2 Linear Algebra Interface"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="architecture.html" title="PyOP2 Architecture"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">PyOP2 Backends</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="pyop2-backends">
+<span id="backends"></span><h1>PyOP2 Backends<a class="headerlink" href="#pyop2-backends" title="Link to this heading">¶</a></h1>
+<p>PyOP2 provides a number of different backends to be able to run parallel
+computations on different hardware architectures. The currently supported
+backends are</p>
+<ul class="simple">
+<li><p><code class="docutils literal notranslate"><span class="pre">sequential</span></code>: runs sequentially on a single CPU core.</p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">openmp</span></code>: runs multiple threads on an SMP CPU using OpenMP. The number of
+threads is set with the environment variable <code class="docutils literal notranslate"><span class="pre">OMP_NUM_THREADS</span></code>.</p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">cuda</span></code>: offloads computation to a NVIDA GPU (requires <span class="xref std std-ref">CUDA and pycuda</span>)</p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">opencl</span></code>: offloads computation to an OpenCL device, either a multi-core
+CPU or a GPU (requires <span class="xref std std-ref">OpenCL and pyopencl</span>)</p></li>
+</ul>
+<p>Distributed parallel computations using MPI are supported by PyOP2 and
+described in detail in <a class="reference internal" href="mpi.html"><span class="doc">MPI</span></a>. Datastructures must be partitioned among
+MPI processes with overlapping regions, so called halos.  The host backends
+<code class="docutils literal notranslate"><span class="pre">sequential</span></code> and <code class="docutils literal notranslate"><span class="pre">openmp</span></code> have full MPI support, the device backends
+<code class="docutils literal notranslate"><span class="pre">cuda</span></code> and <code class="docutils literal notranslate"><span class="pre">opencl</span></code> only support parallel loops on <code class="xref py py-class docutils literal notranslate"><span class="pre">Dats</span></code>. Hybrid parallel computations with OpenMP are possible, where
+<code class="docutils literal notranslate"><span class="pre">OMP_NUM_THREADS</span></code> threads are launched per MPI rank.</p>
+<section id="host-backends">
+<span id="id1"></span><h2>Host backends<a class="headerlink" href="#host-backends" title="Link to this heading">¶</a></h2>
+<p>Any computation in PyOP2 requires the generation of code at runtime specific
+to each individual <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>. The host backends generate code
+which is just-in-time (JIT) compiled into a shared library callable
+via <code class="xref py py-mod docutils literal notranslate"><span class="pre">ctypes</span></code>.  The compilation procedure also takes care of
+caching the compiled library on disk, such that the compilation cost
+is not paid every time.</p>
+<section id="sequential-backend">
+<span id="id2"></span><h3>Sequential backend<a class="headerlink" href="#sequential-backend" title="Link to this heading">¶</a></h3>
+<p>Since there is no parallel computation for the sequential backend, the
+generated code is a C wrapper function with a <code class="docutils literal notranslate"><span class="pre">for</span></code> loop calling the kernel
+for the respective <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>.  This wrapper also takes care of
+staging in and out the data as requested by the access descriptors requested
+in the parallel loop.  Both the kernel and the wrapper function are
+just-in-time compiled in a single compilation unit such that the kernel call
+can be inlined and does not incur any function call overhead.</p>
+<p>Recall the <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> calling the <code class="docutils literal notranslate"><span class="pre">midpoint</span></code> kernel from
+<a class="reference internal" href="kernels.html"><span class="doc">PyOP2 Kernels</span></a>:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">op2</span><span class="o">.</span><span class="n">par_loop</span><span class="p">(</span><span class="n">midpoint</span><span class="p">,</span> <span class="n">cells</span><span class="p">,</span>
+             <span class="n">midpoints</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">WRITE</span><span class="p">),</span>
+             <span class="n">coordinates</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">READ</span><span class="p">,</span> <span class="n">cell2vertex</span><span class="p">))</span>
+</pre></div>
+</div>
+<p>The JIT compiled code for this loop is the kernel followed by the generated
+wrapper code:</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="linenos"> 1</span><span class="kr">inline</span><span class="w"> </span><span class="kt">void</span><span class="w"> </span><span class="nf">midpoint</span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="n">p</span><span class="p">[</span><span class="mi">2</span><span class="p">],</span><span class="w"> </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">coords</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span><span class="w"> </span><span class="p">{</span>
+<span class="linenos"> 2</span><span class="w">  </span><span class="n">p</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="n">coords</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="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">coords</span><span class="p">[</span><span class="mi">1</span><span class="p">][</span><span class="mi">0</span><span class="p">]</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">coords</span><span class="p">[</span><span class="mi">2</span><span class="p">][</span><span class="mi">0</span><span class="p">])</span><span class="w"> </span><span class="o">/</span><span class="w"> </span><span class="mf">3.0</span><span class="p">;</span>
+<span class="linenos"> 3</span><span class="w">  </span><span class="n">p</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="n">coords</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">coords</span><span class="p">[</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">coords</span><span class="p">[</span><span class="mi">2</span><span class="p">][</span><span class="mi">1</span><span class="p">])</span><span class="w"> </span><span class="o">/</span><span class="w"> </span><span class="mf">3.0</span><span class="p">;</span>
+<span class="linenos"> 4</span><span class="p">}</span>
+<span class="linenos"> 5</span>
+<span class="linenos"> 6</span><span class="kt">void</span><span class="w"> </span><span class="nf">wrap_midpoint__</span><span class="p">(</span><span class="n">PyObject</span><span class="w"> </span><span class="o">*</span><span class="n">_start</span><span class="p">,</span><span class="w"> </span><span class="n">PyObject</span><span class="w"> </span><span class="o">*</span><span class="n">_end</span><span class="p">,</span>
+<span class="linenos"> 7</span><span class="w">                     </span><span class="n">PyObject</span><span class="w"> </span><span class="o">*</span><span class="n">_arg0_0</span><span class="p">,</span>
+<span class="linenos"> 8</span><span class="w">                     </span><span class="n">PyObject</span><span class="w"> </span><span class="o">*</span><span class="n">_arg1_0</span><span class="p">,</span><span class="w"> </span><span class="n">PyObject</span><span class="w"> </span><span class="o">*</span><span class="n">_arg1_0_map0_0</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="linenos"> 9</span><span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">start</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="p">)</span><span class="n">PyInt_AsLong</span><span class="p">(</span><span class="n">_start</span><span class="p">);</span>
+<span class="linenos">10</span><span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">end</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="p">)</span><span class="n">PyInt_AsLong</span><span class="p">(</span><span class="n">_end</span><span class="p">);</span>
+<span class="linenos">11</span><span class="w">  </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">arg0_0</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="p">)(((</span><span class="n">PyArrayObject</span><span class="w"> </span><span class="o">*</span><span class="p">)</span><span class="n">_arg0_0</span><span class="p">)</span><span class="o">-&gt;</span><span class="n">data</span><span class="p">);</span>
+<span class="linenos">12</span><span class="w">  </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">arg1_0</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="p">)(((</span><span class="n">PyArrayObject</span><span class="w"> </span><span class="o">*</span><span class="p">)</span><span class="n">_arg1_0</span><span class="p">)</span><span class="o">-&gt;</span><span class="n">data</span><span class="p">);</span>
+<span class="linenos">13</span><span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">arg1_0_map0_0</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="p">)(((</span><span class="n">PyArrayObject</span><span class="w"> </span><span class="o">*</span><span class="p">)</span><span class="n">_arg1_0_map0_0</span><span class="p">)</span><span class="o">-&gt;</span><span class="n">data</span><span class="p">);</span>
+<span class="linenos">14</span><span class="w">  </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">arg1_0_vec</span><span class="p">[</span><span class="mi">3</span><span class="p">];</span>
+<span class="linenos">15</span><span class="w">  </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">n</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">start</span><span class="p">;</span><span class="w"> </span><span class="n">n</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="n">end</span><span class="p">;</span><span class="w"> </span><span class="n">n</span><span class="o">++</span><span class="w"> </span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="linenos">16</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">n</span><span class="p">;</span>
+<span class="linenos">17</span><span class="w">    </span><span class="n">arg1_0_vec</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">arg1_0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">arg1_0_map0_0</span><span class="p">[</span><span class="n">i</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">3</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="mi">0</span><span class="p">]</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">;</span>
+<span class="linenos">18</span><span class="w">    </span><span class="n">arg1_0_vec</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">arg1_0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">arg1_0_map0_0</span><span class="p">[</span><span class="n">i</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">3</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">;</span>
+<span class="linenos">19</span><span class="w">    </span><span class="n">arg1_0_vec</span><span class="p">[</span><span class="mi">2</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">arg1_0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">arg1_0_map0_0</span><span class="p">[</span><span class="n">i</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">3</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="mi">2</span><span class="p">]</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">;</span>
+<span class="linenos">20</span><span class="w">    </span><span class="n">midpoint</span><span class="p">(</span><span class="n">arg0_0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">,</span><span class="w"> </span><span class="n">arg1_0_vec</span><span class="p">);</span>
+<span class="linenos">21</span><span class="w">  </span><span class="p">}</span>
+<span class="linenos">22</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>Note that the wrapper function is called directly from Python and therefore
+all arguments are plain Python objects, which first need to be unwrapped. The
+arguments <code class="docutils literal notranslate"><span class="pre">_start</span></code> and <code class="docutils literal notranslate"><span class="pre">_end</span></code> define the iteration set indices to iterate
+over. The remaining arguments are <code class="xref py py-class docutils literal notranslate"><span class="pre">arrays</span></code>
+corresponding to a <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> or <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> passed to the
+<code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>. Arguments are consecutively numbered to avoid name
+clashes.</p>
+<p>The first <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> argument <code class="docutils literal notranslate"><span class="pre">midpoints</span></code> is direct and
+therefore no corresponding <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> is passed to the wrapper
+function and the data pointer is passed straight to the kernel with an
+appropriate offset. The second argument <code class="docutils literal notranslate"><span class="pre">coordinates</span></code> is indirect and hence
+a <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>-<code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> pair is passed. Pointers to the data
+are gathered via the <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> of arity 3 and staged in the array
+<code class="docutils literal notranslate"><span class="pre">arg1_0_vec</span></code>, which is passed to the kernel. The coordinate data can
+therefore be accessed in the kernel via double indirection with the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> already applied. Note that for both arguments, the
+pointers are to two consecutive double values, since the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code> is of dimension two in either case.</p>
+</section>
+<section id="openmp-backend">
+<span id="id3"></span><h3>OpenMP backend<a class="headerlink" href="#openmp-backend" title="Link to this heading">¶</a></h3>
+<p>In contrast to the sequential backend, the outermost <code class="docutils literal notranslate"><span class="pre">for</span></code> loop in the
+OpenMP backend is annotated with OpenMP pragmas to execute in parallel with
+multiple threads. To avoid race conditions on data access, the iteration set
+is coloured and a thread safe execution plan is computed as described in
+<a class="reference internal" href="plan.html#plan-colouring"><span class="std std-ref">Colouring</span></a>.</p>
+<p>The JIT compiled code for the parallel loop from above changes as follows:</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="linenos"> 1</span><span class="kt">void</span><span class="w"> </span><span class="nf">wrap_midpoint__</span><span class="p">(</span><span class="n">PyObject</span><span class="o">*</span><span class="w"> </span><span class="n">_boffset</span><span class="p">,</span>
+<span class="linenos"> 2</span><span class="w">                     </span><span class="n">PyObject</span><span class="o">*</span><span class="w"> </span><span class="n">_nblocks</span><span class="p">,</span>
+<span class="linenos"> 3</span><span class="w">                     </span><span class="n">PyObject</span><span class="o">*</span><span class="w"> </span><span class="n">_blkmap</span><span class="p">,</span>
+<span class="linenos"> 4</span><span class="w">                     </span><span class="n">PyObject</span><span class="o">*</span><span class="w"> </span><span class="n">_offset</span><span class="p">,</span>
+<span class="linenos"> 5</span><span class="w">                     </span><span class="n">PyObject</span><span class="o">*</span><span class="w"> </span><span class="n">_nelems</span><span class="p">,</span>
+<span class="linenos"> 6</span><span class="w">                     </span><span class="n">PyObject</span><span class="w"> </span><span class="o">*</span><span class="n">_arg0_0</span><span class="p">,</span>
+<span class="linenos"> 7</span><span class="w">                     </span><span class="n">PyObject</span><span class="w"> </span><span class="o">*</span><span class="n">_arg1_0</span><span class="p">,</span><span class="w"> </span><span class="n">PyObject</span><span class="w"> </span><span class="o">*</span><span class="n">_arg1_0_map0_0</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="linenos"> 8</span><span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">boffset</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="p">)</span><span class="n">PyInt_AsLong</span><span class="p">(</span><span class="n">_boffset</span><span class="p">);</span>
+<span class="linenos"> 9</span><span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">nblocks</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="p">)</span><span class="n">PyInt_AsLong</span><span class="p">(</span><span class="n">_nblocks</span><span class="p">);</span>
+<span class="linenos">10</span><span class="w">  </span><span class="kt">int</span><span class="o">*</span><span class="w"> </span><span class="n">blkmap</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="p">)(((</span><span class="n">PyArrayObject</span><span class="w"> </span><span class="o">*</span><span class="p">)</span><span class="n">_blkmap</span><span class="p">)</span><span class="o">-&gt;</span><span class="n">data</span><span class="p">);</span>
+<span class="linenos">11</span><span class="w">  </span><span class="kt">int</span><span class="o">*</span><span class="w"> </span><span class="n">offset</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="p">)(((</span><span class="n">PyArrayObject</span><span class="w"> </span><span class="o">*</span><span class="p">)</span><span class="n">_offset</span><span class="p">)</span><span class="o">-&gt;</span><span class="n">data</span><span class="p">);</span>
+<span class="linenos">12</span><span class="w">  </span><span class="kt">int</span><span class="o">*</span><span class="w"> </span><span class="n">nelems</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="p">)(((</span><span class="n">PyArrayObject</span><span class="w"> </span><span class="o">*</span><span class="p">)</span><span class="n">_nelems</span><span class="p">)</span><span class="o">-&gt;</span><span class="n">data</span><span class="p">);</span>
+<span class="linenos">13</span><span class="w">  </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">arg0_0</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="p">)(((</span><span class="n">PyArrayObject</span><span class="w"> </span><span class="o">*</span><span class="p">)</span><span class="n">_arg0_0</span><span class="p">)</span><span class="o">-&gt;</span><span class="n">data</span><span class="p">);</span>
+<span class="linenos">14</span><span class="w">  </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">arg1_0</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="p">)(((</span><span class="n">PyArrayObject</span><span class="w"> </span><span class="o">*</span><span class="p">)</span><span class="n">_arg1_0</span><span class="p">)</span><span class="o">-&gt;</span><span class="n">data</span><span class="p">);</span>
+<span class="linenos">15</span><span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">arg1_0_map0_0</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="p">)(((</span><span class="n">PyArrayObject</span><span class="w"> </span><span class="o">*</span><span class="p">)</span><span class="n">_arg1_0_map0_0</span><span class="p">)</span><span class="o">-&gt;</span><span class="n">data</span><span class="p">);</span>
+<span class="linenos">16</span><span class="w">  </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">arg1_0_vec</span><span class="p">[</span><span class="mi">32</span><span class="p">][</span><span class="mi">3</span><span class="p">];</span>
+<span class="linenos">17</span><span class="w">  </span><span class="cp">#ifdef _OPENMP</span>
+<span class="linenos">18</span><span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">nthread</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">omp_get_max_threads</span><span class="p">();</span>
+<span class="linenos">19</span><span class="w">  </span><span class="cp">#else</span>
+<span class="linenos">20</span><span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">nthread</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">1</span><span class="p">;</span>
+<span class="linenos">21</span><span class="w">  </span><span class="cp">#endif</span>
+<span class="linenos">22</span><span class="w">  </span><span class="cp">#pragma omp parallel shared(boffset, nblocks, nelems, blkmap)</span>
+<span class="linenos">23</span><span class="w">  </span><span class="p">{</span>
+<span class="linenos">24</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="n">tid</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">omp_get_thread_num</span><span class="p">();</span>
+<span class="linenos">25</span><span class="w">    </span><span class="cp">#pragma omp for schedule(static)</span>
+<span class="linenos">26</span><span class="w">    </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">__b</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">boffset</span><span class="p">;</span><span class="w"> </span><span class="n">__b</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="n">boffset</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">nblocks</span><span class="p">;</span><span class="w"> </span><span class="n">__b</span><span class="o">++</span><span class="p">)</span>
+<span class="linenos">27</span><span class="w">    </span><span class="p">{</span>
+<span class="linenos">28</span><span class="w">      </span><span class="kt">int</span><span class="w"> </span><span class="n">bid</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">blkmap</span><span class="p">[</span><span class="n">__b</span><span class="p">];</span>
+<span class="linenos">29</span><span class="w">      </span><span class="kt">int</span><span class="w"> </span><span class="n">nelem</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">nelems</span><span class="p">[</span><span class="n">bid</span><span class="p">];</span>
+<span class="linenos">30</span><span class="w">      </span><span class="kt">int</span><span class="w"> </span><span class="n">efirst</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">offset</span><span class="p">[</span><span class="n">bid</span><span class="p">];</span>
+<span class="linenos">31</span><span class="w">      </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">n</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">efirst</span><span class="p">;</span><span class="w"> </span><span class="n">n</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="n">efirst</span><span class="o">+</span><span class="w"> </span><span class="n">nelem</span><span class="p">;</span><span class="w"> </span><span class="n">n</span><span class="o">++</span><span class="w"> </span><span class="p">)</span>
+<span class="linenos">32</span><span class="w">      </span><span class="p">{</span>
+<span class="linenos">33</span><span class="w">        </span><span class="kt">int</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">n</span><span class="p">;</span>
+<span class="linenos">34</span><span class="w">        </span><span class="n">arg1_0_vec</span><span class="p">[</span><span class="n">tid</span><span class="p">][</span><span class="mi">0</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">arg1_0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">arg1_0_map0_0</span><span class="p">[</span><span class="n">i</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">3</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="mi">0</span><span class="p">]</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">;</span>
+<span class="linenos">35</span><span class="w">        </span><span class="n">arg1_0_vec</span><span class="p">[</span><span class="n">tid</span><span class="p">][</span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">arg1_0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">arg1_0_map0_0</span><span class="p">[</span><span class="n">i</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">3</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">;</span>
+<span class="linenos">36</span><span class="w">        </span><span class="n">arg1_0_vec</span><span class="p">[</span><span class="n">tid</span><span class="p">][</span><span class="mi">2</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">arg1_0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">arg1_0_map0_0</span><span class="p">[</span><span class="n">i</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">3</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="mi">2</span><span class="p">]</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">;</span>
+<span class="linenos">37</span><span class="w">        </span><span class="n">midpoint</span><span class="p">(</span><span class="n">arg0_0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">,</span><span class="w"> </span><span class="n">arg1_0_vec</span><span class="p">[</span><span class="n">tid</span><span class="p">]);</span>
+<span class="linenos">38</span><span class="w">      </span><span class="p">}</span>
+<span class="linenos">39</span><span class="w">    </span><span class="p">}</span>
+<span class="linenos">40</span><span class="w">  </span><span class="p">}</span>
+<span class="linenos">41</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>Computation is split into <code class="docutils literal notranslate"><span class="pre">nblocks</span></code> blocks which start at an initial offset
+<code class="docutils literal notranslate"><span class="pre">boffset</span></code> and correspond to colours that can be executed conflict free in
+parallel. This loop over colours is therefore wrapped in an OpenMP parallel
+region and is annotated with an <code class="docutils literal notranslate"><span class="pre">omp</span> <span class="pre">for</span></code> pragma. The block id <code class="docutils literal notranslate"><span class="pre">bid</span></code> for
+each of these blocks is given by the block map <code class="docutils literal notranslate"><span class="pre">blkmap</span></code> and is the index
+into the arrays <code class="docutils literal notranslate"><span class="pre">nelems</span></code> and <code class="docutils literal notranslate"><span class="pre">offset</span></code> provided as part of the execution
+plan. These are the number of elements that are part of the given block and
+its starting index. Note that each thread needs its own staging array
+<code class="docutils literal notranslate"><span class="pre">arg1_0_vec</span></code>, which is therefore scoped by the thread id.</p>
+</section>
+</section>
+<section id="device-backends">
+<span id="id4"></span><h2>Device backends<a class="headerlink" href="#device-backends" title="Link to this heading">¶</a></h2>
+<p>As with the host backends, the device backends have most of the implementation
+in common. The PyOP2 data carriers <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>, <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code>
+and <code class="xref py py-class docutils literal notranslate"><span class="pre">Const</span></code> have a data array in host memory and a separate
+array in device memory. Flags indicate the present state of a given data
+carrier:</p>
+<ul class="simple">
+<li><p><code class="docutils literal notranslate"><span class="pre">DEVICE_UNALLOCATED</span></code>: no data is allocated on the device</p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">HOST_UNALLOCATED</span></code>: no data is allocated on the host</p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">DEVICE</span></code>: data is up-to-date (valid) on the device, but invalid on the
+host</p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">HOST</span></code>: data is up-to-date (valid) on the host, but invalid on the device</p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">BOTH</span></code>: data is up-to-date (valid) on both the host and device</p></li>
+</ul>
+<p>When a <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> is called, PyOP2 uses the
+<a class="reference internal" href="concepts.html#access-descriptors"><span class="std std-ref">Access descriptors</span></a> to determine which data needs to be allocated or
+transferred from host to device prior to launching the kernel. Data is only
+transferred if it is out of date at the target location and all data transfer
+is triggered lazily i.e. the actual copy only occurs once the data is
+requested. In particular there is no automatic transfer back of data from
+device to host unless it is accessed on the host.</p>
+<p>A newly created device <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> has no associated device data and
+starts out in the state <code class="docutils literal notranslate"><span class="pre">DEVICE_UNALLOCATED</span></code>. The diagram below shows all
+actions that involve a state transition, which can be divided into three
+groups: calling explicit data transfer functions (red), access data on the
+host (black) and using the <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> in a <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>
+(blue). There is no need for users to explicitly initiate data transfers and
+the tranfer functions are only given for completeness.</p>
+<figure class="align-center" id="id7">
+<img alt="_images/pyop2_device_data_state.svg" src="_images/pyop2_device_data_state.svg" /><figcaption>
+<p><span class="caption-text">State transitions of a data carrier on PyOP2 device backends</span><a class="headerlink" href="#id7" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+<p>When a device <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> is used in a <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> for the
+first time, data is allocated on the device. If the <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> is
+only read, the host array is transferred to device if it was in state <code class="docutils literal notranslate"><span class="pre">HOST</span></code>
+or <code class="docutils literal notranslate"><span class="pre">DEVICE_UNALLOCATED</span></code> before the <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> and the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> is in the state <code class="docutils literal notranslate"><span class="pre">BOTH</span></code> afterwards, unless it was in
+state <code class="docutils literal notranslate"><span class="pre">DEVICE</span></code> in which case it remains in that state. If the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> is written to, data transfer before the
+<code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> is necessary unless the access descriptor is
+<code class="xref py py-data docutils literal notranslate"><span class="pre">WRITE</span></code> and the host data is out of date afterwards and the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> is in the state <code class="docutils literal notranslate"><span class="pre">DEVICE</span></code>. An overview of the state
+transitions and necessary memory allocations and data transfers for the two
+cases is given in the table below:</p>
+<table class="docutils align-default">
+<thead>
+<tr class="row-odd"><th class="head"><p>Initial state</p></th>
+<th class="head"><p><code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> read</p></th>
+<th class="head"><p><code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> written to</p></th>
+</tr>
+</thead>
+<tbody>
+<tr class="row-even"><td><p><code class="docutils literal notranslate"><span class="pre">DEVICE_UNALLOCATED</span></code></p></td>
+<td><p><code class="docutils literal notranslate"><span class="pre">BOTH</span></code> (alloc, transfer h2d)</p></td>
+<td><p><code class="docutils literal notranslate"><span class="pre">DEVICE</span></code> (alloc, transfer h2d unless write-only)</p></td>
+</tr>
+<tr class="row-odd"><td><p><code class="docutils literal notranslate"><span class="pre">DEVICE</span></code></p></td>
+<td><p><code class="docutils literal notranslate"><span class="pre">DEVICE</span></code></p></td>
+<td><p><code class="docutils literal notranslate"><span class="pre">DEVICE</span></code></p></td>
+</tr>
+<tr class="row-even"><td><p><code class="docutils literal notranslate"><span class="pre">HOST</span></code></p></td>
+<td><p><code class="docutils literal notranslate"><span class="pre">BOTH</span></code> (transfer h2d)</p></td>
+<td><p><code class="docutils literal notranslate"><span class="pre">DEVICE</span></code> (transfer h2d unless write-only)</p></td>
+</tr>
+<tr class="row-odd"><td><p><code class="docutils literal notranslate"><span class="pre">BOTH</span></code></p></td>
+<td><p><code class="docutils literal notranslate"><span class="pre">BOTH</span></code></p></td>
+<td><p><code class="docutils literal notranslate"><span class="pre">DEVICE</span></code></p></td>
+</tr>
+</tbody>
+</table>
+<p>Accessing data on the host initiates a device to host data transfer if the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> is in state <code class="docutils literal notranslate"><span class="pre">DEVICE</span></code> and leaves it in state <code class="docutils literal notranslate"><span class="pre">HOST</span></code>
+when using the <code class="xref py py-meth docutils literal notranslate"><span class="pre">data()</span></code> property and <code class="docutils literal notranslate"><span class="pre">BOTH</span></code> when using
+<code class="xref py py-meth docutils literal notranslate"><span class="pre">data_ro()</span></code>.</p>
+<p>The state transitions described above apply in the same way to a
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code>. A <code class="xref py py-class docutils literal notranslate"><span class="pre">Const</span></code> is read-only, never modified
+on device and therefore never out of date on the host. Hence there is no
+state <code class="docutils literal notranslate"><span class="pre">DEVICE</span></code> and it is not necessary to copy back <code class="xref py py-class docutils literal notranslate"><span class="pre">Const</span></code>
+data from device to host.</p>
+<section id="cuda-backend">
+<span id="id5"></span><h3>CUDA backend<a class="headerlink" href="#cuda-backend" title="Link to this heading">¶</a></h3>
+<p>The CUDA backend makes extensive use of <a class="reference external" href="http://mathema.tician.de/software/pycuda/">PyCUDA</a> and its infrastructure for
+just-in-time compilation of CUDA kernels and interfacing them to Python.
+Linear solvers and sparse matrix data structures are implemented on top of the
+<a class="reference external" href="http://cusplibrary.github.io">CUSP library</a> and are described in greater detail in <a class="reference internal" href="linear_algebra.html"><span class="doc">PyOP2 Linear Algebra Interface</span></a>.
+Code generation uses a template based approach, where a <code class="docutils literal notranslate"><span class="pre">__global__</span></code> stub
+routine to be called from the host is generated, which takes care of data
+marshalling and calling the user kernel as an inline <code class="docutils literal notranslate"><span class="pre">__device__</span></code> function.</p>
+<p>We consider the same <code class="docutils literal notranslate"><span class="pre">midpoint</span></code> kernel as in the previous examples, which
+requires no CUDA-specific modifications and is automatically annotated with a
+<code class="docutils literal notranslate"><span class="pre">__device__</span></code> qualifier. <a class="reference external" href="http://mathema.tician.de/software/pycuda/">PyCUDA</a> automatically generates a host stub for the
+generated kernel stub <code class="docutils literal notranslate"><span class="pre">__midpoint_stub</span></code> given a list of parameter types. It
+takes care of translating Python objects to plain C data types and pointers,
+such that a CUDA kernel can be launched straight from Python. The entire CUDA
+code PyOP2 generates is as follows:</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="linenos"> 1</span><span class="n">__device__</span><span class="w"> </span><span class="kt">void</span><span class="w"> </span><span class="n">midpoint</span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="n">p</span><span class="p">[</span><span class="mi">2</span><span class="p">],</span><span class="w"> </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">coords</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span>
+<span class="linenos"> 2</span><span class="p">{</span>
+<span class="linenos"> 3</span><span class="w">  </span><span class="n">p</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">((</span><span class="n">coords</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="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">coords</span><span class="p">[</span><span class="mi">1</span><span class="p">][</span><span class="mi">0</span><span class="p">])</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">coords</span><span class="p">[</span><span class="mi">2</span><span class="p">][</span><span class="mi">0</span><span class="p">])</span><span class="w"> </span><span class="o">/</span><span class="w"> </span><span class="mf">3.0</span><span class="p">;</span>
+<span class="linenos"> 4</span><span class="w">  </span><span class="n">p</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">((</span><span class="n">coords</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">coords</span><span class="p">[</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">])</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">coords</span><span class="p">[</span><span class="mi">2</span><span class="p">][</span><span class="mi">1</span><span class="p">])</span><span class="w"> </span><span class="o">/</span><span class="w"> </span><span class="mf">3.0</span><span class="p">;</span>
+<span class="linenos"> 5</span><span class="p">}</span>
+<span class="linenos"> 6</span>
+<span class="linenos"> 7</span><span class="n">__global__</span><span class="w"> </span><span class="kt">void</span><span class="w"> </span><span class="n">__midpoint_stub</span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">set_size</span><span class="p">,</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">set_offset</span><span class="p">,</span>
+<span class="linenos"> 8</span><span class="w">    </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">arg0</span><span class="p">,</span>
+<span class="linenos"> 9</span><span class="w">    </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">ind_arg1</span><span class="p">,</span>
+<span class="linenos">10</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">ind_map</span><span class="p">,</span>
+<span class="linenos">11</span><span class="w">    </span><span class="kt">short</span><span class="w"> </span><span class="o">*</span><span class="n">loc_map</span><span class="p">,</span>
+<span class="linenos">12</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">ind_sizes</span><span class="p">,</span>
+<span class="linenos">13</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">ind_offs</span><span class="p">,</span>
+<span class="linenos">14</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="n">block_offset</span><span class="p">,</span>
+<span class="linenos">15</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">blkmap</span><span class="p">,</span>
+<span class="linenos">16</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">offset</span><span class="p">,</span>
+<span class="linenos">17</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">nelems</span><span class="p">,</span>
+<span class="linenos">18</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">nthrcol</span><span class="p">,</span>
+<span class="linenos">19</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">thrcol</span><span class="p">,</span>
+<span class="linenos">20</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="n">nblocks</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="linenos">21</span><span class="w">  </span><span class="k">extern</span><span class="w"> </span><span class="n">__shared__</span><span class="w"> </span><span class="kt">char</span><span class="w"> </span><span class="n">shared</span><span class="p">[];</span>
+<span class="linenos">22</span><span class="w">  </span><span class="n">__shared__</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">ind_arg1_map</span><span class="p">;</span>
+<span class="linenos">23</span><span class="w">  </span><span class="n">__shared__</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">ind_arg1_size</span><span class="p">;</span>
+<span class="linenos">24</span><span class="w">  </span><span class="n">__shared__</span><span class="w"> </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">ind_arg1_shared</span><span class="p">;</span>
+<span class="linenos">25</span><span class="w">  </span><span class="n">__shared__</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">nelem</span><span class="p">,</span><span class="w"> </span><span class="n">offset_b</span><span class="p">,</span><span class="w"> </span><span class="n">offset_b_abs</span><span class="p">;</span>
+<span class="linenos">26</span>
+<span class="linenos">27</span><span class="w">  </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">ind_arg1_vec</span><span class="p">[</span><span class="mi">3</span><span class="p">];</span>
+<span class="linenos">28</span>
+<span class="linenos">29</span><span class="w">  </span><span class="k">if</span><span class="w"> </span><span class="p">(</span><span class="n">blockIdx</span><span class="p">.</span><span class="n">x</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">blockIdx</span><span class="p">.</span><span class="n">y</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">gridDim</span><span class="p">.</span><span class="n">x</span><span class="w"> </span><span class="o">&gt;=</span><span class="w"> </span><span class="n">nblocks</span><span class="p">)</span><span class="w"> </span><span class="k">return</span><span class="p">;</span>
+<span class="linenos">30</span><span class="w">  </span><span class="k">if</span><span class="w"> </span><span class="p">(</span><span class="n">threadIdx</span><span class="p">.</span><span class="n">x</span><span class="w"> </span><span class="o">==</span><span class="w"> </span><span class="mi">0</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="linenos">31</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="n">blockId</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">blkmap</span><span class="p">[</span><span class="n">blockIdx</span><span class="p">.</span><span class="n">x</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">blockIdx</span><span class="p">.</span><span class="n">y</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">gridDim</span><span class="p">.</span><span class="n">x</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">block_offset</span><span class="p">];</span>
+<span class="linenos">32</span><span class="w">    </span><span class="n">nelem</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">nelems</span><span class="p">[</span><span class="n">blockId</span><span class="p">];</span>
+<span class="linenos">33</span><span class="w">    </span><span class="n">offset_b_abs</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">offset</span><span class="p">[</span><span class="n">blockId</span><span class="p">];</span>
+<span class="linenos">34</span><span class="w">    </span><span class="n">offset_b</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">offset_b_abs</span><span class="w"> </span><span class="o">-</span><span class="w"> </span><span class="n">set_offset</span><span class="p">;</span>
+<span class="linenos">35</span>
+<span class="linenos">36</span><span class="w">    </span><span class="n">ind_arg1_size</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">ind_sizes</span><span class="p">[</span><span class="mi">0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">blockId</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">1</span><span class="p">];</span>
+<span class="linenos">37</span><span class="w">    </span><span class="n">ind_arg1_map</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="o">&amp;</span><span class="n">ind_map</span><span class="p">[</span><span class="mi">0</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">set_size</span><span class="p">]</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">ind_offs</span><span class="p">[</span><span class="mi">0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">blockId</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">1</span><span class="p">];</span>
+<span class="linenos">38</span>
+<span class="linenos">39</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="n">nbytes</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span>
+<span class="linenos">40</span><span class="w">    </span><span class="n">ind_arg1_shared</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="p">)</span><span class="w"> </span><span class="o">&amp;</span><span class="n">shared</span><span class="p">[</span><span class="n">nbytes</span><span class="p">];</span>
+<span class="linenos">41</span><span class="w">  </span><span class="p">}</span>
+<span class="linenos">42</span>
+<span class="linenos">43</span><span class="w">  </span><span class="n">__syncthreads</span><span class="p">();</span>
+<span class="linenos">44</span>
+<span class="linenos">45</span><span class="w">  </span><span class="c1">// Copy into shared memory</span>
+<span class="linenos">46</span><span class="w">  </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">threadIdx</span><span class="p">.</span><span class="n">x</span><span class="p">;</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="n">ind_arg1_size</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">;</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">+=</span><span class="w"> </span><span class="n">blockDim</span><span class="p">.</span><span class="n">x</span><span class="w"> </span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="linenos">47</span><span class="w">    </span><span class="n">ind_arg1_shared</span><span class="p">[</span><span class="n">idx</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">ind_arg1</span><span class="p">[</span><span class="n">idx</span><span class="w"> </span><span class="o">%</span><span class="w"> </span><span class="mi">2</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">ind_arg1_map</span><span class="p">[</span><span class="n">idx</span><span class="w"> </span><span class="o">/</span><span class="w"> </span><span class="mi">2</span><span class="p">]</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">];</span>
+<span class="linenos">48</span><span class="w">  </span><span class="p">}</span>
+<span class="linenos">49</span>
+<span class="linenos">50</span><span class="w">  </span><span class="n">__syncthreads</span><span class="p">();</span>
+<span class="linenos">51</span>
+<span class="linenos">52</span><span class="w">  </span><span class="c1">// process set elements</span>
+<span class="linenos">53</span><span class="w">  </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">threadIdx</span><span class="p">.</span><span class="n">x</span><span class="p">;</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="n">nelem</span><span class="p">;</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">+=</span><span class="w"> </span><span class="n">blockDim</span><span class="p">.</span><span class="n">x</span><span class="w"> </span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="linenos">54</span><span class="w">    </span><span class="n">ind_arg1_vec</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">ind_arg1_shared</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">loc_map</span><span class="p">[</span><span class="mi">0</span><span class="o">*</span><span class="n">set_size</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">offset_b</span><span class="p">]</span><span class="o">*</span><span class="mi">2</span><span class="p">;</span>
+<span class="linenos">55</span><span class="w">    </span><span class="n">ind_arg1_vec</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">ind_arg1_shared</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">loc_map</span><span class="p">[</span><span class="mi">1</span><span class="o">*</span><span class="n">set_size</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">offset_b</span><span class="p">]</span><span class="o">*</span><span class="mi">2</span><span class="p">;</span>
+<span class="linenos">56</span><span class="w">    </span><span class="n">ind_arg1_vec</span><span class="p">[</span><span class="mi">2</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">ind_arg1_shared</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">loc_map</span><span class="p">[</span><span class="mi">2</span><span class="o">*</span><span class="n">set_size</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">offset_b</span><span class="p">]</span><span class="o">*</span><span class="mi">2</span><span class="p">;</span>
+<span class="linenos">57</span>
+<span class="linenos">58</span><span class="w">    </span><span class="n">midpoint</span><span class="p">(</span><span class="n">arg0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="mi">2</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="p">(</span><span class="n">idx</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">offset_b_abs</span><span class="p">),</span><span class="w"> </span><span class="n">ind_arg1_vec</span><span class="p">);</span>
+<span class="linenos">59</span><span class="w">  </span><span class="p">}</span>
+<span class="linenos">60</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>The CUDA kernel <code class="docutils literal notranslate"><span class="pre">__midpoint_stub</span></code> is launched on the GPU for a specific
+number of threads in parallel. Each thread is identified inside the kernel by
+its thread id <code class="docutils literal notranslate"><span class="pre">threadIdx</span></code> within a block of threads identified by a two
+dimensional block id <code class="docutils literal notranslate"><span class="pre">blockIdx</span></code> within a grid of blocks.</p>
+<p>As for OpenMP, there is the potential for data races, which are prevented by
+colouring the iteration set and computing a parallel execution plan, where all
+elements of the same colour can be modified simultaneously. Each colour is
+computed by a block of threads in parallel. All threads of a thread block have
+access to a shared memory, which is used as a shared staging area initialised
+by thread 0 of each block, see lines 30-41 above. A call to
+<code class="docutils literal notranslate"><span class="pre">__syncthreads()</span></code> ensures these initial values are visible to all threads of
+the block. After this barrier, all threads cooperatively gather data from the
+indirectly accessed <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> via the <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code>, followed
+by another synchronisation. Following that, each thread loops over the
+elements in the partition with an increment of the block size. In each
+iteration a thread-private array of pointers to coordinate data in shared
+memory is built which is then passed to the <code class="docutils literal notranslate"><span class="pre">midpoint</span></code> kernel. As for other
+backends, the first, directly accessed, argument, is passed as a pointer to
+global device memory with a suitable offset.</p>
+</section>
+<section id="opencl-backend">
+<span id="id6"></span><h3>OpenCL backend<a class="headerlink" href="#opencl-backend" title="Link to this heading">¶</a></h3>
+<p>The other device backend OpenCL is structurally very similar to the CUDA
+backend. It uses <a class="reference external" href="http://mathema.tician.de/software/pyopencl/">PyOpenCL</a> to interface to the OpenCL drivers and runtime.
+Linear algebra operations are handled by <a class="reference external" href="http://www.mcs.anl.gov/petsc/petsc-as/">PETSc</a> as described in
+<a class="reference internal" href="linear_algebra.html"><span class="doc">PyOP2 Linear Algebra Interface</span></a>. PyOP2 generates a kernel stub from a template similar
+to the CUDA case.</p>
+<p>Consider the <code class="docutils literal notranslate"><span class="pre">midpoint</span></code> kernel from previous examples, whose parameters in
+the kernel signature are automatically annotated with OpenCL storage
+qualifiers. <a class="reference external" href="http://mathema.tician.de/software/pyopencl/">PyOpenCL</a> provides Python wrappers for OpenCL runtime functions to
+build a kernel from a code string, set its arguments and enqueue the kernel
+for execution. It takes care of the necessary conversion from Python objects
+to plain C data types. PyOP2 generates the following code for the <code class="docutils literal notranslate"><span class="pre">midpoint</span></code>
+example:</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="linenos"> 1</span><span class="cp">#define ROUND_UP(bytes) (((bytes) + 15) &amp; ~15)</span>
+<span class="linenos"> 2</span>
+<span class="linenos"> 3</span><span class="kt">void</span><span class="w"> </span><span class="nf">midpoint</span><span class="p">(</span><span class="n">__global</span><span class="w"> </span><span class="kt">double</span><span class="w"> </span><span class="n">p</span><span class="p">[</span><span class="mi">2</span><span class="p">],</span><span class="w"> </span><span class="n">__local</span><span class="w"> </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">coords</span><span class="p">[</span><span class="mi">2</span><span class="p">]);</span>
+<span class="linenos"> 4</span><span class="kt">void</span><span class="w"> </span><span class="nf">midpoint</span><span class="p">(</span><span class="n">__global</span><span class="w"> </span><span class="kt">double</span><span class="w"> </span><span class="n">p</span><span class="p">[</span><span class="mi">2</span><span class="p">],</span><span class="w"> </span><span class="n">__local</span><span class="w"> </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">coords</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span>
+<span class="linenos"> 5</span><span class="p">{</span>
+<span class="linenos"> 6</span><span class="w">  </span><span class="n">p</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">((</span><span class="n">coords</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="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">coords</span><span class="p">[</span><span class="mi">1</span><span class="p">][</span><span class="mi">0</span><span class="p">])</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">coords</span><span class="p">[</span><span class="mi">2</span><span class="p">][</span><span class="mi">0</span><span class="p">])</span><span class="w"> </span><span class="o">/</span><span class="w"> </span><span class="mf">3.0</span><span class="p">;</span>
+<span class="linenos"> 7</span><span class="w">  </span><span class="n">p</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">((</span><span class="n">coords</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">coords</span><span class="p">[</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">])</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">coords</span><span class="p">[</span><span class="mi">2</span><span class="p">][</span><span class="mi">1</span><span class="p">])</span><span class="w"> </span><span class="o">/</span><span class="w"> </span><span class="mf">3.0</span><span class="p">;</span>
+<span class="linenos"> 8</span><span class="p">}</span>
+<span class="linenos"> 9</span>
+<span class="linenos">10</span><span class="n">__kernel</span><span class="w"> </span><span class="nf">__attribute__</span><span class="p">((</span><span class="n">reqd_work_group_size</span><span class="p">(</span><span class="mi">668</span><span class="p">,</span><span class="w"> </span><span class="mi">1</span><span class="p">,</span><span class="w"> </span><span class="mi">1</span><span class="p">)))</span>
+<span class="linenos">11</span><span class="kt">void</span><span class="w"> </span><span class="n">__midpoint_stub</span><span class="p">(</span>
+<span class="linenos">12</span><span class="w">    </span><span class="n">__global</span><span class="w"> </span><span class="kt">double</span><span class="o">*</span><span class="w"> </span><span class="n">arg0</span><span class="p">,</span>
+<span class="linenos">13</span><span class="w">    </span><span class="n">__global</span><span class="w"> </span><span class="kt">double</span><span class="o">*</span><span class="w"> </span><span class="n">ind_arg1</span><span class="p">,</span>
+<span class="linenos">14</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="n">set_size</span><span class="p">,</span>
+<span class="linenos">15</span><span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="n">set_offset</span><span class="p">,</span>
+<span class="linenos">16</span><span class="w">    </span><span class="n">__global</span><span class="w"> </span><span class="kt">int</span><span class="o">*</span><span class="w"> </span><span class="n">p_ind_map</span><span class="p">,</span>
+<span class="linenos">17</span><span class="w">    </span><span class="n">__global</span><span class="w"> </span><span class="kt">short</span><span class="w"> </span><span class="o">*</span><span class="n">p_loc_map</span><span class="p">,</span>
+<span class="linenos">18</span><span class="w">    </span><span class="n">__global</span><span class="w"> </span><span class="kt">int</span><span class="o">*</span><span class="w"> </span><span class="n">p_ind_sizes</span><span class="p">,</span>
+<span class="linenos">19</span><span class="w">    </span><span class="n">__global</span><span class="w"> </span><span class="kt">int</span><span class="o">*</span><span class="w"> </span><span class="n">p_ind_offsets</span><span class="p">,</span>
+<span class="linenos">20</span><span class="w">    </span><span class="n">__global</span><span class="w"> </span><span class="kt">int</span><span class="o">*</span><span class="w"> </span><span class="n">p_blk_map</span><span class="p">,</span>
+<span class="linenos">21</span><span class="w">    </span><span class="n">__global</span><span class="w"> </span><span class="kt">int</span><span class="o">*</span><span class="w"> </span><span class="n">p_offset</span><span class="p">,</span>
+<span class="linenos">22</span><span class="w">    </span><span class="n">__global</span><span class="w"> </span><span class="kt">int</span><span class="o">*</span><span class="w"> </span><span class="n">p_nelems</span><span class="p">,</span>
+<span class="linenos">23</span><span class="w">    </span><span class="n">__global</span><span class="w"> </span><span class="kt">int</span><span class="o">*</span><span class="w"> </span><span class="n">p_nthrcol</span><span class="p">,</span>
+<span class="linenos">24</span><span class="w">    </span><span class="n">__global</span><span class="w"> </span><span class="kt">int</span><span class="o">*</span><span class="w"> </span><span class="n">p_thrcol</span><span class="p">,</span>
+<span class="linenos">25</span><span class="w">    </span><span class="n">__private</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">block_offset</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="linenos">26</span><span class="w">  </span><span class="n">__local</span><span class="w"> </span><span class="kt">char</span><span class="w"> </span><span class="n">shared</span><span class="w"> </span><span class="p">[</span><span class="mi">64</span><span class="p">]</span><span class="w"> </span><span class="n">__attribute__</span><span class="p">((</span><span class="n">aligned</span><span class="p">(</span><span class="k">sizeof</span><span class="p">(</span><span class="kt">long</span><span class="p">))));</span>
+<span class="linenos">27</span><span class="w">  </span><span class="n">__local</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">offset_b</span><span class="p">;</span>
+<span class="linenos">28</span><span class="w">  </span><span class="n">__local</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">offset_b_abs</span><span class="p">;</span>
+<span class="linenos">29</span><span class="w">  </span><span class="n">__local</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">active_threads_count</span><span class="p">;</span>
+<span class="linenos">30</span>
+<span class="linenos">31</span><span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">nbytes</span><span class="p">;</span>
+<span class="linenos">32</span><span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">block_id</span><span class="p">;</span>
+<span class="linenos">33</span>
+<span class="linenos">34</span><span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">i_1</span><span class="p">;</span>
+<span class="linenos">35</span><span class="w">  </span><span class="c1">// shared indirection mappings</span>
+<span class="linenos">36</span><span class="w">  </span><span class="n">__global</span><span class="w"> </span><span class="kt">int</span><span class="o">*</span><span class="w"> </span><span class="n">__local</span><span class="w"> </span><span class="n">ind_arg1_map</span><span class="p">;</span>
+<span class="linenos">37</span><span class="w">  </span><span class="n">__local</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">ind_arg1_size</span><span class="p">;</span>
+<span class="linenos">38</span><span class="w">  </span><span class="n">__local</span><span class="w"> </span><span class="kt">double</span><span class="o">*</span><span class="w"> </span><span class="n">__local</span><span class="w"> </span><span class="n">ind_arg1_shared</span><span class="p">;</span>
+<span class="linenos">39</span><span class="w">  </span><span class="n">__local</span><span class="w"> </span><span class="kt">double</span><span class="o">*</span><span class="w"> </span><span class="n">ind_arg1_vec</span><span class="p">[</span><span class="mi">3</span><span class="p">];</span>
+<span class="linenos">40</span>
+<span class="linenos">41</span><span class="w">  </span><span class="k">if</span><span class="w"> </span><span class="p">(</span><span class="n">get_local_id</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span><span class="w"> </span><span class="o">==</span><span class="w"> </span><span class="mi">0</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="linenos">42</span><span class="w">    </span><span class="n">block_id</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">p_blk_map</span><span class="p">[</span><span class="n">get_group_id</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">block_offset</span><span class="p">];</span>
+<span class="linenos">43</span><span class="w">    </span><span class="n">active_threads_count</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">p_nelems</span><span class="p">[</span><span class="n">block_id</span><span class="p">];</span>
+<span class="linenos">44</span><span class="w">    </span><span class="n">offset_b_abs</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">p_offset</span><span class="p">[</span><span class="n">block_id</span><span class="p">];</span>
+<span class="linenos">45</span><span class="w">    </span><span class="n">offset_b</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">offset_b_abs</span><span class="w"> </span><span class="o">-</span><span class="w"> </span><span class="n">set_offset</span><span class="p">;</span><span class="n">ind_arg1_size</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">p_ind_sizes</span><span class="p">[</span><span class="mi">0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">block_id</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">1</span><span class="p">];</span>
+<span class="linenos">46</span><span class="w">    </span><span class="n">ind_arg1_map</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="o">&amp;</span><span class="n">p_ind_map</span><span class="p">[</span><span class="mi">0</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">set_size</span><span class="p">]</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">p_ind_offsets</span><span class="p">[</span><span class="mi">0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">block_id</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">1</span><span class="p">];</span>
+<span class="linenos">47</span>
+<span class="linenos">48</span><span class="w">    </span><span class="n">nbytes</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span>
+<span class="linenos">49</span><span class="w">    </span><span class="n">ind_arg1_shared</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="n">__local</span><span class="w"> </span><span class="kt">double</span><span class="o">*</span><span class="p">)</span><span class="w"> </span><span class="p">(</span><span class="o">&amp;</span><span class="n">shared</span><span class="p">[</span><span class="n">nbytes</span><span class="p">]);</span>
+<span class="linenos">50</span><span class="w">    </span><span class="n">nbytes</span><span class="w"> </span><span class="o">+=</span><span class="w"> </span><span class="n">ROUND_UP</span><span class="p">(</span><span class="n">ind_arg1_size</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="k">sizeof</span><span class="p">(</span><span class="kt">double</span><span class="p">));</span>
+<span class="linenos">51</span><span class="w">  </span><span class="p">}</span>
+<span class="linenos">52</span><span class="w">  </span><span class="n">barrier</span><span class="p">(</span><span class="n">CLK_LOCAL_MEM_FENCE</span><span class="p">);</span>
+<span class="linenos">53</span>
+<span class="linenos">54</span><span class="w">  </span><span class="c1">// staging in of indirect dats</span>
+<span class="linenos">55</span><span class="w">  </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="n">i_1</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">get_local_id</span><span class="p">(</span><span class="mi">0</span><span class="p">);</span><span class="w"> </span><span class="n">i_1</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="n">ind_arg1_size</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">;</span><span class="w"> </span><span class="n">i_1</span><span class="w"> </span><span class="o">+=</span><span class="w"> </span><span class="n">get_local_size</span><span class="p">(</span><span class="mi">0</span><span class="p">))</span><span class="w"> </span><span class="p">{</span>
+<span class="linenos">56</span><span class="w">    </span><span class="n">ind_arg1_shared</span><span class="p">[</span><span class="n">i_1</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">ind_arg1</span><span class="p">[</span><span class="n">i_1</span><span class="w"> </span><span class="o">%</span><span class="w"> </span><span class="mi">2</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">ind_arg1_map</span><span class="p">[</span><span class="n">i_1</span><span class="w"> </span><span class="o">/</span><span class="w"> </span><span class="mi">2</span><span class="p">]</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">];</span>
+<span class="linenos">57</span><span class="w">  </span><span class="p">}</span>
+<span class="linenos">58</span><span class="w">  </span><span class="n">barrier</span><span class="p">(</span><span class="n">CLK_LOCAL_MEM_FENCE</span><span class="p">);</span>
+<span class="linenos">59</span>
+<span class="linenos">60</span><span class="w">  </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="n">i_1</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">get_local_id</span><span class="p">(</span><span class="mi">0</span><span class="p">);</span><span class="w"> </span><span class="n">i_1</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="n">active_threads_count</span><span class="p">;</span><span class="w"> </span><span class="n">i_1</span><span class="w"> </span><span class="o">+=</span><span class="w"> </span><span class="n">get_local_size</span><span class="p">(</span><span class="mi">0</span><span class="p">))</span><span class="w"> </span><span class="p">{</span>
+<span class="linenos">61</span><span class="w">    </span><span class="n">ind_arg1_vec</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">ind_arg1_shared</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">p_loc_map</span><span class="p">[</span><span class="n">i_1</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="mi">0</span><span class="o">*</span><span class="n">set_size</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">offset_b</span><span class="p">]</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">;</span>
+<span class="linenos">62</span><span class="w">    </span><span class="n">ind_arg1_vec</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">ind_arg1_shared</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">p_loc_map</span><span class="p">[</span><span class="n">i_1</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="mi">1</span><span class="o">*</span><span class="n">set_size</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">offset_b</span><span class="p">]</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">;</span>
+<span class="linenos">63</span><span class="w">    </span><span class="n">ind_arg1_vec</span><span class="p">[</span><span class="mi">2</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">ind_arg1_shared</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">p_loc_map</span><span class="p">[</span><span class="n">i_1</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="mi">2</span><span class="o">*</span><span class="n">set_size</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">offset_b</span><span class="p">]</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">;</span>
+<span class="linenos">64</span>
+<span class="linenos">65</span><span class="w">    </span><span class="n">midpoint</span><span class="p">((</span><span class="n">__global</span><span class="w"> </span><span class="kt">double</span><span class="o">*</span><span class="w"> </span><span class="n">__private</span><span class="p">)(</span><span class="n">arg0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="p">(</span><span class="n">i_1</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">offset_b_abs</span><span class="p">)</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">2</span><span class="p">),</span><span class="w"> </span><span class="n">ind_arg1_vec</span><span class="p">);</span>
+<span class="linenos">66</span><span class="w">  </span><span class="p">}</span>
+<span class="linenos">67</span><span class="p">}</span>
+</pre></div>
+</div>
+<p>Parallel computations in OpenCL are executed by <em>work items</em> organised into
+<em>work groups</em>. OpenCL requires the annotation of all pointer arguments with
+the memory region they point to: <code class="docutils literal notranslate"><span class="pre">__global</span></code> memory is visible to any work
+item, <code class="docutils literal notranslate"><span class="pre">__local</span></code> memory to any work item within the same work group and
+<code class="docutils literal notranslate"><span class="pre">__private</span></code> memory is private to a work item. PyOP2 does this annotation
+automatically for the user kernel if the OpenCL backend is used. Local memory
+therefore corresponds to CUDA’s shared memory and private memory is called
+local memory in CUDA. The work item id within the work group is accessed via
+the OpenCL runtime call <code class="docutils literal notranslate"><span class="pre">get_local_id(0)</span></code>, the work group id via
+<code class="docutils literal notranslate"><span class="pre">get_group_id(0)</span></code>. A barrier synchronisation across all work items of a work
+group is enforced with a call to <code class="docutils literal notranslate"><span class="pre">barrier(CLK_LOCAL_MEM_FENCE)</span></code>. Bearing
+these differences in mind, the OpenCL kernel stub is structurally almost
+identical to the corresponding CUDA version above.</p>
+<p>The required local memory size per work group <code class="docutils literal notranslate"><span class="pre">reqd_work_group_size</span></code> is
+computed as part of the execution plan. In CUDA this value is a launch
+parameter to the kernel, whereas in OpenCL it needs to be hard coded as a
+kernel attribute.</p>
+</section>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">PyOP2 Backends</a><ul>
+<li><a class="reference internal" href="#host-backends">Host backends</a><ul>
+<li><a class="reference internal" href="#sequential-backend">Sequential backend</a></li>
+<li><a class="reference internal" href="#openmp-backend">OpenMP backend</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#device-backends">Device backends</a><ul>
+<li><a class="reference internal" href="#cuda-backend">CUDA backend</a></li>
+<li><a class="reference internal" href="#opencl-backend">OpenCL backend</a></li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="architecture.html"
+                          title="previous chapter">PyOP2 Architecture</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="linear_algebra.html"
+                          title="next chapter">PyOP2 Linear Algebra Interface</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/backends.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="linear_algebra.html" title="PyOP2 Linear Algebra Interface"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="architecture.html" title="PyOP2 Architecture"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">PyOP2 Backends</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/caching.html b/caching.html
new file mode 100644
index 000000000..eb3a52583
--- /dev/null
+++ b/caching.html
@@ -0,0 +1,221 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>Caching in PyOP2 &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="Profiling" href="profiling.html" />
+    <link rel="prev" title="MPI" href="mpi.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="profiling.html" title="Profiling"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="mpi.html" title="MPI"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Caching in PyOP2</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="caching-in-pyop2">
+<span id="caching"></span><h1>Caching in PyOP2<a class="headerlink" href="#caching-in-pyop2" title="Link to this heading">¶</a></h1>
+<p>PyOP2 makes heavy use of caches to ensure performance is not adversely
+affected by too many runtime computations.  The caching in PyOP2 takes
+a number of forms:</p>
+<ol class="arabic">
+<li><p>Disk-based caching of generated code</p>
+<p>Since compiling a generated code module may be an expensive
+operation, PyOP2 caches the generated code on disk such that
+subsequent runs of the same simulation will not have to pay a
+compilation cost.</p>
+</li>
+<li><p>In memory caching of generated code function pointers</p>
+<p>Once code has been generated and loaded into the running PyOP2
+process, we cache the resulting callable function pointer for the
+lifetime of the process, such that subsequent calls to the same
+generated code are fast.</p>
+</li>
+<li><p>In memory caching of expensive to build objects</p>
+<p>Some PyOP2 objects, in particular <code class="xref py py-class docutils literal notranslate"><span class="pre">Sparsity</span></code> objects,
+can be expensive to construct.  Since a sparsity does not change if
+it is built again with the same arguments, we only construct the
+sparsity once for each unique set of arguments.</p>
+</li>
+</ol>
+<p>The caching strategies for PyOP2 follow from two axioms:</p>
+<ol class="arabic simple">
+<li><p>For PyOP2 <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code>s and <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code>s, equality
+is identity</p></li>
+<li><p>Caches of generated code should depend on metadata, but not data</p></li>
+</ol>
+<p>The first axiom implies that two <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code>s or
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code>s compare equal if and only if they are the same
+object.  The second implies that generated code must be <em>independent</em>
+of the absolute size of the data the <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> that
+generated it executed over.  For example, the size of the iteration
+set should not be part of the key, but the arity of any maps and size
+and type of every data item should be.</p>
+<p>On consequence of these rules is that there are effectively two
+separate types of cache in PyOP2, object and class caches,
+distinguished by where the cache itself lives.</p>
+<section id="class-caches">
+<h2>Class caches<a class="headerlink" href="#class-caches" title="Link to this heading">¶</a></h2>
+<p>These are used to cache objects that depend on metadata, but not
+object instances, such are generated code.  They are implemented by
+the cacheable class inheriting from <code class="xref py py-class docutils literal notranslate"><span class="pre">Cached</span></code>.</p>
+<div class="admonition note">
+<p class="admonition-title">Note</p>
+<p>There is currently no eviction strategy for class caches, should
+they grow too large, for example by executing many different parallel
+loops, an out of memory error can occur</p>
+</div>
+</section>
+<section id="object-caches">
+<h2>Object caches<a class="headerlink" href="#object-caches" title="Link to this heading">¶</a></h2>
+<p>These are used to cache objects that are built on top of
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code>s and <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code>s.  They are implemented by the
+cacheable class inheriting from <code class="xref py py-class docutils literal notranslate"><span class="pre">ObjectCached</span></code> and the
+caching instance defining a <code class="docutils literal notranslate"><span class="pre">_cache</span></code> attribute.</p>
+<p>The motivation for these caches is that cache key for objects such as
+sparsities relies on an identical sparsity being built if the
+arguments are identical.  So that users of the API do not have to
+worry too much about carrying around “temporary” objects forever such
+that they will hit caches, PyOP2 builds up a hierarchy of caches of
+transient objects on top of the immutable sets and maps.</p>
+<p>So, for example, the user can build and throw away
+<code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code>s as normal in their code.  Internally, however,
+these instances are cached on the set they are built on top of.  Thus,
+in the following snippet, we have that <code class="docutils literal notranslate"><span class="pre">ds</span></code> and <code class="docutils literal notranslate"><span class="pre">ds2</span></code> are the same
+object:</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="n">s</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span>
+<span class="n">ds</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">DataSet</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="mi">10</span><span class="p">)</span>
+<span class="n">ds2</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">DataSet</span><span class="p">(</span><span class="n">s</span><span class="p">,</span> <span class="mi">10</span><span class="p">)</span>
+<span class="k">assert</span> <span class="n">ds</span> <span class="ow">is</span> <span class="n">ds2</span>
+</pre></div>
+</div>
+<p>The setup of these caches is such that the lifetime of objects in the
+cache is tied to the lifetime of both the caching and the cached
+object.  In the above example, as long as the user program holds a
+reference to one of <code class="docutils literal notranslate"><span class="pre">s</span></code>, <code class="docutils literal notranslate"><span class="pre">ds</span></code> or <code class="docutils literal notranslate"><span class="pre">ds2</span></code> all three objects will
+remain live.  As soon as all references are lost, all three become
+candidates for garbage collection.</p>
+<div class="admonition note">
+<p class="admonition-title">Note</p>
+<p>The cache eviction strategy for these caches relies on the Python
+garbage collector, and hence on the user not holding onto
+references to some of either the cached or the caching objects for
+too long.  Should the objects on which the caches live persist, an
+out of memory error may occur.</p>
+</div>
+</section>
+<section id="debugging-cache-leaks">
+<h2>Debugging cache leaks<a class="headerlink" href="#debugging-cache-leaks" title="Link to this heading">¶</a></h2>
+<p>To debug potential problems with the cache, PyOP2 can be instructed to
+print the size of both object and class caches at program exit.  This
+can be done by setting the environment variable
+<code class="docutils literal notranslate"><span class="pre">PYOP2_PRINT_CACHE_SIZE</span></code> to 1 before running a PyOP2 program, or
+passing the <code class="docutils literal notranslate"><span class="pre">print_cache_size</span></code> to <code class="xref py py-func docutils literal notranslate"><span class="pre">init()</span></code>.</p>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">Caching in PyOP2</a><ul>
+<li><a class="reference internal" href="#class-caches">Class caches</a></li>
+<li><a class="reference internal" href="#object-caches">Object caches</a></li>
+<li><a class="reference internal" href="#debugging-cache-leaks">Debugging cache leaks</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="mpi.html"
+                          title="previous chapter">MPI</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="profiling.html"
+                          title="next chapter">Profiling</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/caching.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="profiling.html" title="Profiling"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="mpi.html" title="MPI"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Caching in PyOP2</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/concepts.html b/concepts.html
new file mode 100644
index 000000000..9be5a215d
--- /dev/null
+++ b/concepts.html
@@ -0,0 +1,363 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>PyOP2 Concepts &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="PyOP2 Kernels" href="kernels.html" />
+    <link rel="prev" title="Installing PyOP2" href="installation.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="kernels.html" title="PyOP2 Kernels"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="installation.html" title="Installing PyOP2"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">PyOP2 Concepts</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="pyop2-concepts">
+<span id="concepts"></span><h1>PyOP2 Concepts<a class="headerlink" href="#pyop2-concepts" title="Link to this heading">¶</a></h1>
+<p>Many numerical algorithms and scientific computations on unstructured meshes
+can be viewed as the <em>independent application</em> of a <em>local operation</em>
+everywhere on a mesh. This local operation is often called a computational
+<em>kernel</em> and its independent application lends itself naturally to parallel
+computation. An unstructured mesh can be described by <em>sets of entities</em>
+(vertices, edges, cells) and the connectivity between those sets forming the
+topology of the mesh.</p>
+<p>PyOP2 is a domain-specific language (DSL) for the parallel executions of
+computational kernels on unstructured meshes or graphs.</p>
+<section id="sets-and-mappings">
+<span id="sets"></span><h2>Sets and mappings<a class="headerlink" href="#sets-and-mappings" title="Link to this heading">¶</a></h2>
+<p>A mesh is defined by <code class="xref py py-class docutils literal notranslate"><span class="pre">sets</span></code> of entities and
+<code class="xref py py-class docutils literal notranslate"><span class="pre">mappings</span></code> between these sets. Sets are used to represent
+entities in the mesh (nodes in the graph) or degrees of freedom of data
+(fields) living “on” the mesh (graph), while maps define the connectivity
+between entities (links in the graph) or degrees of freedom, for example
+associating an edge with its incident vertices. Sets of mesh entities may
+coincide with sets of degrees of freedom, but this is not necessarily the case
+e.g. the set of degrees of freedom for a field may be defined on the vertices
+of the mesh and the midpoints of edges connecting the vertices.</p>
+<div class="admonition note">
+<p class="admonition-title">Note</p>
+<p>There is a requirement for the map to be of <em>constant arity</em>, that is each
+element in the source set must be associated with a constant number of
+elements in the target set. There is no requirement for the map to be
+injective or surjective. This restriction excludes certain kinds of mappings
+e.g. a map from vertices to incident egdes or cells is only possible on a
+very regular mesh where the multiplicity of any vertex is constant.</p>
+</div>
+<p>In the following we declare a <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> <code class="docutils literal notranslate"><span class="pre">vertices</span></code>, a
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> <code class="docutils literal notranslate"><span class="pre">edges</span></code> and a <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> <code class="docutils literal notranslate"><span class="pre">edges2vertices</span></code>
+between them, which associates the two incident vertices with each edge:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">vertices</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="mi">4</span><span class="p">)</span>
+<span class="n">edges</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="mi">3</span><span class="p">)</span>
+<span class="n">edges2vertices</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Map</span><span class="p">(</span><span class="n">edges</span><span class="p">,</span> <span class="n">vertices</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="p">[[</span><span class="mi">0</span><span class="p">,</span> <span class="mi">1</span><span class="p">],</span> <span class="p">[</span><span class="mi">1</span><span class="p">,</span> <span class="mi">2</span><span class="p">],</span> <span class="p">[</span><span class="mi">2</span><span class="p">,</span> <span class="mi">3</span><span class="p">]])</span>
+</pre></div>
+</div>
+</section>
+<section id="data">
+<span id="id1"></span><h2>Data<a class="headerlink" href="#data" title="Link to this heading">¶</a></h2>
+<p>PyOP2 distinguishes three kinds of user provided data: data that lives on a
+set (often referred to as a field) is represented by a <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>,
+data that has no association with a set by a <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code> and data
+that is visible globally and referred to by a unique identifier is declared as
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Const</span></code>. Examples of the use of these data types are given in
+the <a class="reference internal" href="#par-loops"><span class="std std-ref">Parallel loops</span></a> section below.</p>
+<section id="dat">
+<span id="data-dat"></span><h3>Dat<a class="headerlink" href="#dat" title="Link to this heading">¶</a></h3>
+<p>Since a set does not have any type but only a cardinality, data declared on a
+set through a <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> needs additional metadata to allow PyOP2 to
+interpret the data and to specify how much memory is required to store it. This
+metadata is the <em>datatype</em> and the <em>shape</em> of the data associated with any
+given set element. The shape is not associated with the <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>
+directly, but with a <code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code>. One can associate a scalar with
+each element of the set or a one- or higher-dimensional vector. Similar to the
+restriction on maps, the shape and therefore the size of the data associated
+which each element needs to be uniform. PyOP2 supports all common primitive
+data types supported by <a class="reference external" href="http://docs.scipy.org/doc/numpy/reference/arrays.dtypes.html">NumPy</a>.  Custom datatypes are supported insofar as
+the user implements the serialisation and deserialisation of that type into
+primitive data that can be handled by PyOP2.</p>
+<p>Declaring coordinate data on the <code class="docutils literal notranslate"><span class="pre">vertices</span></code> defined above, where two float
+coordinates are associated with each vertex, is done like this:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">dvertices</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">DataSet</span><span class="p">(</span><span class="n">vertices</span><span class="p">,</span> <span class="n">dim</span><span class="o">=</span><span class="mi">2</span><span class="p">)</span>
+<span class="n">coordinates</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Dat</span><span class="p">(</span><span class="n">dvertices</span><span class="p">,</span>
+                      <span class="p">[[</span><span class="mf">0.0</span><span class="p">,</span> <span class="mf">0.0</span><span class="p">],</span> <span class="p">[</span><span class="mf">0.0</span><span class="p">,</span> <span class="mf">1.0</span><span class="p">],</span> <span class="p">[</span><span class="mf">1.0</span><span class="p">,</span> <span class="mf">1.0</span><span class="p">],</span> <span class="p">[</span><span class="mf">1.0</span><span class="p">,</span> <span class="mf">0.0</span><span class="p">]],</span>
+                      <span class="n">dtype</span><span class="o">=</span><span class="nb">float</span><span class="p">)</span>
+</pre></div>
+</div>
+</section>
+<section id="global">
+<span id="data-global"></span><h3>Global<a class="headerlink" href="#global" title="Link to this heading">¶</a></h3>
+<p>In contrast to a <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>, a <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code> has no
+association to a set and the shape and type of the data are declared directly
+on the <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code>. A 2x2 elasticity tensor would be defined as
+follows:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">elasticity</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Global</span><span class="p">((</span><span class="mi">2</span><span class="p">,</span> <span class="mi">2</span><span class="p">),</span> <span class="p">[[</span><span class="mf">1.0</span><span class="p">,</span> <span class="mf">0.0</span><span class="p">],</span> <span class="p">[</span><span class="mf">0.0</span><span class="p">,</span> <span class="mf">1.0</span><span class="p">]],</span> <span class="n">dtype</span><span class="o">=</span><span class="nb">float</span><span class="p">)</span>
+</pre></div>
+</div>
+</section>
+<section id="const">
+<span id="data-const"></span><h3>Const<a class="headerlink" href="#const" title="Link to this heading">¶</a></h3>
+<p>Data that is globally visible and read-only to kernels is declared with a
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Const</span></code> and needs to have a globally unique identifier.  It does
+not need to be declared as an argument to a <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>, but is
+accessible in a kernel by name. A globally visible parameter <code class="docutils literal notranslate"><span class="pre">eps</span></code> would be
+declared as follows:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">eps</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Const</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="mf">1e-14</span><span class="p">,</span> <span class="n">name</span><span class="o">=</span><span class="s2">&quot;eps&quot;</span><span class="p">,</span> <span class="n">dtype</span><span class="o">=</span><span class="nb">float</span><span class="p">)</span>
+</pre></div>
+</div>
+</section>
+<section id="mat">
+<span id="data-mat"></span><h3>Mat<a class="headerlink" href="#mat" title="Link to this heading">¶</a></h3>
+<p>In a PyOP2 context, a (sparse) matrix is a linear operator from one set to
+another. In other words, it is a linear function which takes a
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> on one set <span class="math">A</span> and returns the value of a
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> on another set <span class="math">B</span>. Of course, in particular,
+<span class="math">A</span> may be the same set as <span class="math">B</span>. This makes the operation of at
+least some matrices equivalent to the operation of a particular PyOP2 kernel.</p>
+<p>PyOP2 can be used to assemble <code class="xref py py-class docutils literal notranslate"><span class="pre">matrices</span></code>, which are defined
+on a <code class="xref py py-class docutils literal notranslate"><span class="pre">sparsity</span> <span class="pre">pattern</span></code> which is built from a pair of
+<code class="xref py py-class docutils literal notranslate"><span class="pre">DataSets</span></code> defining the row and column spaces the
+sparsity maps between and one or more pairs of maps, one for the row and one
+for the column space of the matrix respectively. The sparsity uniquely defines
+the non-zero structure of the sparse matrix and can be constructed purely from
+those mappings. To declare a <code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code> on a <code class="xref py py-class docutils literal notranslate"><span class="pre">Sparsity</span></code>
+only the data type needs to be given.</p>
+<p>Since the construction of large sparsity patterns is a very expensive
+operation, the decoupling of <code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code> and <code class="xref py py-class docutils literal notranslate"><span class="pre">Sparsity</span></code>
+allows the reuse of sparsity patterns for a number of matrices without
+recomputation. In fact PyOP2 takes care of caching sparsity patterns on behalf
+of the user, so declaring a sparsity on the same maps as a previously declared
+sparsity yields the cached object instead of building another one.</p>
+<p>Defining a matrix of floats on a sparsity which spans from the space of
+vertices to the space of vertices via the edges is done as follows:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">sparsity</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Sparsity</span><span class="p">((</span><span class="n">dvertices</span><span class="p">,</span> <span class="n">dvertices</span><span class="p">),</span>
+                        <span class="p">[(</span><span class="n">edges2vertices</span><span class="p">,</span> <span class="n">edges2vertices</span><span class="p">)])</span>
+<span class="n">matrix</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Mat</span><span class="p">(</span><span class="n">sparsity</span><span class="p">,</span> <span class="nb">float</span><span class="p">)</span>
+</pre></div>
+</div>
+</section>
+</section>
+<section id="parallel-loops">
+<span id="par-loops"></span><h2>Parallel loops<a class="headerlink" href="#parallel-loops" title="Link to this heading">¶</a></h2>
+<p>Computations in PyOP2 are executed as <code class="xref py py-func docutils literal notranslate"><span class="pre">parallel</span> <span class="pre">loops</span></code>
+of a <code class="xref py py-class docutils literal notranslate"><span class="pre">Kernel</span></code> over an <em>iteration set</em>. Parallel loops are the
+core construct of PyOP2 and hide most of its complexity such as parallel
+scheduling, partitioning, colouring, data transfer from and to device and
+staging of the data into on chip memory. Computations in a parallel loop must
+be independent of the order in which they are executed over the set to allow
+PyOP2 maximum flexibility to schedule the computation in the most efficient
+way. Kernels are described in more detail in <a class="reference internal" href="kernels.html"><span class="doc">PyOP2 Kernels</span></a>.</p>
+<section id="loop-invocations">
+<span id="id2"></span><h3>Loop invocations<a class="headerlink" href="#loop-invocations" title="Link to this heading">¶</a></h3>
+<p>A parallel loop invocation requires as arguments, other than the iteration set
+and the kernel to operate on, the data the kernel reads and/or writes. A
+parallel loop argument is constructed by calling the underlying data object
+(i.e. the <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> or <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code>) and passing an
+<em>access descriptor</em> and the mapping to be used when accessing the data. The
+mapping is required for an <em>indirectly accessed</em> <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> not
+declared on the same set as the iteration set of the parallel loop. In the
+case of <em>directly accessed</em> data defined on the same set as the iteration set
+the map is omitted and only an access descriptor given.</p>
+<p>Consider a parallel loop that translates the <code class="docutils literal notranslate"><span class="pre">coordinate</span></code> field by a
+constant offset given by the <code class="xref py py-class docutils literal notranslate"><span class="pre">Const</span></code> <code class="docutils literal notranslate"><span class="pre">offset</span></code>. Note how the
+kernel has access to the local variable <code class="docutils literal notranslate"><span class="pre">offset</span></code> even though it has not been
+passed as an argument to the <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>. This loop is direct and
+the argument <code class="docutils literal notranslate"><span class="pre">coordinates</span></code> is read and written:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">op2</span><span class="o">.</span><span class="n">Const</span><span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="p">[</span><span class="mf">1.0</span><span class="p">,</span> <span class="mf">1.0</span><span class="p">],</span> <span class="n">dtype</span><span class="o">=</span><span class="nb">float</span><span class="p">,</span> <span class="n">name</span><span class="o">=</span><span class="s2">&quot;offset&quot;</span><span class="p">);</span>
+
+<span class="n">translate</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Kernel</span><span class="p">(</span><span class="s2">&quot;&quot;&quot;void translate(double * coords) {</span>
+<span class="s2">  coords[0] += offset[0];</span>
+<span class="s2">  coords[1] += offset[1];</span>
+<span class="s2">}&quot;&quot;&quot;</span><span class="p">,</span> <span class="s2">&quot;translate&quot;</span><span class="p">)</span>
+
+<span class="n">op2</span><span class="o">.</span><span class="n">par_loop</span><span class="p">(</span><span class="n">translate</span><span class="p">,</span> <span class="n">vertices</span><span class="p">,</span> <span class="n">coordinates</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">RW</span><span class="p">))</span>
+</pre></div>
+</div>
+</section>
+<section id="access-descriptors">
+<span id="id3"></span><h3>Access descriptors<a class="headerlink" href="#access-descriptors" title="Link to this heading">¶</a></h3>
+<p>Access descriptors define how the data is accessed by the kernel and give
+PyOP2 crucial information as to how the data needs to be treated during
+staging in before and staging out after kernel execution. They must be one of
+<code class="xref py py-data docutils literal notranslate"><span class="pre">pyop2.READ</span></code> (read-only), <code class="xref py py-data docutils literal notranslate"><span class="pre">pyop2.WRITE</span></code> (write-only),
+<code class="xref py py-data docutils literal notranslate"><span class="pre">pyop2.RW</span></code> (read-write), <code class="xref py py-data docutils literal notranslate"><span class="pre">pyop2.INC</span></code> (increment),
+<code class="xref py py-data docutils literal notranslate"><span class="pre">pyop2.MIN</span></code> (minimum reduction) or <code class="xref py py-data docutils literal notranslate"><span class="pre">pyop2.MAX</span></code> (maximum
+reduction).</p>
+<p>Not all of these descriptors apply to all PyOP2 data types. A
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> can have modes <code class="xref py py-data docutils literal notranslate"><span class="pre">READ</span></code>, <code class="xref py py-data docutils literal notranslate"><span class="pre">WRITE</span></code>,
+<code class="xref py py-data docutils literal notranslate"><span class="pre">RW</span></code> and <code class="xref py py-data docutils literal notranslate"><span class="pre">INC</span></code>. For a <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code> the
+valid modes are <code class="xref py py-data docutils literal notranslate"><span class="pre">READ</span></code>, <code class="xref py py-data docutils literal notranslate"><span class="pre">INC</span></code>, <code class="xref py py-data docutils literal notranslate"><span class="pre">MIN</span></code> and
+<code class="xref py py-data docutils literal notranslate"><span class="pre">MAX</span></code> and for a <code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code> only <code class="xref py py-data docutils literal notranslate"><span class="pre">WRITE</span></code> and
+<code class="xref py py-data docutils literal notranslate"><span class="pre">INC</span></code> are allowed.</p>
+</section>
+<section id="loops-assembling-matrices">
+<span id="matrix-loops"></span><h3>Loops assembling matrices<a class="headerlink" href="#loops-assembling-matrices" title="Link to this heading">¶</a></h3>
+<p>We declare a parallel loop assembling the <code class="docutils literal notranslate"><span class="pre">matrix</span></code> via a given <code class="docutils literal notranslate"><span class="pre">kernel</span></code>
+which we’ll assume has been defined before over the <code class="docutils literal notranslate"><span class="pre">edges</span></code> and with
+<code class="docutils literal notranslate"><span class="pre">coordinates</span></code> as input data. The <code class="docutils literal notranslate"><span class="pre">matrix</span></code> is the output argument of this
+parallel loop and therefore has the access descriptor <code class="xref py py-data docutils literal notranslate"><span class="pre">INC</span></code> since
+the assembly accumulates contributions from different vertices via the
+<code class="docutils literal notranslate"><span class="pre">edges2vertices</span></code> mapping. Note that the mappings are being indexed with the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">iteration</span> <span class="pre">indices</span></code> <code class="docutils literal notranslate"><span class="pre">op2.i[0]</span></code> and
+<code class="docutils literal notranslate"><span class="pre">op2.i[1]</span></code> respectively. This means that PyOP2 generates a <a class="reference internal" href="kernels.html#local-iteration-spaces"><span class="std std-ref">local
+iteration space</span></a> of size <code class="docutils literal notranslate"><span class="pre">arity</span> <span class="pre">*</span> <span class="pre">arity</span></code> with the
+<code class="docutils literal notranslate"><span class="pre">arity</span></code> of the <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> <code class="docutils literal notranslate"><span class="pre">edges2vertices</span></code> for any given element
+of the iteration set.  This local iteration space is then iterated over using
+the iteration indices on the maps.  The kernel is assumed to only apply to a
+single point in that local iteration space. The <code class="docutils literal notranslate"><span class="pre">coordinates</span></code> are accessed
+via the same mapping, but are a read-only input argument to the kernel and
+therefore use the access descriptor <code class="xref py py-data docutils literal notranslate"><span class="pre">READ</span></code>:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">op2</span><span class="o">.</span><span class="n">par_loop</span><span class="p">(</span><span class="n">kernel</span><span class="p">,</span> <span class="n">edges</span><span class="p">,</span>
+             <span class="n">matrix</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">INC</span><span class="p">,</span> <span class="p">(</span><span class="n">edges2vertices</span><span class="p">[</span><span class="n">op2</span><span class="o">.</span><span class="n">i</span><span class="p">[</span><span class="mi">0</span><span class="p">]],</span>
+                              <span class="n">edges2vertices</span><span class="p">[</span><span class="n">op2</span><span class="o">.</span><span class="n">i</span><span class="p">[</span><span class="mi">1</span><span class="p">]])),</span>
+             <span class="n">coordinates</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">READ</span><span class="p">,</span> <span class="n">edges2vertices</span><span class="p">))</span>
+</pre></div>
+</div>
+<p>You can stack up multiple successive parallel loops that add values to
+a matrix, before you use the resulting values, you must explicitly
+tell PyOP2 that you want to do so, by calling
+<code class="xref py py-meth docutils literal notranslate"><span class="pre">assemble()</span></code> on the matrix.  Note that executing a
+<code class="xref py py-func docutils literal notranslate"><span class="pre">solve()</span></code> will do this automatically for you.</p>
+</section>
+<section id="loops-with-global-reductions">
+<span id="reduction-loops"></span><h3>Loops with global reductions<a class="headerlink" href="#loops-with-global-reductions" title="Link to this heading">¶</a></h3>
+<p><code class="xref py py-class docutils literal notranslate"><span class="pre">Globals</span></code> are used primarily for reductions where a
+given quantity on a field is reduced to a single number by summation or
+finding the minimum or maximum. Consider a kernel computing the <a class="reference external" href="https://en.wikipedia.org/wiki/L2_norm#Euclidean_norm">L2 norm</a> of
+the <code class="docutils literal notranslate"><span class="pre">pressure</span></code> field defined on the set of <code class="docutils literal notranslate"><span class="pre">vertices</span></code> as <code class="docutils literal notranslate"><span class="pre">l2norm</span></code>. Note
+that the <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> constructor automatically creates an anonymous
+<code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code> of dimension 1 if a <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> is passed as
+the first argument. We assume <code class="docutils literal notranslate"><span class="pre">pressure</span></code> is the result of some prior
+computation and only give the declaration for context.</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">pressure</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Dat</span><span class="p">(</span><span class="n">vertices</span><span class="p">,</span> <span class="p">[</span><span class="o">...</span><span class="p">],</span> <span class="n">dtype</span><span class="o">=</span><span class="nb">float</span><span class="p">)</span>
+<span class="n">l2norm</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Global</span><span class="p">(</span><span class="n">dim</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span> <span class="n">data</span><span class="o">=</span><span class="p">[</span><span class="mf">0.0</span><span class="p">])</span>
+
+<span class="n">norm</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Kernel</span><span class="p">(</span><span class="s2">&quot;&quot;&quot;void norm(double * out, double * field) {</span>
+<span class="s2">  *out += field[0] * field[0];</span>
+<span class="s2">}&quot;&quot;&quot;</span><span class="p">,</span> <span class="s2">&quot;norm&quot;</span><span class="p">)</span>
+
+<span class="n">op2</span><span class="o">.</span><span class="n">par_loop</span><span class="p">(</span><span class="n">pressure</span><span class="p">,</span> <span class="n">vertices</span><span class="p">,</span>
+             <span class="n">l2norm</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">INC</span><span class="p">),</span>
+             <span class="n">vertices</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">READ</span><span class="p">))</span>
+</pre></div>
+</div>
+</section>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">PyOP2 Concepts</a><ul>
+<li><a class="reference internal" href="#sets-and-mappings">Sets and mappings</a></li>
+<li><a class="reference internal" href="#data">Data</a><ul>
+<li><a class="reference internal" href="#dat">Dat</a></li>
+<li><a class="reference internal" href="#global">Global</a></li>
+<li><a class="reference internal" href="#const">Const</a></li>
+<li><a class="reference internal" href="#mat">Mat</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#parallel-loops">Parallel loops</a><ul>
+<li><a class="reference internal" href="#loop-invocations">Loop invocations</a></li>
+<li><a class="reference internal" href="#access-descriptors">Access descriptors</a></li>
+<li><a class="reference internal" href="#loops-assembling-matrices">Loops assembling matrices</a></li>
+<li><a class="reference internal" href="#loops-with-global-reductions">Loops with global reductions</a></li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="installation.html"
+                          title="previous chapter">Installing PyOP2</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="kernels.html"
+                          title="next chapter">PyOP2 Kernels</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/concepts.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="kernels.html" title="PyOP2 Kernels"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="installation.html" title="Installing PyOP2"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">PyOP2 Concepts</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/genindex.html b/genindex.html
new file mode 100644
index 000000000..9a7ec06db
--- /dev/null
+++ b/genindex.html
@@ -0,0 +1,1138 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
+    <title>Index &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="#" />
+    <link rel="search" title="Search" href="search.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="#" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Index</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+
+<h1 id="index">Index</h1>
+
+<div class="genindex-jumpbox">
+ <a href="#A"><strong>A</strong></a>
+ | <a href="#C"><strong>C</strong></a>
+ | <a href="#D"><strong>D</strong></a>
+ | <a href="#E"><strong>E</strong></a>
+ | <a href="#F"><strong>F</strong></a>
+ | <a href="#G"><strong>G</strong></a>
+ | <a href="#H"><strong>H</strong></a>
+ | <a href="#I"><strong>I</strong></a>
+ | <a href="#K"><strong>K</strong></a>
+ | <a href="#L"><strong>L</strong></a>
+ | <a href="#M"><strong>M</strong></a>
+ | <a href="#N"><strong>N</strong></a>
+ | <a href="#O"><strong>O</strong></a>
+ | <a href="#P"><strong>P</strong></a>
+ | <a href="#R"><strong>R</strong></a>
+ | <a href="#S"><strong>S</strong></a>
+ | <a href="#T"><strong>T</strong></a>
+ | <a href="#U"><strong>U</strong></a>
+ | <a href="#V"><strong>V</strong></a>
+ | <a href="#W"><strong>W</strong></a>
+ | <a href="#Z"><strong>Z</strong></a>
+ 
+</div>
+<h2 id="A">A</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat">AbstractDat (class in pyop2.types.dat)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.access.Access">Access (class in pyop2.types.access)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.align">align() (in module pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.map.Map.arange">arange (pyop2.types.map.Map attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.map.MixedMap.arange">(pyop2.types.map.MixedMap attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.map.Map.arities">arities (pyop2.types.map.Map attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.map.MixedMap.arities">(pyop2.types.map.MixedMap attribute)</a>
+</li>
+      </ul></li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.map.Map.arity">arity (pyop2.types.map.Map attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.map.MixedMap.arity">(pyop2.types.map.MixedMap attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.exceptions.ArityTypeError">ArityTypeError</a>
+</li>
+      <li><a href="pyop2.html#pyop2.datatypes.as_cstr">as_cstr() (in module pyop2.datatypes)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.datatypes.as_ctypes">as_ctypes() (in module pyop2.datatypes)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.datatypes.as_numpy_dtype">as_numpy_dtype() (in module pyop2.datatypes)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.as_tuple">as_tuple() (in module pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.as_type">as_type() (in module pyop2.utils)</a>
+</li>
+  </ul></td>
+</tr></table>
+
+<h2 id="C">C</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.html#pyop2.configuration.Configuration.cache_dir">cache_dir (pyop2.configuration.Configuration attribute)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.cached_property">cached_property (class in pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.cdim">cdim (pyop2.types.dat.AbstractDat attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.DatView.cdim">(pyop2.types.dat.DatView attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier.cdim">(pyop2.types.data_carrier.DataCarrier attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.DataSet.cdim">(pyop2.types.dataset.DataSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.cdim">(pyop2.types.dataset.GlobalDataSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.cdim">(pyop2.types.dataset.MixedDataSet attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.utils.validate_dtype.check_arg">check_arg() (pyop2.utils.validate_dtype method)</a>
+
+      <ul>
+        <li><a href="pyop2.html#pyop2.utils.validate_in.check_arg">(pyop2.utils.validate_in method)</a>
+</li>
+        <li><a href="pyop2.html#pyop2.utils.validate_range.check_arg">(pyop2.utils.validate_range method)</a>
+</li>
+        <li><a href="pyop2.html#pyop2.utils.validate_type.check_arg">(pyop2.utils.validate_type method)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.utils.validate_base.check_args">check_args() (pyop2.utils.validate_base method)</a>
+</li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.halo.Halo.comm">comm (pyop2.types.halo.Halo property)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.CompilationError">CompilationError</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.map.ComposedMap">ComposedMap (class in pyop2.types.map)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.configuration.Configuration">Configuration (class in pyop2.configuration)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.ConfigurationError">ConfigurationError</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.glob.Constant">Constant (class in pyop2.types.glob)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.copy">copy() (pyop2.types.dat.AbstractDat method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.copy">(pyop2.types.dat.MixedDat method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.copy">(pyop2.types.glob.SetFreeDataCarrier method)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.set.Set.core_part">core_part (pyop2.types.set.Set attribute)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.GlobalSet.core_size">core_size (pyop2.types.set.GlobalSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.set.MixedSet.core_size">(pyop2.types.set.MixedSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.set.Set.core_size">(pyop2.types.set.Set attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier.ctype">ctype (pyop2.types.data_carrier.DataCarrier attribute)</a>
+</li>
+  </ul></td>
+</tr></table>
+
+<h2 id="D">D</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.dat.Dat">Dat (class in pyop2.types.dat)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.dat_version">dat_version (pyop2.types.dat.MixedDat property)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.data_carrier.VecAccessMixin.dat_version">(pyop2.types.data_carrier.VecAccessMixin property)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.data">data (pyop2.types.dat.AbstractDat property)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.DatView.data">(pyop2.types.dat.DatView property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.data">(pyop2.types.dat.MixedDat property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.data">(pyop2.types.glob.SetFreeDataCarrier property)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.data_ro">data_ro (pyop2.types.dat.AbstractDat property)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.DatView.data_ro">(pyop2.types.dat.DatView property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.data_ro">(pyop2.types.dat.MixedDat property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.data_ro">(pyop2.types.glob.SetFreeDataCarrier property)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.data_ro_with_halos">data_ro_with_halos (pyop2.types.dat.AbstractDat property)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.DatView.data_ro_with_halos">(pyop2.types.dat.DatView property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.data_ro_with_halos">(pyop2.types.dat.MixedDat property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.data_ro_with_halos">(pyop2.types.glob.SetFreeDataCarrier property)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.data_with_halos">data_with_halos (pyop2.types.dat.AbstractDat property)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.DatView.data_with_halos">(pyop2.types.dat.DatView property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.data_with_halos">(pyop2.types.dat.MixedDat property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.data_with_halos">(pyop2.types.glob.SetFreeDataCarrier property)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.data_wo">data_wo (pyop2.types.dat.AbstractDat property)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.DatView.data_wo">(pyop2.types.dat.DatView property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.data_wo">(pyop2.types.dat.MixedDat property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.data_wo">(pyop2.types.glob.SetFreeDataCarrier property)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.data_wo_with_halos">data_wo_with_halos (pyop2.types.dat.AbstractDat property)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.DatView.data_wo_with_halos">(pyop2.types.dat.DatView property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.data_wo_with_halos">(pyop2.types.dat.MixedDat property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.data_wo_with_halos">(pyop2.types.glob.SetFreeDataCarrier property)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier">DataCarrier (class in pyop2.types.data_carrier)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dataset.DataSet">DataSet (class in pyop2.types.dataset)</a>
+</li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.dataset">dataset (pyop2.types.dat.AbstractDat attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.dataset">(pyop2.types.dat.MixedDat attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.Global.dataset">(pyop2.types.glob.Global attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.exceptions.DataSetTypeError">DataSetTypeError</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.DataTypeError">DataTypeError</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.DataValueError">DataValueError</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.DatTypeError">DatTypeError</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.DatView">DatView (class in pyop2.types.dat)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.mpi.decref">decref() (in module pyop2.mpi)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.configuration.Configuration.DEFAULTS">DEFAULTS (pyop2.configuration.Configuration attribute)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.Set.difference">difference() (pyop2.types.set.Set method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.set.Subset.difference">(pyop2.types.set.Subset method)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.dim">dim (pyop2.types.dat.AbstractDat attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.DatView.dim">(pyop2.types.dat.DatView attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier.dim">(pyop2.types.data_carrier.DataCarrier attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.DataSet.dim">(pyop2.types.dataset.DataSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.dim">(pyop2.types.dataset.GlobalDataSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.dim">(pyop2.types.dataset.MixedDataSet attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.exceptions.DimTypeError">DimTypeError</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dataset.DataSet.dm">dm (pyop2.types.dataset.DataSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.dm">(pyop2.types.dataset.GlobalDataSet attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.dtype">dtype (pyop2.types.dat.AbstractDat attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.dtype">(pyop2.types.dat.MixedDat attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier.dtype">(pyop2.types.data_carrier.DataCarrier attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.dtype">(pyop2.types.glob.SetFreeDataCarrier property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.map.Map.dtype">(pyop2.types.map.Map attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.datatypes.dtype_limits">dtype_limits() (in module pyop2.datatypes)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.glob.Constant.duplicate">duplicate() (pyop2.types.glob.Constant method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.glob.Global.duplicate">(pyop2.types.glob.Global method)</a>
+</li>
+      </ul></li>
+  </ul></td>
+</tr></table>
+
+<h2 id="E">E</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.data_carrier.EmptyDataMixin">EmptyDataMixin (class in pyop2.types.data_carrier)</a>
+</li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.set.ExtrudedSet">ExtrudedSet (class in pyop2.types.set)</a>
+</li>
+  </ul></td>
+</tr></table>
+
+<h2 id="F">F</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.dataset.DataSet.field_ises">field_ises (pyop2.types.dataset.DataSet attribute)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.flatten">flatten() (in module pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.map.ComposedMap.flattened_maps">flattened_maps (pyop2.types.map.ComposedMap attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.map.Map.flattened_maps">(pyop2.types.map.Map attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.map.MixedMap.flattened_maps">(pyop2.types.map.MixedMap attribute)</a>
+</li>
+      </ul></li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.freeze_halo">freeze_halo() (pyop2.types.dat.AbstractDat method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.freeze_halo">(pyop2.types.dat.MixedDat method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.Global.freeze_halo">(pyop2.types.glob.Global method)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.frozen_halo">frozen_halo (class in pyop2.types.dat)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.frozen_halo">frozen_halo() (pyop2.types.dat.AbstractDat method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.glob.Global.frozen_halo">(pyop2.types.glob.Global method)</a>
+</li>
+      </ul></li>
+  </ul></td>
+</tr></table>
+
+<h2 id="G">G</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.html#pyop2.utils.get_petsc_dir">get_petsc_dir() (in module pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.glob.Global">Global (class in pyop2.types.glob)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.global_to_local_begin">global_to_local_begin() (pyop2.types.dat.AbstractDat method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.global_to_local_begin">(pyop2.types.dat.MixedDat method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.Global.global_to_local_begin">(pyop2.types.glob.Global method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.halo.Halo.global_to_local_begin">(pyop2.types.halo.Halo method)</a>
+</li>
+      </ul></li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.global_to_local_end">global_to_local_end() (pyop2.types.dat.AbstractDat method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.global_to_local_end">(pyop2.types.dat.MixedDat method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.Global.global_to_local_end">(pyop2.types.glob.Global method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.halo.Halo.global_to_local_end">(pyop2.types.halo.Halo method)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet">GlobalDataSet (class in pyop2.types.dataset)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.GlobalSet">GlobalSet (class in pyop2.types.set)</a>
+</li>
+  </ul></td>
+</tr></table>
+
+<h2 id="H">H</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.halo.Halo">Halo (class in pyop2.types.halo)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.GlobalSet.halo">halo (pyop2.types.set.GlobalSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.set.MixedSet.halo">(pyop2.types.set.MixedSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.set.Set.halo">(pyop2.types.set.Set attribute)</a>
+</li>
+      </ul></li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.dat.DatView.halo_valid">halo_valid (pyop2.types.dat.DatView property)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.halo_valid">(pyop2.types.dat.MixedDat property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.halo_valid">(pyop2.types.glob.SetFreeDataCarrier property)</a>
+</li>
+      </ul></li>
+  </ul></td>
+</tr></table>
+
+<h2 id="I">I</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.access.INC">INC (in module pyop2.types.access)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.access.Access.INC">(pyop2.types.access.Access attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.mpi.incref">incref() (in module pyop2.mpi)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.increment_dat_version">increment_dat_version() (pyop2.types.dat.MixedDat method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier.increment_dat_version">(pyop2.types.data_carrier.DataCarrier method)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.exceptions.IndexTypeError">IndexTypeError</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.IndexValueError">IndexValueError</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.Subset.indices">indices (pyop2.types.set.Subset attribute)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.inner">inner() (pyop2.types.dat.AbstractDat method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.inner">(pyop2.types.dat.MixedDat method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.inner">(pyop2.types.glob.SetFreeDataCarrier method)</a>
+</li>
+      </ul></li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.html#pyop2.mpi.internal_comm">internal_comm() (in module pyop2.mpi)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.Set.intersection">intersection() (pyop2.types.set.Set method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.set.Subset.intersection">(pyop2.types.set.Subset method)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.mpi.is_pyop2_comm">is_pyop2_comm() (in module pyop2.mpi)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.IterateValueError">IterateValueError</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.map.Map.iterset">iterset (pyop2.types.map.Map attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.map.MixedMap.iterset">(pyop2.types.map.MixedMap attribute)</a>
+</li>
+      </ul></li>
+  </ul></td>
+</tr></table>
+
+<h2 id="K">K</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.html#pyop2.exceptions.KernelTypeError">KernelTypeError</a>
+</li>
+  </ul></td>
+</tr></table>
+
+<h2 id="L">L</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.set.ExtrudedSet.layers">layers (pyop2.types.set.ExtrudedSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.set.MixedSet.layers">(pyop2.types.set.MixedSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.set.Set.layers">(pyop2.types.set.Set attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.set.ExtrudedSet.layers_array">layers_array (pyop2.types.set.ExtrudedSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.set.Subset.layers_array">(pyop2.types.set.Subset attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dataset.DataSet.layout_vec">layout_vec (pyop2.types.dataset.DataSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.layout_vec">(pyop2.types.dataset.GlobalDataSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.layout_vec">(pyop2.types.dataset.MixedDataSet attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dataset.DataSet.lgmap">lgmap (pyop2.types.dataset.DataSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.lgmap">(pyop2.types.dataset.GlobalDataSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.lgmap">(pyop2.types.dataset.MixedDataSet attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.load">load() (pyop2.types.dat.AbstractDat method)</a>
+</li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.dataset.DataSet.local_ises">local_ises (pyop2.types.dataset.DataSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.local_ises">(pyop2.types.dataset.GlobalDataSet attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.local_to_global_begin">local_to_global_begin() (pyop2.types.dat.AbstractDat method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.local_to_global_begin">(pyop2.types.dat.MixedDat method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.Global.local_to_global_begin">(pyop2.types.glob.Global method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.halo.Halo.local_to_global_begin">(pyop2.types.halo.Halo method)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.local_to_global_end">local_to_global_end() (pyop2.types.dat.AbstractDat method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.local_to_global_end">(pyop2.types.dat.MixedDat method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.Global.local_to_global_end">(pyop2.types.glob.Global method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.halo.Halo.local_to_global_end">(pyop2.types.halo.Halo method)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.halo.Halo.local_to_global_numbering">local_to_global_numbering (pyop2.types.halo.Halo property)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.logger.log">log() (in module pyop2.logger)</a>
+</li>
+  </ul></td>
+</tr></table>
+
+<h2 id="M">M</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.map.Map">Map (class in pyop2.types.map)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.MapTypeError">MapTypeError</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.MapValueError">MapValueError</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.MatTypeError">MatTypeError</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.access.MAX">MAX (in module pyop2.types.access)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.access.Access.MAX">(pyop2.types.access.Access attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.access.MIN">MIN (in module pyop2.types.access)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.access.Access.MIN">(pyop2.types.access.Access attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat">MixedDat (class in pyop2.types.dat)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dataset.MixedDataSet">MixedDataSet (class in pyop2.types.dataset)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.map.MixedMap">MixedMap (class in pyop2.types.map)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.MixedSet">MixedSet (class in pyop2.types.set)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.ModeValueError">ModeValueError</a>
+</li>
+      <li>
+    module
+
+      <ul>
+        <li><a href="pyop2.html#module-pyop2.configuration">pyop2.configuration</a>
+</li>
+        <li><a href="pyop2.html#module-pyop2.datatypes">pyop2.datatypes</a>
+</li>
+        <li><a href="pyop2.html#module-pyop2.exceptions">pyop2.exceptions</a>
+</li>
+        <li><a href="pyop2.html#module-pyop2.logger">pyop2.logger</a>
+</li>
+        <li><a href="pyop2.html#module-pyop2.mpi">pyop2.mpi</a>
+</li>
+        <li><a href="pyop2.html#module-pyop2.profiling">pyop2.profiling</a>
+</li>
+        <li><a href="pyop2.types.html#module-pyop2.types.access">pyop2.types.access</a>
+</li>
+        <li><a href="pyop2.types.html#module-pyop2.types.dat">pyop2.types.dat</a>
+</li>
+        <li><a href="pyop2.types.html#module-pyop2.types.data_carrier">pyop2.types.data_carrier</a>
+</li>
+        <li><a href="pyop2.types.html#module-pyop2.types.dataset">pyop2.types.dataset</a>
+</li>
+        <li><a href="pyop2.types.html#module-pyop2.types.glob">pyop2.types.glob</a>
+</li>
+        <li><a href="pyop2.types.html#module-pyop2.types.halo">pyop2.types.halo</a>
+</li>
+        <li><a href="pyop2.types.html#module-pyop2.types.map">pyop2.types.map</a>
+</li>
+        <li><a href="pyop2.types.html#module-pyop2.types.set">pyop2.types.set</a>
+</li>
+        <li><a href="pyop2.html#module-pyop2.utils">pyop2.utils</a>
+</li>
+      </ul></li>
+  </ul></td>
+</tr></table>
+
+<h2 id="N">N</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier.name">name (pyop2.types.data_carrier.DataCarrier attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.DataSet.name">(pyop2.types.dataset.DataSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.name">(pyop2.types.dataset.GlobalDataSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.name">(pyop2.types.dataset.MixedDataSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.map.Map.name">(pyop2.types.map.Map attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.map.MixedMap.name">(pyop2.types.map.MixedMap attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.set.GlobalSet.name">(pyop2.types.set.GlobalSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.set.MixedSet.name">(pyop2.types.set.MixedSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.set.Set.name">(pyop2.types.set.Set attribute)</a>
+</li>
+      </ul></li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.html#pyop2.exceptions.NameTypeError">NameTypeError</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.nbytes">nbytes (pyop2.types.dat.AbstractDat attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.nbytes">(pyop2.types.dat.MixedDat attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.nbytes">(pyop2.types.glob.SetFreeDataCarrier property)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.norm">norm (pyop2.types.dat.AbstractDat property)</a>
+</li>
+  </ul></td>
+</tr></table>
+
+<h2 id="O">O</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.map.Map.offset">offset (pyop2.types.map.Map attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.map.MixedMap.offset">(pyop2.types.map.MixedMap attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.map.Map.offset_quotient">offset_quotient (pyop2.types.map.Map attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.map.MixedMap.offset_quotient">(pyop2.types.map.MixedMap attribute)</a>
+</li>
+      </ul></li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.set.Subset.owned_indices">owned_indices (pyop2.types.set.Subset attribute)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.Set.owned_part">owned_part (pyop2.types.set.Set attribute)</a>
+</li>
+  </ul></td>
+</tr></table>
+
+<h2 id="P">P</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.set.ExtrudedSet.parent">parent (pyop2.types.set.ExtrudedSet attribute)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.parse_args">parse_args() (in module pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.parser">parser() (in module pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.GlobalSet.partition_size">partition_size (pyop2.types.set.GlobalSet property)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.set.Set.partition_size">(pyop2.types.set.Set property)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.map.PermutedMap">PermutedMap (class in pyop2.types.map)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.logger.progress">progress() (in module pyop2.logger)</a>
+</li>
+      <li>
+    pyop2.configuration
+
+      <ul>
+        <li><a href="pyop2.html#module-pyop2.configuration">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.datatypes
+
+      <ul>
+        <li><a href="pyop2.html#module-pyop2.datatypes">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.exceptions
+
+      <ul>
+        <li><a href="pyop2.html#module-pyop2.exceptions">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.logger
+
+      <ul>
+        <li><a href="pyop2.html#module-pyop2.logger">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.mpi
+
+      <ul>
+        <li><a href="pyop2.html#module-pyop2.mpi">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.profiling
+
+      <ul>
+        <li><a href="pyop2.html#module-pyop2.profiling">module</a>
+</li>
+      </ul></li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li>
+    pyop2.types.access
+
+      <ul>
+        <li><a href="pyop2.types.html#module-pyop2.types.access">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.types.dat
+
+      <ul>
+        <li><a href="pyop2.types.html#module-pyop2.types.dat">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.types.data_carrier
+
+      <ul>
+        <li><a href="pyop2.types.html#module-pyop2.types.data_carrier">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.types.dataset
+
+      <ul>
+        <li><a href="pyop2.types.html#module-pyop2.types.dataset">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.types.glob
+
+      <ul>
+        <li><a href="pyop2.types.html#module-pyop2.types.glob">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.types.halo
+
+      <ul>
+        <li><a href="pyop2.types.html#module-pyop2.types.halo">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.types.map
+
+      <ul>
+        <li><a href="pyop2.types.html#module-pyop2.types.map">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.types.set
+
+      <ul>
+        <li><a href="pyop2.types.html#module-pyop2.types.set">module</a>
+</li>
+      </ul></li>
+      <li>
+    pyop2.utils
+
+      <ul>
+        <li><a href="pyop2.html#module-pyop2.utils">module</a>
+</li>
+      </ul></li>
+  </ul></td>
+</tr></table>
+
+<h2 id="R">R</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.access.READ">READ (in module pyop2.types.access)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.access.Access.READ">(pyop2.types.access.Access attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.configuration.Configuration.reconfigure">reconfigure() (pyop2.configuration.Configuration method)</a>
+</li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.html#pyop2.configuration.Configuration.reset">reset() (pyop2.configuration.Configuration method)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.access.RW">RW (in module pyop2.types.access)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.access.Access.RW">(pyop2.types.access.Access attribute)</a>
+</li>
+      </ul></li>
+  </ul></td>
+</tr></table>
+
+<h2 id="S">S</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.save">save() (pyop2.types.dat.AbstractDat method)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dataset.DataSet.scalar_lgmap">scalar_lgmap (pyop2.types.dataset.DataSet attribute)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.Set">Set (class in pyop2.types.set)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dataset.DataSet.set">set (pyop2.types.dataset.DataSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.set">(pyop2.types.dataset.GlobalDataSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.set">(pyop2.types.dataset.MixedDataSet attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.logger.set_log_level">set_log_level() (in module pyop2.logger)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier">SetFreeDataCarrier (class in pyop2.types.glob)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.SetPartition">SetPartition (class in pyop2.types.set)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.SetTypeError">SetTypeError</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.SetValueError">SetValueError</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.shape">shape (pyop2.types.dat.AbstractDat attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.DatView.shape">(pyop2.types.dat.DatView attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.shape">(pyop2.types.glob.SetFreeDataCarrier property)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.size">size (pyop2.types.dataset.GlobalDataSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.set.GlobalSet.size">(pyop2.types.set.GlobalSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.set.MixedSet.size">(pyop2.types.set.MixedSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.set.Set.size">(pyop2.types.set.Set attribute)</a>
+</li>
+      </ul></li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.set.GlobalSet.sizes">sizes (pyop2.types.set.GlobalSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.set.MixedSet.sizes">(pyop2.types.set.MixedSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.set.Set.sizes">(pyop2.types.set.Set attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.exceptions.SizeTypeError">SizeTypeError</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.SparsityFormatError">SparsityFormatError</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.SparsityTypeError">SparsityTypeError</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.split">split (pyop2.types.dat.AbstractDat attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.split">(pyop2.types.dat.MixedDat attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.split">(pyop2.types.dataset.MixedDataSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.split">(pyop2.types.glob.SetFreeDataCarrier property)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.map.Map.split">(pyop2.types.map.Map attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.map.MixedMap.split">(pyop2.types.map.MixedMap attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.set.MixedSet.split">(pyop2.types.set.MixedSet attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.utils.strip">strip() (in module pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.Subset">Subset (class in pyop2.types.set)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.exceptions.SubsetIndexOutOfBounds">SubsetIndexOutOfBounds</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.Subset.superset">superset (pyop2.types.set.Subset attribute)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.set.Set.symmetric_difference">symmetric_difference() (pyop2.types.set.Set method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.set.Subset.symmetric_difference">(pyop2.types.set.Subset method)</a>
+</li>
+      </ul></li>
+  </ul></td>
+</tr></table>
+
+<h2 id="T">T</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.html#pyop2.mpi.temp_internal_comm">temp_internal_comm (class in pyop2.mpi)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.profiling.timed_function">timed_function (class in pyop2.profiling)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.profiling.timed_region">timed_region() (in module pyop2.profiling)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.profiling.timed_stage">timed_stage() (in module pyop2.profiling)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.map.Map.toset">toset (pyop2.types.map.Map attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.map.MixedMap.toset">(pyop2.types.map.MixedMap attribute)</a>
+</li>
+      </ul></li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.set.GlobalSet.total_size">total_size (pyop2.types.set.GlobalSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.set.MixedSet.total_size">(pyop2.types.set.MixedSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.set.Set.total_size">(pyop2.types.set.Set attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.utils.trim">trim() (in module pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.tuplify">tuplify() (in module pyop2.utils)</a>
+</li>
+  </ul></td>
+</tr></table>
+
+<h2 id="U">U</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.dataset.DataSet.unblocked_lgmap">unblocked_lgmap (pyop2.types.dataset.DataSet attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.unblocked_lgmap">(pyop2.types.dataset.GlobalDataSet attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.unblocked_lgmap">(pyop2.types.dataset.MixedDataSet attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.unfreeze_halo">unfreeze_halo() (pyop2.types.dat.AbstractDat method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.unfreeze_halo">(pyop2.types.dat.MixedDat method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.Global.unfreeze_halo">(pyop2.types.glob.Global method)</a>
+</li>
+      </ul></li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.set.Set.union">union() (pyop2.types.set.Set method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.set.Subset.union">(pyop2.types.set.Subset method)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.html#pyop2.configuration.Configuration.unsafe_reconfigure">unsafe_reconfigure() (pyop2.configuration.Configuration method)</a>
+</li>
+  </ul></td>
+</tr></table>
+
+<h2 id="V">V</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.html#pyop2.utils.validate_base">validate_base (class in pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.validate_dtype">validate_dtype (class in pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.validate_in">validate_in (class in pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.validate_range">validate_range (class in pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.validate_type">validate_type (class in pyop2.utils)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.map.ComposedMap.values">values (pyop2.types.map.ComposedMap attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.map.Map.values">(pyop2.types.map.Map attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.map.MixedMap.values">(pyop2.types.map.MixedMap attribute)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.map.ComposedMap.values_with_halo">values_with_halo (pyop2.types.map.ComposedMap attribute)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.map.Map.values_with_halo">(pyop2.types.map.Map attribute)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.map.MixedMap.values_with_halo">(pyop2.types.map.MixedMap attribute)</a>
+</li>
+      </ul></li>
+  </ul></td>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.data_carrier.VecAccessMixin.vec">vec (pyop2.types.data_carrier.VecAccessMixin property)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.dat.Dat.vec_context">vec_context() (pyop2.types.dat.Dat method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.vec_context">(pyop2.types.dat.MixedDat method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.data_carrier.VecAccessMixin.vec_context">(pyop2.types.data_carrier.VecAccessMixin method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.Global.vec_context">(pyop2.types.glob.Global method)</a>
+</li>
+      </ul></li>
+      <li><a href="pyop2.types.html#pyop2.types.data_carrier.VecAccessMixin.vec_ro">vec_ro (pyop2.types.data_carrier.VecAccessMixin property)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.data_carrier.VecAccessMixin.vec_wo">vec_wo (pyop2.types.data_carrier.VecAccessMixin property)</a>
+</li>
+      <li><a href="pyop2.types.html#pyop2.types.data_carrier.VecAccessMixin">VecAccessMixin (class in pyop2.types.data_carrier)</a>
+</li>
+      <li><a href="pyop2.html#pyop2.utils.verify_reshape">verify_reshape() (in module pyop2.utils)</a>
+</li>
+  </ul></td>
+</tr></table>
+
+<h2 id="W">W</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.access.WRITE">WRITE (in module pyop2.types.access)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.access.Access.WRITE">(pyop2.types.access.Access attribute)</a>
+</li>
+      </ul></li>
+  </ul></td>
+</tr></table>
+
+<h2 id="Z">Z</h2>
+<table style="width: 100%" class="indextable genindextable"><tr>
+  <td style="width: 33%; vertical-align: top;"><ul>
+      <li><a href="pyop2.types.html#pyop2.types.dat.AbstractDat.zero">zero() (pyop2.types.dat.AbstractDat method)</a>
+
+      <ul>
+        <li><a href="pyop2.types.html#pyop2.types.dat.MixedDat.zero">(pyop2.types.dat.MixedDat method)</a>
+</li>
+        <li><a href="pyop2.types.html#pyop2.types.glob.Global.zero">(pyop2.types.glob.Global method)</a>
+</li>
+      </ul></li>
+  </ul></td>
+</tr></table>
+
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="#" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Index</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/index.html b/index.html
new file mode 100644
index 000000000..4b2ad34b5
--- /dev/null
+++ b/index.html
@@ -0,0 +1,224 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>Welcome to PyOP2’s documentation! &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="Installing PyOP2" href="installation.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="installation.html" title="Installing PyOP2"
+             accesskey="N">next</a> |</li>
+        <li class="nav-item nav-item-0"><a href="#">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Welcome to PyOP2’s documentation!</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="welcome-to-pyop2-s-documentation">
+<h1>Welcome to PyOP2’s documentation!<a class="headerlink" href="#welcome-to-pyop2-s-documentation" title="Link to this heading">¶</a></h1>
+<div class="admonition warning">
+<p class="admonition-title">Warning</p>
+<p>The prose documentation contained here is significantly out-of-date and thus
+contains many inaccuracies. It is, nevertheless, quite a useful resource for
+people new to PyOP2. Please read with care.</p>
+<p>The API documentation, however, is updated regularly and can be considered
+accurate.</p>
+</div>
+<p>Contents:</p>
+<div class="toctree-wrapper compound">
+<ul>
+<li class="toctree-l1"><a class="reference internal" href="installation.html">Installing PyOP2</a></li>
+<li class="toctree-l1"><a class="reference internal" href="concepts.html">PyOP2 Concepts</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="concepts.html#sets-and-mappings">Sets and mappings</a></li>
+<li class="toctree-l2"><a class="reference internal" href="concepts.html#data">Data</a></li>
+<li class="toctree-l2"><a class="reference internal" href="concepts.html#parallel-loops">Parallel loops</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="kernels.html">PyOP2 Kernels</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="kernels.html#kernel-api">Kernel API</a></li>
+<li class="toctree-l2"><a class="reference internal" href="kernels.html#data-layout">Data layout</a></li>
+<li class="toctree-l2"><a class="reference internal" href="kernels.html#local-iteration-spaces">Local iteration spaces</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="ir.html">The PyOP2 Intermediate Representation</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="ir.html#using-the-intermediate-representation">Using the Intermediate Representation</a></li>
+<li class="toctree-l2"><a class="reference internal" href="ir.html#achieving-performance-portability-with-the-ir">Achieving Performance Portability with the IR</a></li>
+<li class="toctree-l2"><a class="reference internal" href="ir.html#optimizing-kernels-on-cpus">Optimizing kernels on CPUs</a></li>
+<li class="toctree-l2"><a class="reference internal" href="ir.html#how-to-select-specific-kernel-optimizations">How to select specific kernel optimizations</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="architecture.html">PyOP2 Architecture</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="architecture.html#multiple-backend-support">Multiple Backend Support</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="backends.html">PyOP2 Backends</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="backends.html#host-backends">Host backends</a></li>
+<li class="toctree-l2"><a class="reference internal" href="backends.html#device-backends">Device backends</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="linear_algebra.html">PyOP2 Linear Algebra Interface</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="linear_algebra.html#sparse-matrix-storage-formats">Sparse Matrix Storage Formats</a></li>
+<li class="toctree-l2"><a class="reference internal" href="linear_algebra.html#matrix-assembly">Matrix assembly</a></li>
+<li class="toctree-l2"><a class="reference internal" href="linear_algebra.html#building-a-sparsity-pattern">Building a sparsity pattern</a></li>
+<li class="toctree-l2"><a class="reference internal" href="linear_algebra.html#solving-a-linear-system">Solving a linear system</a></li>
+<li class="toctree-l2"><a class="reference internal" href="linear_algebra.html#gpu-matrix-assembly">GPU matrix assembly</a></li>
+<li class="toctree-l2"><a class="reference internal" href="linear_algebra.html#gpu-linear-algebra">GPU linear algebra</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="plan.html">Parallel Execution Plan</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="plan.html#partitioning">Partitioning</a></li>
+<li class="toctree-l2"><a class="reference internal" href="plan.html#local-renumbering-and-staging">Local Renumbering and Staging</a></li>
+<li class="toctree-l2"><a class="reference internal" href="plan.html#colouring">Colouring</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="mixed.html">Mixed Types</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="mixed.html#mixed-set-dataset-map-and-dat">Mixed Set, DataSet, Map and Dat</a></li>
+<li class="toctree-l2"><a class="reference internal" href="mixed.html#block-sparsity-and-mat">Block Sparsity and Mat</a></li>
+<li class="toctree-l2"><a class="reference internal" href="mixed.html#mixed-assembly">Mixed Assembly</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="mpi.html">MPI</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="mpi.html#local-numbering">Local Numbering</a></li>
+<li class="toctree-l2"><a class="reference internal" href="mpi.html#computation-communication-overlap">Computation-communication Overlap</a></li>
+<li class="toctree-l2"><a class="reference internal" href="mpi.html#halo-exchange">Halo exchange</a></li>
+<li class="toctree-l2"><a class="reference internal" href="mpi.html#distributed-assembly">Distributed Assembly</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="caching.html">Caching in PyOP2</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="caching.html#class-caches">Class caches</a></li>
+<li class="toctree-l2"><a class="reference internal" href="caching.html#object-caches">Object caches</a></li>
+<li class="toctree-l2"><a class="reference internal" href="caching.html#debugging-cache-leaks">Debugging cache leaks</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="profiling.html">Profiling</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="profiling.html#profiling-pyop2-programs">Profiling PyOP2 programs</a></li>
+<li class="toctree-l2"><a class="reference internal" href="profiling.html#using-pyop2-s-internal-timers">Using PyOP2’s internal timers</a></li>
+<li class="toctree-l2"><a class="reference internal" href="profiling.html#line-by-line-profiling">Line-by-line profiling</a></li>
+<li class="toctree-l2"><a class="reference internal" href="profiling.html#memory-profiling">Memory profiling</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="user.html">pyop2 user documentation</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="user.html#pyop2-package"><code class="xref py py-mod docutils literal notranslate"><span class="pre">pyop2</span></code> Package</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="pyop2.html">pyop2 package</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#subpackages">Subpackages</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#submodules">Submodules</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#pyop2-caching-module">pyop2.caching module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#pyop2-compilation-module">pyop2.compilation module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#module-pyop2.configuration">pyop2.configuration module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#module-pyop2.datatypes">pyop2.datatypes module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#module-pyop2.exceptions">pyop2.exceptions module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#pyop2-global-kernel-module">pyop2.global_kernel module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#pyop2-local-kernel-module">pyop2.local_kernel module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#module-pyop2.logger">pyop2.logger module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#module-pyop2.mpi">pyop2.mpi module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#pyop2-op2-module">pyop2.op2 module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#pyop2-parloop-module">pyop2.parloop module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#module-pyop2.profiling">pyop2.profiling module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#pyop2-sparsity-module">pyop2.sparsity module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#module-pyop2.utils">pyop2.utils module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#pyop2-version-module">pyop2.version module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.html#module-contents">Module contents</a></li>
+</ul>
+</li>
+</ul>
+</div>
+</section>
+<section id="indices-and-tables">
+<h1>Indices and tables<a class="headerlink" href="#indices-and-tables" title="Link to this heading">¶</a></h1>
+<ul class="simple">
+<li><p><a class="reference internal" href="genindex.html"><span class="std std-ref">Index</span></a></p></li>
+<li><p><a class="reference internal" href="py-modindex.html"><span class="std std-ref">Module Index</span></a></p></li>
+<li><p><a class="reference internal" href="search.html"><span class="std std-ref">Search Page</span></a></p></li>
+</ul>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="#">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">Welcome to PyOP2’s documentation!</a></li>
+<li><a class="reference internal" href="#indices-and-tables">Indices and tables</a></li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="installation.html"
+                          title="next chapter">Installing PyOP2</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/index.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="installation.html" title="Installing PyOP2"
+             >next</a> |</li>
+        <li class="nav-item nav-item-0"><a href="#">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Welcome to PyOP2’s documentation!</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/installation.html b/installation.html
new file mode 100644
index 000000000..c9ff2f492
--- /dev/null
+++ b/installation.html
@@ -0,0 +1,127 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>Installing PyOP2 &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="PyOP2 Concepts" href="concepts.html" />
+    <link rel="prev" title="Welcome to PyOP2’s documentation!" href="index.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="concepts.html" title="PyOP2 Concepts"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="index.html" title="Welcome to PyOP2’s documentation!"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Installing PyOP2</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <a class="reference external image-reference" href="https://travis-ci.org/OP2/PyOP2"><img alt="build status" src="https://travis-ci.org/OP2/PyOP2.png?branch=master" /></a>
+<nav class="contents" id="contents" role="doc-toc">
+<p class="topic-title">Contents</p>
+<ul class="simple">
+<li><p><a class="reference internal" href="#installing-pyop2" id="id1">Installing PyOP2</a></p></li>
+</ul>
+</nav>
+<section id="installing-pyop2">
+<h1><a class="toc-backref" href="#id1" role="doc-backlink">Installing PyOP2</a><a class="headerlink" href="#installing-pyop2" title="Link to this heading">¶</a></h1>
+<p>PyOP2 requires Python 3.6 or later.</p>
+<p>The main testing platform for PyOP2 is Ubuntu 18.04 64-bit with Python
+3.6. Later Ubuntu versions should also work. Some users successfully
+use PyOP2 on Mac OS X.</p>
+<p>Installation of the dependencies is somewhat involved, and therefore
+the recommended way to obtain PyOP2 is by using the <a class="reference external" href="https://www.firedrakeproject.org/download.html">Firedrake
+installation script</a>.  This will give
+you a Python 3 venv that contains a working PyOP2 installation.</p>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="index.html"
+                          title="previous chapter">Welcome to PyOP2’s documentation!</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="concepts.html"
+                          title="next chapter">PyOP2 Concepts</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/installation.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="concepts.html" title="PyOP2 Concepts"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="index.html" title="Welcome to PyOP2’s documentation!"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Installing PyOP2</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/ir.html b/ir.html
new file mode 100644
index 000000000..8c358f456
--- /dev/null
+++ b/ir.html
@@ -0,0 +1,412 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>The PyOP2 Intermediate Representation &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="PyOP2 Architecture" href="architecture.html" />
+    <link rel="prev" title="PyOP2 Kernels" href="kernels.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="architecture.html" title="PyOP2 Architecture"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="kernels.html" title="PyOP2 Kernels"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">The PyOP2 Intermediate Representation</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="the-pyop2-intermediate-representation">
+<h1>The PyOP2 Intermediate Representation<a class="headerlink" href="#the-pyop2-intermediate-representation" title="Link to this heading">¶</a></h1>
+<p>The <code class="xref py py-class docutils literal notranslate"><span class="pre">parallel</span> <span class="pre">loop</span></code> is the main construct of PyOP2.
+It applies a specific <code class="xref py py-class docutils literal notranslate"><span class="pre">Kernel</span></code> to all elements in the iteration
+set of the parallel loop. Here, we describe how to use the PyOP2 API to build
+a kernel and, also, we provide simple guidelines on how to write efficient
+kernels.</p>
+<section id="using-the-intermediate-representation">
+<h2>Using the Intermediate Representation<a class="headerlink" href="#using-the-intermediate-representation" title="Link to this heading">¶</a></h2>
+<p>In the <a class="reference internal" href="kernels.html"><span class="doc">previous section</span></a>, we described the API for
+PyOP2 kernels in terms of the C code that gets executed.
+Passing in a string of C code is the simplest way of creating a
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Kernel</span></code>.  Another possibility is to use PyOP2 Intermediate
+Representation (IR) objects to express the <code class="xref py py-class docutils literal notranslate"><span class="pre">Kernel</span></code> semantics.</p>
+<p>An Abstract Syntax Tree of the kernel code can be manually built using IR
+objects. Since PyOP2 has been primarily thought to be fed by higher layers
+of abstractions, rather than by users, no C-to-AST parser is currently provided.
+The advantage of providing an AST, instead of C code, is that it enables PyOP2
+to inspect and transform the kernel, which is aimed at achieving performance
+portability among different architectures and, more generally, better execution
+times.</p>
+<p>For the purposes of exposition, let us consider a simple
+kernel <code class="docutils literal notranslate"><span class="pre">init</span></code> which initialises the members of a <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>
+to zero.</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="kn">from</span> <span class="nn">op2</span> <span class="kn">import</span> <span class="n">Kernel</span>
+
+<span class="n">code</span> <span class="o">=</span> <span class="s2">&quot;&quot;&quot;void init(double* edge_weight) {</span>
+<span class="s2">  for (int i = 0; i &lt; 3; i++)</span>
+<span class="s2">    edge_weight[i] = 0.0;</span>
+<span class="s2">}&quot;&quot;&quot;</span>
+<span class="n">kernel</span> <span class="o">=</span> <span class="n">Kernel</span><span class="p">(</span><span class="n">code</span><span class="p">,</span> <span class="s2">&quot;init&quot;</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>Here, we describe how we can use PyOP2 IR objects to build an AST for
+the this kernel. For example, the most basic AST one can come up with
+is</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="kn">from</span> <span class="nn">op2</span> <span class="kn">import</span> <span class="n">Kernel</span>
+<span class="kn">from</span> <span class="nn">ir.ast_base</span> <span class="kn">import</span> <span class="o">*</span>
+
+<span class="n">ast</span> <span class="o">=</span> <span class="n">FlatBlock</span><span class="p">(</span><span class="s2">&quot;&quot;&quot;void init(double* edge_weight) {</span>
+<span class="s2">  for (int i = 0; i &lt; 3; i++)</span>
+<span class="s2">    edge_weight[i] = 0.0;</span>
+<span class="s2">}&quot;&quot;&quot;</span><span class="p">)</span>
+<span class="n">kernel</span> <span class="o">=</span> <span class="n">Kernel</span><span class="p">(</span><span class="n">ast</span><span class="p">,</span> <span class="s2">&quot;init&quot;</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>The <code class="xref py py-class docutils literal notranslate"><span class="pre">FlatBlock</span></code> object encapsulates a “flat” block
+of code, which is not modified by the IR engine. A
+<code class="xref py py-class docutils literal notranslate"><span class="pre">FlatBlock</span></code> is used to represent (possibly large)
+fragments of code for which we are not interested in any kind of
+transformation, so it may be particularly useful to speed up code development
+when writing, for example, test cases or non-expensive kernels.  On the other
+hand, time-demanding kernels should be properly represented using a “real”
+AST. For example, an useful AST for <code class="docutils literal notranslate"><span class="pre">init</span></code> could be the following</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="kn">from</span> <span class="nn">op2</span> <span class="kn">import</span> <span class="n">Kernel</span>
+<span class="kn">from</span> <span class="nn">ir.ast_base</span> <span class="kn">import</span> <span class="o">*</span>
+
+<span class="n">ast_body</span> <span class="o">=</span> <span class="p">[</span><span class="n">FlatBlock</span><span class="p">(</span><span class="s2">&quot;...some code can go here...&quot;</span><span class="p">),</span>
+            <span class="n">c_for</span><span class="p">(</span><span class="s2">&quot;i&quot;</span><span class="p">,</span> <span class="mi">3</span><span class="p">,</span> <span class="n">Assign</span><span class="p">(</span><span class="n">Symbol</span><span class="p">(</span><span class="s2">&quot;edge_weight&quot;</span><span class="p">,</span> <span class="p">(</span><span class="s2">&quot;i&quot;</span><span class="p">,)),</span> <span class="n">c_sym</span><span class="p">(</span><span class="s2">&quot;0.0&quot;</span><span class="p">)))]</span>
+<span class="n">ast</span> <span class="o">=</span> <span class="n">FunDecl</span><span class="p">(</span><span class="s2">&quot;void&quot;</span><span class="p">,</span> <span class="s2">&quot;init&quot;</span><span class="p">,</span>
+              <span class="p">[</span><span class="n">Decl</span><span class="p">(</span><span class="s2">&quot;double*&quot;</span><span class="p">,</span> <span class="n">c_sym</span><span class="p">(</span><span class="s2">&quot;edge_weight&quot;</span><span class="p">))],</span>
+              <span class="n">ast_body</span><span class="p">)</span>
+<span class="n">kernel</span> <span class="o">=</span> <span class="n">Kernel</span><span class="p">(</span><span class="n">ast</span><span class="p">,</span> <span class="s2">&quot;init&quot;</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>In this example, we first construct the body of the kernel function. We have
+an initial <code class="xref py py-class docutils literal notranslate"><span class="pre">FlatBlock</span></code> that contains, for instance,
+some sort of initialization code. <code class="xref py py-func docutils literal notranslate"><span class="pre">c_for()</span></code> is a shortcut
+for building a <code class="xref py py-class docutils literal notranslate"><span class="pre">for</span> <span class="pre">loop</span></code>.  It takes an
+iteration variable (<code class="docutils literal notranslate"><span class="pre">i</span></code>), the extent of the loop and its body.  Multiple
+statements in the body can be passed in as a list.
+<code class="xref py py-func docutils literal notranslate"><span class="pre">c_sym()</span></code> is a shortcut for building <code class="xref py py-class docutils literal notranslate"><span class="pre">symbols</span></code>. You may want to use
+<code class="xref py py-func docutils literal notranslate"><span class="pre">c_sym()</span></code> when the symbol makes no explicit use of
+iteration variables.</p>
+<p>We use <code class="xref py py-class docutils literal notranslate"><span class="pre">Symbol</span></code> instead of
+<code class="xref py py-func docutils literal notranslate"><span class="pre">c_sym()</span></code>,  when <code class="docutils literal notranslate"><span class="pre">edge_weight</span></code> accesses a specific
+element using the iteration variable <code class="docutils literal notranslate"><span class="pre">i</span></code>. This is fundamental to allow the
+IR engine to perform many kind of transformations involving the kernel’s
+iteration space(s). Finally, the signature of the function is constructed
+using the <code class="xref py py-class docutils literal notranslate"><span class="pre">FunDecl</span></code>.</p>
+<p>Other examples on how to build ASTs can be found in the tests folder,
+particularly looking into <code class="docutils literal notranslate"><span class="pre">test_matrices.py</span></code> and
+<code class="docutils literal notranslate"><span class="pre">test_iteration_space_dats.py</span></code>.</p>
+</section>
+<section id="achieving-performance-portability-with-the-ir">
+<h2>Achieving Performance Portability with the IR<a class="headerlink" href="#achieving-performance-portability-with-the-ir" title="Link to this heading">¶</a></h2>
+<p>One of the key objectives of PyOP2 is obtaining performance portability.
+This means that exactly the same program can be executed on a range of
+different platforms, and that the PyOP2 engine will strive to get the best
+performance out of the chosen platform. PyOP2 allows users to write kernels
+by completely abstracting from the underlying machine. This is mainly
+achieved in two steps:</p>
+<ul class="simple">
+<li><p>Given the AST of a kernel, PyOP2 applies a first transformation aimed at
+mapping the parallelism inherent to the kernel to that available in the
+backend.</p></li>
+<li><p>Then, PyOP2 applies optimizations to the sequential code, depending on the
+underlying backend.</p></li>
+</ul>
+<p>To maximize the outcome of the transformation process, it is important that
+kernels are written as simply as possible. That is, premature optimization,
+possibly for a specific backend, might harm performance.</p>
+<p>A minimal language, the so-called PyOP2 Kernel Domain-Specific Language, is
+used to trigger specific transformations. If we had had a parser from C
+code to AST, we would have embedded this DSL in C by means of <code class="docutils literal notranslate"><span class="pre">pragmas</span></code>.
+As we directly build an AST, we achieve the same goal by decorating AST nodes
+with specific attributes, added at node creation-time. An overview of the
+language follows</p>
+<ul class="simple">
+<li><p><code class="docutils literal notranslate"><span class="pre">pragma</span> <span class="pre">pyop2</span> <span class="pre">itspace</span></code>. This is added to <code class="xref py py-class docutils literal notranslate"><span class="pre">For</span></code>
+nodes (i.e. written on top of for loops). It tells PyOP2 that the following
+is a fully-parallel loop, that is all of its iterations can be executed in
+parallel without any sort of synchronization.</p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">pragma</span> <span class="pre">pyop2</span> <span class="pre">assembly(itvar1,</span> <span class="pre">itvar2)</span></code>. This is added to a statement node,
+to denote that we are performing a local assembly operation along to the
+<code class="docutils literal notranslate"><span class="pre">itvar1</span></code> and <code class="docutils literal notranslate"><span class="pre">itvar2</span></code> dimensions.</p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">pragma</span> <span class="pre">pyop2</span> <span class="pre">simd</span></code>. This is added on top of the kernel signature. It is
+used to suggest PyOP2 to apply SIMD vectorization along the ParLoop’s
+iteration set dimension. This kind of vectorization is also known as
+<em>inter-kernel vectorization</em>. This feature is currently not supported
+by PyOP2, and will be added only in a future release.</p></li>
+</ul>
+<p>The <code class="docutils literal notranslate"><span class="pre">itspace</span></code> pragma tells PyOP2 how to extract parallelism from the kernel.
+Consider again our usual example. To expose a parallel iteration space, one
+one must write</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="kn">from</span> <span class="nn">op2</span> <span class="kn">import</span> <span class="n">Kernel</span>
+
+<span class="n">code</span> <span class="o">=</span> <span class="s2">&quot;&quot;&quot;void init(double* edge_weight) {</span>
+<span class="s2">  #pragma pyop2 itspace</span>
+<span class="s2">  for (int i = 0; i &lt; 3; i++)</span>
+<span class="s2">    edge_weight[i] = 0.0;</span>
+<span class="s2">}&quot;&quot;&quot;</span>
+<span class="n">kernel</span> <span class="o">=</span> <span class="n">Kernel</span><span class="p">(</span><span class="n">code</span><span class="p">,</span> <span class="s2">&quot;init&quot;</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>The <code class="xref py py-func docutils literal notranslate"><span class="pre">c_for()</span></code> shortcut when creating an AST expresses
+the same semantics of a for loop decorated with a <code class="docutils literal notranslate"><span class="pre">pragma</span> <span class="pre">pyop2</span> <span class="pre">itspace</span></code>.</p>
+<p>Now, imagine we are executing the <code class="docutils literal notranslate"><span class="pre">init</span></code> kernel on a CPU architecture.
+Typically we want a single core to execute the entire kernel, because it is
+very likely that the kernel’s iteration space is small and its working set
+fits the L1 cache, and no benefit would be gained by splitting the computation
+between distinct cores. On the other end, if the backend is a GPU or an
+accelerator, a different execution model might give better performance.
+There’s a huge amount of parallelism available, for example, in a GPU, so
+delegating the execution of an individual iteration (or a chunk of iterations)
+to a single thread could pay off. If that is the case, the PyOP2 IR engine
+re-structures the kernel code to exploit such parallelism.</p>
+</section>
+<section id="optimizing-kernels-on-cpus">
+<h2>Optimizing kernels on CPUs<a class="headerlink" href="#optimizing-kernels-on-cpus" title="Link to this heading">¶</a></h2>
+<p>So far, some effort has been spent on optimizations for CPU platforms. Being a
+DSL, PyOP2 provides specific support for those (linear algebra) operations that
+are common among unstructured-mesh-based numerical methods. For example, PyOP2
+is capable of aggressively optimizing local assembly codes for applications
+based on the Finite Element Method. We therefore distinguish optimizations in
+two categories:</p>
+<ul class="simple">
+<li><p>Generic optimizations, such as data alignment and support for autovectorization.</p></li>
+<li><p>Domain-specific optimizations (DSO)</p></li>
+</ul>
+<p>To trigger DSOs, statements must be decorated using the kernel DSL. For example,
+if the kernel computes the local assembly of an element in an unstructured mesh,
+then a <code class="docutils literal notranslate"><span class="pre">pragma</span> <span class="pre">pyop2</span> <span class="pre">assembly(itvar1,</span> <span class="pre">itvar2)</span></code> should be added on top of the
+corresponding statement. When constructing the AST of a kernel, this can be
+simply achieved by</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="kn">from</span> <span class="nn">ir.ast_base</span> <span class="kn">import</span> <span class="o">*</span>
+
+<span class="n">s1</span> <span class="o">=</span> <span class="n">Symbol</span><span class="p">(</span><span class="s2">&quot;X&quot;</span><span class="p">,</span> <span class="p">(</span><span class="s2">&quot;i&quot;</span><span class="p">,))</span>
+<span class="n">s2</span> <span class="o">=</span> <span class="n">Symbol</span><span class="p">(</span><span class="s2">&quot;Y&quot;</span><span class="p">,</span> <span class="p">(</span><span class="s2">&quot;j&quot;</span><span class="p">,))</span>
+<span class="n">tensor</span> <span class="o">=</span> <span class="n">Symbol</span><span class="p">(</span><span class="s2">&quot;A&quot;</span><span class="p">,</span> <span class="p">(</span><span class="s2">&quot;i&quot;</span><span class="p">,</span> <span class="s2">&quot;j&quot;</span><span class="p">))</span>
+<span class="n">pragma</span> <span class="o">=</span> <span class="s2">&quot;#pragma pyop2 outerproduct(j,k)&quot;</span>
+<span class="n">code</span> <span class="o">=</span> <span class="n">c_for</span><span class="p">(</span><span class="s2">&quot;i&quot;</span><span class="p">,</span> <span class="mi">3</span><span class="p">,</span> <span class="n">c_for</span><span class="p">(</span><span class="s2">&quot;j&quot;</span><span class="p">,</span> <span class="mi">3</span><span class="p">,</span> <span class="n">Incr</span><span class="p">(</span><span class="n">tensor</span><span class="p">,</span> <span class="n">Prod</span><span class="p">(</span><span class="n">s1</span><span class="p">,</span> <span class="n">s2</span><span class="p">),</span> <span class="n">pragma</span><span class="p">)))</span>
+</pre></div>
+</div>
+<p>That, conceptually, corresponds to</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="cp">#pragma pyop2 itspace</span>
+<span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="mi">3</span><span class="p">;</span><span class="w"> </span><span class="n">i</span><span class="o">++</span><span class="p">)</span>
+<span class="w">  </span><span class="cp">#pragma pyop2 itspace</span>
+<span class="w">  </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">j</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span><span class="w"> </span><span class="n">j</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="mi">3</span><span class="p">;</span><span class="w"> </span><span class="n">j</span><span class="o">++</span><span class="p">)</span>
+<span class="w">    </span><span class="cp">#pragma pyop2 assembly(i, j)</span>
+<span class="w">    </span><span class="n">A</span><span class="p">[</span><span class="n">i</span><span class="p">][</span><span class="n">j</span><span class="p">]</span><span class="w"> </span><span class="o">+=</span><span class="w"> </span><span class="n">X</span><span class="p">[</span><span class="n">i</span><span class="p">]</span><span class="o">*</span><span class="n">Y</span><span class="p">[</span><span class="n">j</span><span class="p">]</span>
+</pre></div>
+</div>
+<p>Visiting the AST, PyOP2 finds a 2-dimensional iteration space and an assembly
+statement. Currently, <code class="docutils literal notranslate"><span class="pre">#pragma</span> <span class="pre">pyop2</span> <span class="pre">itspace</span></code> is ignored when the backend is
+a CPU. The <code class="docutils literal notranslate"><span class="pre">#pragma</span> <span class="pre">pyop2</span> <span class="pre">assembly(i,</span> <span class="pre">j)</span></code> can trigger multiple DSOs.
+PyOP2 currently lacks an autotuning system that automatically finds out the
+best possible kernel implementation; that is, the optimizations that minimize
+the kernel run-time. To drive the optimization process, the user (or the
+higher layer) can specify which optimizations should be applied. Currently,
+PyOP2 can automate:</p>
+<ul class="simple">
+<li><p>Alignment and padding of data structures: for issuing aligned loads and stores.</p></li>
+<li><p>Loop trip count adjustment according to padding: useful for autovectorization
+when the trip count is not a multiple of the vector length</p></li>
+<li><p>Loop-invariant code motion and autovectorization of invariant code: this is
+particularly useful since trip counts are typically small, and hoisted code
+can still represent a significant proportion of the execution time</p></li>
+<li><p>Register tiling for rectangular iteration spaces</p></li>
+<li><p>(DSO for pragma assembly): Outer-product vectorization + unroll-and-jam of
+outer loops to improve register re-use or to mitigate register pressure</p></li>
+</ul>
+</section>
+<section id="how-to-select-specific-kernel-optimizations">
+<h2>How to select specific kernel optimizations<a class="headerlink" href="#how-to-select-specific-kernel-optimizations" title="Link to this heading">¶</a></h2>
+<p>When constructing a <code class="xref py py-class docutils literal notranslate"><span class="pre">Kernel</span></code>, it is possible to specify the set
+of optimizations we want PyOP2 to apply. The IR engine will analyse the kernel
+AST and will try to apply, incrementally, such optimizations. The PyOP2’s FFC
+interface, which build a <code class="xref py py-class docutils literal notranslate"><span class="pre">Kernel</span></code> object given an AST provided
+by FFC, makes already use of the available optimizations. Here, we take the
+emblematic case of the FFC interface and describe how to play with the various
+optimizations through a series of examples.</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="n">ast</span> <span class="o">=</span> <span class="o">...</span>
+<span class="n">opts</span> <span class="o">=</span> <span class="p">{</span><span class="s1">&#39;licm&#39;</span><span class="p">:</span> <span class="kc">False</span><span class="p">,</span>
+        <span class="s1">&#39;tile&#39;</span><span class="p">:</span> <span class="kc">None</span><span class="p">,</span>
+        <span class="s1">&#39;ap&#39;</span><span class="p">:</span> <span class="kc">False</span><span class="p">,</span>
+        <span class="s1">&#39;vect&#39;</span><span class="p">:</span> <span class="kc">None</span><span class="p">}</span>
+<span class="n">kernel</span> <span class="o">=</span> <span class="n">Kernel</span><span class="p">(</span><span class="n">ast</span><span class="p">,</span> <span class="s1">&#39;my_kernel&#39;</span><span class="p">,</span> <span class="n">opts</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>In this example, we have an AST <code class="docutils literal notranslate"><span class="pre">ast</span></code> and we specify optimizations through
+the dictionary <code class="docutils literal notranslate"><span class="pre">opts</span></code>; then, we build the <code class="xref py py-class docutils literal notranslate"><span class="pre">Kernel</span></code>, passing in
+the optional argument <code class="docutils literal notranslate"><span class="pre">opts</span></code>. No optimizations are enabled here. The
+possible options are:</p>
+<ul class="simple">
+<li><p><code class="docutils literal notranslate"><span class="pre">licm</span></code>: Loop-Invariant Code Motion.</p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">tile</span></code>: Register Tiling (of rectangular iteration spaces)</p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">ap</span></code>: Data alignment, padding. Trip count adjustment.</p></li>
+<li><p><code class="docutils literal notranslate"><span class="pre">vect</span></code>: SIMD intra-kernel vectorization.</p></li>
+</ul>
+<p>If we wanted to apply both loop-invariant code motion and data alignment, we
+would simply write</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="n">ast</span> <span class="o">=</span> <span class="o">...</span>
+<span class="n">opts</span> <span class="o">=</span> <span class="p">{</span><span class="s1">&#39;licm&#39;</span><span class="p">:</span> <span class="kc">True</span><span class="p">,</span>
+        <span class="s1">&#39;ap&#39;</span><span class="p">:</span> <span class="kc">True</span><span class="p">}</span>
+<span class="n">kernel</span> <span class="o">=</span> <span class="n">Kernel</span><span class="p">(</span><span class="n">ast</span><span class="p">,</span> <span class="s1">&#39;my_kernel&#39;</span><span class="p">,</span> <span class="n">opts</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>Now, let’s assume we know the kernel has a rectangular iteration space. We want
+to try register tiling, with a particular tile size. The way to get it is</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="n">ast</span> <span class="o">=</span> <span class="o">...</span>
+<span class="n">opts</span> <span class="o">=</span> <span class="p">{</span><span class="s1">&#39;tile&#39;</span><span class="p">:</span> <span class="p">(</span><span class="kc">True</span><span class="p">,</span> <span class="mi">8</span><span class="p">)}</span>
+<span class="n">kernel</span> <span class="o">=</span> <span class="n">Kernel</span><span class="p">(</span><span class="n">ast</span><span class="p">,</span> <span class="s1">&#39;my_kernel&#39;</span><span class="p">,</span> <span class="n">opts</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>In this case, the iteration space is sliced into tiles of size 8x8. If the
+iteration space is smaller than the slice, then the transformation is not
+applied. By specifying <code class="docutils literal notranslate"><span class="pre">-1</span></code> instead of <code class="docutils literal notranslate"><span class="pre">8</span></code>, we leave PyOP2 free to choose
+automatically a certain tile size.</p>
+<p>A fundamental optimization for any PyOP2 kernel is SIMD vectorization. This is
+because almost always kernels fit the L1 cache and are likely to be compute-
+bound. Backend compilers’ AutoVectorization (AV) is therefore an opportunity.
+By enforcing data alignment and padding, we can increase the chance AV is
+successful. To try AV, one should write</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="kn">import</span> <span class="nn">ir.ast_plan</span> <span class="k">as</span> <span class="nn">ap</span>
+
+<span class="n">ast</span> <span class="o">=</span> <span class="o">...</span>
+<span class="n">opts</span> <span class="o">=</span> <span class="p">{</span><span class="s1">&#39;ap&#39;</span><span class="p">:</span> <span class="kc">True</span><span class="p">,</span>
+        <span class="s1">&#39;vect&#39;</span><span class="p">:</span> <span class="p">(</span><span class="n">ap</span><span class="o">.</span><span class="n">AUTOVECT</span><span class="p">,</span> <span class="o">-</span><span class="mi">1</span><span class="p">)}</span>
+<span class="n">kernel</span> <span class="o">=</span> <span class="n">Kernel</span><span class="p">(</span><span class="n">ast</span><span class="p">,</span> <span class="s1">&#39;my_kernel&#39;</span><span class="p">,</span> <span class="n">opts</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>The <code class="docutils literal notranslate"><span class="pre">vect</span></code>’s second parameter (-1) is ignored when AV is requested.
+If our kernel is computing an assembly-like operation, then we can ask PyOP2
+to optimize for register locality and register pressure, by resorting to a
+different vectorization technique. Early experiments show that this approach
+can be particularly useful when the amount of data movement in the assembly
+loops is “significant”. Of course, this depends on kernel parameters (e.g.
+size of assembly loop, number and size of arrays involved in the assembly) as
+well as on architecture parameters (e.g. size of L1 cache, number of available
+registers). This strategy takes the name of <em>Outer-Product Vectorization</em>
+(OP), and can be activated in the following way (again, we suggest to use it
+along with data alignment and padding).</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="kn">import</span> <span class="nn">ir.ast_plan</span> <span class="k">as</span> <span class="nn">ap</span>
+
+<span class="n">ast</span> <span class="o">=</span> <span class="o">...</span>
+<span class="n">opts</span> <span class="o">=</span> <span class="p">{</span><span class="s1">&#39;ap&#39;</span><span class="p">:</span> <span class="kc">True</span><span class="p">,</span>
+        <span class="s1">&#39;vect&#39;</span><span class="p">:</span> <span class="p">(</span><span class="n">ap</span><span class="o">.</span><span class="n">V_OP_UAJ</span><span class="p">,</span> <span class="mi">1</span><span class="p">)}</span>
+<span class="n">kernel</span> <span class="o">=</span> <span class="n">Kernel</span><span class="p">(</span><span class="n">ast</span><span class="p">,</span> <span class="s1">&#39;my_kernel&#39;</span><span class="p">,</span> <span class="n">opts</span><span class="p">)</span>
+</pre></div>
+</div>
+<p><code class="docutils literal notranslate"><span class="pre">UAJ</span></code> in <code class="docutils literal notranslate"><span class="pre">V_OP_UAJ</span></code> stands for <code class="docutils literal notranslate"><span class="pre">Unroll-and-Jam</span></code>. It has been proved that
+OP shows a much better performance when used in combination with unrolling the
+outer assembly loop and incorporating (<em>jamming</em>) the unrolled iterations
+within the inner loop. The second parameter, therefore, specifies the unroll-
+and-jam factor: the higher it is, the larger is the number of iterations
+unrolled. A factor 1 means that no unroll-and-jam is performed. The optimal
+factor highly depends on the computational characteristics of the kernel.</p>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">The PyOP2 Intermediate Representation</a><ul>
+<li><a class="reference internal" href="#using-the-intermediate-representation">Using the Intermediate Representation</a></li>
+<li><a class="reference internal" href="#achieving-performance-portability-with-the-ir">Achieving Performance Portability with the IR</a></li>
+<li><a class="reference internal" href="#optimizing-kernels-on-cpus">Optimizing kernels on CPUs</a></li>
+<li><a class="reference internal" href="#how-to-select-specific-kernel-optimizations">How to select specific kernel optimizations</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="kernels.html"
+                          title="previous chapter">PyOP2 Kernels</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="architecture.html"
+                          title="next chapter">PyOP2 Architecture</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/ir.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="architecture.html" title="PyOP2 Architecture"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="kernels.html" title="PyOP2 Kernels"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">The PyOP2 Intermediate Representation</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/kernels.html b/kernels.html
new file mode 100644
index 000000000..776432973
--- /dev/null
+++ b/kernels.html
@@ -0,0 +1,326 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>PyOP2 Kernels &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="The PyOP2 Intermediate Representation" href="ir.html" />
+    <link rel="prev" title="PyOP2 Concepts" href="concepts.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="ir.html" title="The PyOP2 Intermediate Representation"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="concepts.html" title="PyOP2 Concepts"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">PyOP2 Kernels</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="pyop2-kernels">
+<span id="kernels"></span><h1>PyOP2 Kernels<a class="headerlink" href="#pyop2-kernels" title="Link to this heading">¶</a></h1>
+<p>Kernels in PyOP2 define the local operations that are to be performed for each
+element of the iteration set the kernel is executed over. There must be a one
+to one match between the arguments declared in the kernel signature and the
+actual arguments passed to the parallel loop executing this kernel. As
+described in <a class="reference internal" href="concepts.html"><span class="doc">PyOP2 Concepts</span></a>, data is accessed directly on the iteration set
+or via mappings passed in the <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> call.</p>
+<p>The kernel only sees data corresponding to the current element of the
+iteration set it is invoked for. Any data read by the kernel i.e. accessed as
+<code class="xref py py-data docutils literal notranslate"><span class="pre">READ</span></code>, <code class="xref py py-data docutils literal notranslate"><span class="pre">RW</span></code> or <code class="xref py py-data docutils literal notranslate"><span class="pre">INC</span></code> is automatically
+gathered via the mapping relationship in the <em>staging in</em> phase and the kernel
+is passed pointers to the staging memory. Similarly, after the kernel has been
+invoked, any modified data i.e. accessed as <code class="xref py py-data docutils literal notranslate"><span class="pre">WRITE</span></code>,
+<code class="xref py py-data docutils literal notranslate"><span class="pre">RW</span></code> or <code class="xref py py-data docutils literal notranslate"><span class="pre">INC</span></code> is scattered back out via the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> in the <em>staging out</em> phase. It is only safe for a kernel
+to manipulate data in the way declared via the access descriptor in the
+parallel loop call. Any modifications to an argument accessed read-only would
+not be written back since the staging out phase is skipped for this argument.
+Similarly, the result of reading an argument declared as write-only is
+undefined since the data has not been staged in.</p>
+<section id="kernel-api">
+<span id="id1"></span><h2>Kernel API<a class="headerlink" href="#kernel-api" title="Link to this heading">¶</a></h2>
+<p>Consider a <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> computing the midpoint of a triangle given
+the three vertex coordinates. Note that we make use of a covenience in the
+PyOP2 syntax, which allow declaring an anonymous <code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code> of a
+dimension greater one by using the <code class="docutils literal notranslate"><span class="pre">**</span></code> operator. We omit the actual data in
+the declaration of the <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> <code class="docutils literal notranslate"><span class="pre">cell2vertex</span></code> and
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> <code class="docutils literal notranslate"><span class="pre">coordinates</span></code>.</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">vertices</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="n">num_vertices</span><span class="p">)</span>
+<span class="n">cells</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="n">num_cells</span><span class="p">)</span>
+
+<span class="n">cell2vertex</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Map</span><span class="p">(</span><span class="n">cells</span><span class="p">,</span> <span class="n">vertices</span><span class="p">,</span> <span class="mi">3</span><span class="p">,</span> <span class="p">[</span><span class="o">...</span><span class="p">])</span>
+
+<span class="n">coordinates</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Dat</span><span class="p">(</span><span class="n">vertices</span> <span class="o">**</span> <span class="mi">2</span><span class="p">,</span> <span class="p">[</span><span class="o">...</span><span class="p">],</span> <span class="n">dtype</span><span class="o">=</span><span class="nb">float</span><span class="p">)</span>
+<span class="n">midpoints</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Dat</span><span class="p">(</span><span class="n">cells</span> <span class="o">**</span> <span class="mi">2</span><span class="p">,</span> <span class="n">dtype</span><span class="o">=</span><span class="nb">float</span><span class="p">)</span>
+
+<span class="n">op2</span><span class="o">.</span><span class="n">par_loop</span><span class="p">(</span><span class="n">midpoint</span><span class="p">,</span> <span class="n">cells</span><span class="p">,</span>
+             <span class="n">midpoints</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">WRITE</span><span class="p">),</span>
+             <span class="n">coordinates</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">READ</span><span class="p">,</span> <span class="n">cell2vertex</span><span class="p">))</span>
+</pre></div>
+</div>
+<p>Kernels are implemented in a restricted subset of C99 and are declared by
+passing a <em>C code string</em> and the <em>kernel function name</em>, which must match the
+name in the C kernel signature, to the <code class="xref py py-class docutils literal notranslate"><span class="pre">Kernel</span></code> constructor:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">midpoint</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Kernel</span><span class="p">(</span><span class="s2">&quot;&quot;&quot;</span>
+<span class="s2">void midpoint(double p[2], double *coords[2]) {</span>
+<span class="s2">  p[0] = (coords[0][0] + coords[1][0] + coords[2][0]) / 3.0;</span>
+<span class="s2">  p[1] = (coords[0][1] + coords[1][1] + coords[2][1]) / 3.0;</span>
+<span class="s2">}&quot;&quot;&quot;</span><span class="p">,</span> <span class="s2">&quot;midpoint&quot;</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>Since kernels cannot return any value, the return type is always <code class="docutils literal notranslate"><span class="pre">void</span></code>. The
+kernel argument <code class="docutils literal notranslate"><span class="pre">p</span></code> corresponds to the third <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>
+argument <code class="docutils literal notranslate"><span class="pre">midpoints</span></code> and <code class="docutils literal notranslate"><span class="pre">coords</span></code> to the fourth argument <code class="docutils literal notranslate"><span class="pre">coordinates</span></code>
+respectively. Argument names need not agree, the matching is by position.</p>
+<p>Data types of kernel arguments must match the type of data passed to the
+parallel loop. The Python types <code class="xref py py-class docutils literal notranslate"><span class="pre">float</span></code> and <code class="xref py py-class docutils literal notranslate"><span class="pre">numpy.float64</span></code>
+correspond to a C <code class="xref py py-class docutils literal notranslate"><span class="pre">double</span></code>, <code class="xref py py-class docutils literal notranslate"><span class="pre">numpy.float32</span></code> to a C
+<code class="xref py py-class docutils literal notranslate"><span class="pre">float</span></code>, <code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code> or <code class="xref py py-class docutils literal notranslate"><span class="pre">numpy.int64</span></code> to a C <code class="xref py py-class docutils literal notranslate"><span class="pre">long</span></code> and
+<code class="xref py py-class docutils literal notranslate"><span class="pre">numpy.int32</span></code> to a C <code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code>.</p>
+<p>Direct <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> arguments such as <code class="docutils literal notranslate"><span class="pre">midpoints</span></code> are passed to
+the kernel as a <code class="docutils literal notranslate"><span class="pre">double</span> <span class="pre">*</span></code>, indirect arguments such as <code class="docutils literal notranslate"><span class="pre">coordinates</span></code> as a
+<code class="docutils literal notranslate"><span class="pre">double</span> <span class="pre">**</span></code> with the first indirection due to the map and the second
+indirection due the data dimension. The kernel signature above uses arrays
+with explicit sizes to draw attention to the fact that these are known. We
+could have interchangibly used a kernel signature with plain pointers:</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="kt">void</span><span class="w"> </span><span class="n">midpoint</span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">p</span><span class="p">,</span><span class="w"> </span><span class="kt">double</span><span class="w"> </span><span class="o">**</span><span class="w"> </span><span class="n">coords</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>Argument creation supports an optional flag <code class="docutils literal notranslate"><span class="pre">flatten</span></code>, which is used
+for kernels which expect data to be laid out by component:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">midpoint</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Kernel</span><span class="p">(</span><span class="s2">&quot;&quot;&quot;</span>
+<span class="s2">void midpoint(double p[2], double *coords[1]) {</span>
+<span class="s2">  p[0] = (coords[0][0] + coords[1][0] + coords[2][0]) / 3.0;</span>
+<span class="s2">  p[1] = (coords[3][0] + coords[4][0] + coords[5][0]) / 3.0;</span>
+<span class="s2">}&quot;&quot;&quot;</span><span class="p">,</span> <span class="s2">&quot;midpoint&quot;</span><span class="p">)</span>
+
+<span class="n">op2</span><span class="o">.</span><span class="n">par_loop</span><span class="p">(</span><span class="n">midpoint</span><span class="p">,</span> <span class="n">cells</span><span class="p">,</span>
+             <span class="n">midpoints</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">WRITE</span><span class="p">),</span>
+             <span class="n">coordinates</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">READ</span><span class="p">,</span> <span class="n">cell2vertex</span><span class="p">,</span> <span class="n">flatten</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
+</pre></div>
+</div>
+</section>
+<section id="data-layout">
+<span id="id2"></span><h2>Data layout<a class="headerlink" href="#data-layout" title="Link to this heading">¶</a></h2>
+<p>Data for a <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> declared on a <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> is
+stored contiguously for all elements of the set. For each element,
+this is a contiguous chunk of data of a shape given by the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code> <code class="docutils literal notranslate"><span class="pre">dim</span></code> and the datatype of the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>.  The size of this chunk is the product of the
+extents of the <code class="docutils literal notranslate"><span class="pre">dim</span></code> tuple times the size of the datatype.</p>
+<p>During execution of the <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>, the kernel is called
+for each element of the iteration set and passed data for each of its
+arguments corresponding to the current set element <code class="docutils literal notranslate"><span class="pre">i</span></code> only.</p>
+<p>For a directly accessed argument such as <code class="docutils literal notranslate"><span class="pre">midpoints</span></code> above, the
+kernel is passed a pointer to the beginning of the chunk of data for
+the element <code class="docutils literal notranslate"><span class="pre">i</span></code> the kernel is currently called for. In CUDA/OpenCL
+<code class="docutils literal notranslate"><span class="pre">i</span></code> is the global thread id since the kernel is launched in parallel
+for all elements.</p>
+<figure class="align-center" id="id4">
+<img alt="_images/direct_arg.svg" src="_images/direct_arg.svg" /><figcaption>
+<p><span class="caption-text">Data layout for a directly accessed <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> argument with
+<code class="docutils literal notranslate"><span class="pre">dim</span></code> 2</span><a class="headerlink" href="#id4" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+<p>For an indirectly accessed argument such as <code class="docutils literal notranslate"><span class="pre">coordinates</span></code> above,
+PyOP2 gathers pointers to the data via the <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code>
+<code class="docutils literal notranslate"><span class="pre">cell2vertex</span></code> used for the indirection. The kernel is passed a list
+of pointers of length corresponding to the <em>arity</em> of the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code>, in the example above 3. Each of these points to
+the data chunk for the element in the target <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> given
+by <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> entries <code class="docutils literal notranslate"><span class="pre">(i,</span> <span class="pre">0)</span></code>, <code class="docutils literal notranslate"><span class="pre">(i,</span> <span class="pre">1)</span></code> and <code class="docutils literal notranslate"><span class="pre">(i,</span> <span class="pre">2)</span></code>.</p>
+<figure class="align-center" id="id5">
+<img alt="_images/indirect_arg.svg" src="_images/indirect_arg.svg" /><figcaption>
+<p><span class="caption-text">Data layout for a <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> argument with <code class="docutils literal notranslate"><span class="pre">dim</span></code> 2 indirectly
+accessed through a <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> of <code class="docutils literal notranslate"><span class="pre">arity</span></code> 3</span><a class="headerlink" href="#id5" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+<p>If the argument is created with the keyword argument <code class="docutils literal notranslate"><span class="pre">flatten</span></code> set
+to <code class="docutils literal notranslate"><span class="pre">True</span></code>, a flattened vector of pointers is passed to the kernel.
+This vector is of length <code class="docutils literal notranslate"><span class="pre">dim</span> <span class="pre">*</span> <span class="pre">arity</span></code> (where <code class="docutils literal notranslate"><span class="pre">dim</span></code> is the product
+of the extents of the <code class="docutils literal notranslate"><span class="pre">dim</span></code> tuple), which is 6 in the example above.
+Each entry points to a single data value of the <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>.
+The ordering is by component of <code class="docutils literal notranslate"><span class="pre">dim</span></code> i.e. the first component of
+each data item for each element in the target set pointed to by the
+map followed by the second component etc.</p>
+<figure class="align-center" id="id6">
+<img alt="_images/indirect_arg_flattened.svg" src="_images/indirect_arg_flattened.svg" /><figcaption>
+<p><span class="caption-text">Data layout for a flattened <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> argument with <code class="docutils literal notranslate"><span class="pre">dim</span></code> 2
+indirectly accessed through a <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> of <code class="docutils literal notranslate"><span class="pre">arity</span></code> 3</span><a class="headerlink" href="#id6" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+</section>
+<section id="local-iteration-spaces">
+<span id="id3"></span><h2>Local iteration spaces<a class="headerlink" href="#local-iteration-spaces" title="Link to this heading">¶</a></h2>
+<p>PyOP2 supports complex kernels with large local working set sizes, which may
+not run very efficiently on architectures with a limited amount of registers
+and on-chip resources. In many cases the resource usage is proportional to the
+size of the <em>local iteration space</em> the kernel operates on.</p>
+<p>Consider a finite-element local assembly kernel for vector-valued basis
+functions of second order on triangles.  There are kernels more complex and
+computing considerably larger local tensors commonly found in finite-element
+computations, in particular for higher-order basis functions, and this kernel
+only serves to illustrate the concept. For each element in the iteration set,
+this kernel computes a 12x12 local tensor:</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="kt">void</span><span class="w"> </span><span class="nf">kernel</span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="n">A</span><span class="p">[</span><span class="mi">12</span><span class="p">][</span><span class="mi">12</span><span class="p">],</span><span class="w"> </span><span class="p">...)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">  </span><span class="p">...</span>
+<span class="w">  </span><span class="c1">// loops over the local iteration space</span>
+<span class="w">  </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">j</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span><span class="w"> </span><span class="n">j</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="mi">12</span><span class="p">;</span><span class="w"> </span><span class="n">j</span><span class="o">++</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">    </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">k</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span><span class="w"> </span><span class="n">k</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="mi">12</span><span class="p">;</span><span class="w"> </span><span class="n">k</span><span class="o">++</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">      </span><span class="n">A</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="w"> </span><span class="o">+=</span><span class="w"> </span><span class="p">...</span>
+<span class="w">    </span><span class="p">}</span>
+<span class="w">  </span><span class="p">}</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+<p>PyOP2 invokes this kernel for each element in the iteration set:</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">ele</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span><span class="w"> </span><span class="n">ele</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="n">nele</span><span class="p">;</span><span class="w"> </span><span class="o">++</span><span class="n">ele</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">  </span><span class="kt">double</span><span class="w"> </span><span class="n">A</span><span class="p">[</span><span class="mi">12</span><span class="p">][</span><span class="mi">12</span><span class="p">];</span>
+<span class="w">  </span><span class="p">...</span>
+<span class="w">  </span><span class="n">kernel</span><span class="p">(</span><span class="n">A</span><span class="p">,</span><span class="w"> </span><span class="p">...);</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+<p>To improve the efficiency of executing complex kernels on manycore
+platforms, their operation can be distributed among several threads
+which each compute a single point in this local iteration space to
+increase the level of parallelism and to lower the amount of resources
+required per thread. In the case of the kernel above we obtain:</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="kt">void</span><span class="w"> </span><span class="nf">mass</span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="n">A</span><span class="p">[</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">],</span><span class="w"> </span><span class="p">...,</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">j</span><span class="p">,</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">k</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">  </span><span class="p">...</span>
+<span class="w">  </span><span class="n">A</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="w"> </span><span class="o">+=</span><span class="w"> </span><span class="p">...</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+<p>Note how the doubly nested loop over basis function is hoisted out of the
+kernel, which receives its position in the local iteration space to compute as
+additional arguments <code class="docutils literal notranslate"><span class="pre">j</span></code> and <code class="docutils literal notranslate"><span class="pre">k</span></code>. PyOP2 then calls the kernel for
+each element of the local iteration space for each set element:</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">ele</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span><span class="w"> </span><span class="n">ele</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="n">nele</span><span class="p">;</span><span class="w"> </span><span class="o">++</span><span class="n">ele</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">  </span><span class="kt">double</span><span class="w"> </span><span class="n">A</span><span class="p">[</span><span class="mi">1</span><span class="p">][</span><span class="mi">1</span><span class="p">];</span>
+<span class="w">  </span><span class="p">...</span>
+<span class="w">  </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">j</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span><span class="w"> </span><span class="n">j</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="mi">12</span><span class="p">;</span><span class="w"> </span><span class="n">j</span><span class="o">++</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">    </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">k</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span><span class="w"> </span><span class="n">k</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="mi">12</span><span class="p">;</span><span class="w"> </span><span class="n">k</span><span class="o">++</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">      </span><span class="n">kernel</span><span class="p">(</span><span class="n">A</span><span class="p">,</span><span class="w"> </span><span class="p">...,</span><span class="w"> </span><span class="n">j</span><span class="p">,</span><span class="w"> </span><span class="n">k</span><span class="p">);</span>
+<span class="w">    </span><span class="p">}</span>
+<span class="w">  </span><span class="p">}</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+<p>On manycore platforms, the local iteration space does not translate into a
+loop nest, but rather into a larger number of threads being launched to
+compute each of its elements:</p>
+<figure class="align-center" id="id7">
+<img alt="_images/iteration_spaces.svg" src="_images/iteration_spaces.svg" /><figcaption>
+<p><span class="caption-text">Local iteration space for a kernel computing a 12x12 local tensor</span><a class="headerlink" href="#id7" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+<p>PyOP2 needs to be told to loop over this local iteration space by
+indexing the corresponding maps with an
+<code class="xref py py-class docutils literal notranslate"><span class="pre">IterationIndex</span></code> <code class="xref py py-data docutils literal notranslate"><span class="pre">i</span></code> in the
+<code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> call.</p>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">PyOP2 Kernels</a><ul>
+<li><a class="reference internal" href="#kernel-api">Kernel API</a></li>
+<li><a class="reference internal" href="#data-layout">Data layout</a></li>
+<li><a class="reference internal" href="#local-iteration-spaces">Local iteration spaces</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="concepts.html"
+                          title="previous chapter">PyOP2 Concepts</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="ir.html"
+                          title="next chapter">The PyOP2 Intermediate Representation</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/kernels.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="ir.html" title="The PyOP2 Intermediate Representation"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="concepts.html" title="PyOP2 Concepts"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">PyOP2 Kernels</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/linear_algebra.html b/linear_algebra.html
new file mode 100644
index 000000000..cf9bbabb1
--- /dev/null
+++ b/linear_algebra.html
@@ -0,0 +1,387 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>PyOP2 Linear Algebra Interface &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="Parallel Execution Plan" href="plan.html" />
+    <link rel="prev" title="PyOP2 Backends" href="backends.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="plan.html" title="Parallel Execution Plan"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="backends.html" title="PyOP2 Backends"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">PyOP2 Linear Algebra Interface</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="pyop2-linear-algebra-interface">
+<span id="linear-algebra"></span><h1>PyOP2 Linear Algebra Interface<a class="headerlink" href="#pyop2-linear-algebra-interface" title="Link to this heading">¶</a></h1>
+<p>PyOP2 supports linear algebra operations on sparse matrices using a thin
+wrapper around the <a class="reference external" href="http://www.mcs.anl.gov/petsc/">PETSc</a> library harnessed via its <a class="reference external" href="http://pythonhosted.org/petsc4py/">petsc4py</a> interface.</p>
+<p>As described in <a class="reference internal" href="concepts.html"><span class="doc">PyOP2 Concepts</span></a>, a sparse matrix is a linear operator that
+maps a <code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code> representing its row space to a
+<code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code> representing its column space and vice versa. These
+two spaces are commonly the same, in which case the resulting matrix is
+square. A sparse matrix is represented by a <code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code>, which is
+declared on a <code class="xref py py-class docutils literal notranslate"><span class="pre">Sparsity</span></code>, representing its non-zero structure.</p>
+<section id="sparse-matrix-storage-formats">
+<span id="matrix-storage"></span><h2>Sparse Matrix Storage Formats<a class="headerlink" href="#sparse-matrix-storage-formats" title="Link to this heading">¶</a></h2>
+<p><a class="reference external" href="http://www.mcs.anl.gov/petsc/">PETSc</a> uses the popular Compressed Sparse Row (CSR) format to only store the
+non-zero entries of a sparse matrix. In CSR, a matrix is stored as three
+one-dimensional arrays of <em>row pointers</em>, <em>column indices</em> and <em>values</em>, where
+the two former are of integer type and the latter of float type, usually
+double. As the name suggests, non-zero entries are stored per row, where each
+non-zero is defined by a pair of column index and corresponding value. The
+column indices and values arrays therefore have a length equal to the total
+number of non-zero entries. Row indices are given implicitly by the row
+pointer array, which contains the starting index in the column index and
+values arrays for the non-zero entries of each row. In other words, the
+non-zeros for row <code class="docutils literal notranslate"><span class="pre">i</span></code> are at positions <code class="docutils literal notranslate"><span class="pre">row_ptr[i]</span></code> up to but not
+including <code class="docutils literal notranslate"><span class="pre">row_ptr[i+1]</span></code> in the column index and values arrays. For each
+row, entries are sorted by column index to allow for faster lookups using a
+binary search.</p>
+<figure class="align-center" id="id2">
+<img alt="_images/csr.svg" src="_images/csr.svg" /><figcaption>
+<p><span class="caption-text">A sparse matrix and its corresponding CSR row pointer, column indices and
+values arrays</span><a class="headerlink" href="#id2" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+<p>For distributed parallel storage with MPI, the rows of the matrix are
+distribued evenly among the processors. Each row is then again divided into a
+<em>diagonal</em> and an <em>off-diagonal</em> part, where the diagonal part comprises
+columns <code class="docutils literal notranslate"><span class="pre">i</span></code> to <code class="docutils literal notranslate"><span class="pre">j</span></code> if <code class="docutils literal notranslate"><span class="pre">i</span></code> and <code class="docutils literal notranslate"><span class="pre">j</span></code> are the first and last row owned by
+a given processor, and the off-diagonal part all other rows.</p>
+<figure class="align-center" id="id3">
+<img alt="_images/mpi_matrix.svg" src="_images/mpi_matrix.svg" /><figcaption>
+<p><span class="caption-text">Distribution of a sparse matrix among 3 MPI processes</span><a class="headerlink" href="#id3" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+</section>
+<section id="matrix-assembly">
+<span id="id1"></span><h2>Matrix assembly<a class="headerlink" href="#matrix-assembly" title="Link to this heading">¶</a></h2>
+<p>Sparse matrices are assembled by adding up local contributions which are
+mapped to global matrix entries via a local-to-global mapping represented by a
+pair of <code class="xref py py-class docutils literal notranslate"><span class="pre">Maps</span></code> for the row and column space.</p>
+<figure class="align-center" id="id4">
+<img alt="_images/assembly.svg" src="_images/assembly.svg" /><figcaption>
+<p><span class="caption-text">Assembly of a local tensor <span class="math">A^K</span> into a global matrix <span class="math">A</span> using
+the local-to-global mapping <span class="math">\iota_K^1</span> for rows and <span class="math">\iota_K^2</span>
+for columns</span><a class="headerlink" href="#id4" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+<p>For each <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> that assembles a matrix, PyOP2 generates a
+call to <a class="reference external" href="http://www.mcs.anl.gov/petsc/">PETSc</a>’s <a class="reference external" href="http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/Mat/MatSetValues.html">MatSetValues</a> function for each element of the iteration set,
+adding the local contributions computed by the user kernel to the global
+matrix using the given <code class="xref py py-class docutils literal notranslate"><span class="pre">Maps</span></code>. At the end of the
+<code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> PyOP2 automatically calls <a class="reference external" href="http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/Mat/MatAssemblyBegin.html">MatAssemblyBegin</a> and
+<a class="reference external" href="http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/Mat/MatAssemblyEnd.html">MatAssemblyEnd</a> to finalise matrix assembly.</p>
+<p>Consider assembling a <code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code> on a <code class="xref py py-class docutils literal notranslate"><span class="pre">Sparsity</span></code> built
+from a <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> from <code class="docutils literal notranslate"><span class="pre">elements</span></code> to <code class="docutils literal notranslate"><span class="pre">nodes</span></code>. The assembly is
+done in a <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> over <code class="docutils literal notranslate"><span class="pre">elements</span></code>, where the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code> <code class="docutils literal notranslate"><span class="pre">A</span></code> is accssed indirectly via the <code class="docutils literal notranslate"><span class="pre">elem_node</span></code>
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> using the <code class="xref py py-class docutils literal notranslate"><span class="pre">IterationIndex</span></code>
+<code class="xref py py-class docutils literal notranslate"><span class="pre">i</span></code>:</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="n">nodes</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="n">NUM_NODES</span><span class="p">,</span> <span class="s2">&quot;nodes&quot;</span><span class="p">)</span>
+<span class="n">elements</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="n">NUM_ELE</span><span class="p">,</span> <span class="s2">&quot;elements&quot;</span><span class="p">)</span>
+
+<span class="n">elem_node</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Map</span><span class="p">(</span><span class="n">elements</span><span class="p">,</span> <span class="n">nodes</span><span class="p">,</span> <span class="mi">3</span><span class="p">,</span> <span class="o">...</span><span class="p">)</span>
+
+<span class="n">sparsity</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Sparsity</span><span class="p">((</span><span class="n">nodes</span><span class="p">,</span> <span class="n">nodes</span><span class="p">),</span> <span class="p">(</span><span class="n">elem_node</span><span class="p">,</span> <span class="n">elem_node</span><span class="p">))</span>
+<span class="n">A</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Mat</span><span class="p">(</span><span class="n">sparsity</span><span class="p">,</span> <span class="n">np</span><span class="o">.</span><span class="n">float64</span><span class="p">)</span>
+
+<span class="n">b</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Dat</span><span class="p">(</span><span class="n">nodes</span><span class="p">,</span> <span class="n">dtype</span><span class="o">=</span><span class="n">np</span><span class="o">.</span><span class="n">float64</span><span class="p">)</span>
+
+<span class="c1"># Assemble the matrix mat</span>
+<span class="n">op2</span><span class="o">.</span><span class="n">par_loop</span><span class="p">(</span><span class="n">mat_kernel</span><span class="p">,</span> <span class="n">elements</span><span class="p">,</span>
+             <span class="n">A</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">INC</span><span class="p">,</span> <span class="p">(</span><span class="n">elem_node</span><span class="p">[</span><span class="n">op2</span><span class="o">.</span><span class="n">i</span><span class="p">[</span><span class="mi">0</span><span class="p">]],</span> <span class="n">elem_node</span><span class="p">[</span><span class="n">op2</span><span class="o">.</span><span class="n">i</span><span class="p">[</span><span class="mi">1</span><span class="p">]])),</span>
+             <span class="o">...</span><span class="p">)</span>
+
+<span class="c1"># Assemble the right-hand side vector b</span>
+<span class="n">op2</span><span class="o">.</span><span class="n">par_loop</span><span class="p">(</span><span class="n">rhs_kernel</span><span class="p">,</span> <span class="n">elements</span><span class="p">,</span>
+             <span class="n">b</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">INC</span><span class="p">,</span> <span class="n">elem_node</span><span class="p">[</span><span class="n">op2</span><span class="o">.</span><span class="n">i</span><span class="p">[</span><span class="mi">0</span><span class="p">]]),</span>
+             <span class="o">...</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>The code generated for the <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> assembling the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code> for the sequential backend is similar to the following,
+where initialisation and staging code described in <a class="reference internal" href="backends.html#sequential-backend"><span class="std std-ref">Sequential backend</span></a>
+have been omitted for brevity. For each element of the iteration
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> a buffer for the local tensor is initialised to zero and
+passed to the user kernel performing the local assembly operation. The
+<code class="docutils literal notranslate"><span class="pre">addto_vector</span></code> call subsequently adds this local contribution to the global
+sparse matrix.</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="kt">void</span><span class="w"> </span><span class="nf">wrap_mat_kernel__</span><span class="p">(...)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">  </span><span class="p">...</span>
+<span class="w">  </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">n</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">start</span><span class="p">;</span><span class="w"> </span><span class="n">n</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="n">end</span><span class="p">;</span><span class="w"> </span><span class="n">n</span><span class="o">++</span><span class="w"> </span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">    </span><span class="kt">int</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">n</span><span class="p">;</span>
+<span class="w">    </span><span class="p">...</span>
+<span class="w">    </span><span class="kt">double</span><span class="w"> </span><span class="n">buffer_arg0_0</span><span class="p">[</span><span class="mi">3</span><span class="p">][</span><span class="mi">3</span><span class="p">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">{{</span><span class="mi">0</span><span class="p">}};</span><span class="w">     </span><span class="c1">// local tensor initialised to 0</span>
+<span class="w">    </span><span class="n">mat_kernel</span><span class="p">(</span><span class="n">buffer_arg0_0</span><span class="p">,</span><span class="w"> </span><span class="p">...);</span><span class="w">         </span><span class="c1">// local assembly kernel</span>
+<span class="w">    </span><span class="n">addto_vector</span><span class="p">(</span><span class="n">arg0_0_0</span><span class="p">,</span><span class="w"> </span><span class="n">buffer_arg0_0</span><span class="p">,</span><span class="w">   </span><span class="c1">// Mat objet, local tensor</span>
+<span class="w">                 </span><span class="mi">3</span><span class="p">,</span><span class="w"> </span><span class="n">arg0_0_map0_0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">3</span><span class="p">,</span><span class="w">  </span><span class="c1">// # rows, global row indices</span>
+<span class="w">                 </span><span class="mi">3</span><span class="p">,</span><span class="w"> </span><span class="n">arg0_0_map1_0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">3</span><span class="p">,</span><span class="w">  </span><span class="c1">// # cols, global column indices</span>
+<span class="w">                 </span><span class="mi">0</span><span class="p">);</span><span class="w">                        </span><span class="c1">// mode: 0 add, 1 insert</span>
+<span class="w">  </span><span class="p">}</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+</section>
+<section id="building-a-sparsity-pattern">
+<span id="sparsity-pattern"></span><h2>Building a sparsity pattern<a class="headerlink" href="#building-a-sparsity-pattern" title="Link to this heading">¶</a></h2>
+<p>The sparsity pattern of a matrix is uniquely defined by the dimensions of the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">DataSets</span></code> forming its row and column space, and one or
+more pairs of <code class="xref py py-class docutils literal notranslate"><span class="pre">Maps</span></code> defining its non-zero structure. This
+is exploited in PyOP2 by caching sparsity patterns with these unique
+attributes as the cache key to save expensive recomputation. Whenever a
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Sparsity</span></code> is initialised, an already computed pattern with the same
+unique key is returned if it exists.</p>
+<p>For a valid sparsity, each row <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> must map to the set of the
+row <code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code>, each column <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> to that of the
+column <code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code> and the from sets of each pair must match. A
+matrix on a sparsity pattern built from more than one pair of maps is
+assembled by multiple parallel loops iterating over the corresponding
+iteration set for each pair.</p>
+<p>Sparsity construction proceeds by iterating each <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> pair and
+building a set of indices of the non-zero columns for each row. Each pair of
+entries in the row and column maps gives the row and column index of a
+non-zero entry in the matrix and therefore the column index is added to the
+set of non-zero entries for that particular row. The array of non-zero entries
+per row is then determined as the size of the set for each row and its
+exclusive scan yields the row pointer array. The column index array is the
+concatenation of all the sets. An algorithm for the sequential case is given
+below:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="k">for</span> <span class="n">rowmap</span><span class="p">,</span> <span class="n">colmap</span> <span class="ow">in</span> <span class="n">maps</span><span class="p">:</span>
+    <span class="k">for</span> <span class="n">e</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">rowmap</span><span class="o">.</span><span class="n">from_size</span><span class="p">):</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">rowmap</span><span class="o">.</span><span class="n">arity</span><span class="p">):</span>
+            <span class="n">row</span> <span class="o">=</span> <span class="n">rowmap</span><span class="o">.</span><span class="n">values</span><span class="p">[</span><span class="n">i</span> <span class="o">+</span> <span class="n">e</span><span class="o">*</span><span class="n">rowmap</span><span class="o">.</span><span class="n">arity</span><span class="p">]</span>
+            <span class="k">for</span> <span class="n">d</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">colmap</span><span class="o">.</span><span class="n">arity</span><span class="p">):</span>
+                <span class="n">diag</span><span class="p">[</span><span class="n">row</span><span class="p">]</span><span class="o">.</span><span class="n">insert</span><span class="p">(</span><span class="n">colmap</span><span class="o">.</span><span class="n">values</span><span class="p">[</span><span class="n">d</span> <span class="o">+</span> <span class="n">e</span> <span class="o">*</span> <span class="n">colmap</span><span class="o">.</span><span class="n">arity</span><span class="p">])</span>
+</pre></div>
+</div>
+<p>For the MPI parallel case a minor modification is required, since for each row
+a set of diagonal and off-diagonal column indices needs to be built as
+described in <a class="reference internal" href="#matrix-storage"><span class="std std-ref">Sparse Matrix Storage Formats</span></a>:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="k">for</span> <span class="n">rowmap</span><span class="p">,</span> <span class="n">colmap</span> <span class="ow">in</span> <span class="n">maps</span><span class="p">:</span>
+    <span class="k">for</span> <span class="n">e</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">rowmap</span><span class="o">.</span><span class="n">from_size</span><span class="p">):</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">rowmap</span><span class="o">.</span><span class="n">arity</span><span class="p">):</span>
+            <span class="n">row</span> <span class="o">=</span> <span class="n">rowmap</span><span class="o">.</span><span class="n">values</span><span class="p">[</span><span class="n">i</span> <span class="o">+</span> <span class="n">e</span><span class="o">*</span><span class="n">rowmap</span><span class="o">.</span><span class="n">arity</span><span class="p">]</span>
+            <span class="k">if</span> <span class="n">row</span> <span class="o">&lt;</span> <span class="n">nrows</span><span class="p">:</span>
+                <span class="k">for</span> <span class="n">d</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">colmap</span><span class="o">.</span><span class="n">arity</span><span class="p">):</span>
+                    <span class="k">if</span> <span class="n">col</span> <span class="o">&lt;</span> <span class="n">ncols</span><span class="p">:</span>
+                        <span class="n">diag</span><span class="p">[</span><span class="n">row</span><span class="p">]</span><span class="o">.</span><span class="n">insert</span><span class="p">(</span><span class="n">colmap</span><span class="o">.</span><span class="n">values</span><span class="p">[</span><span class="n">d</span> <span class="o">+</span> <span class="n">e</span><span class="o">*</span><span class="n">colmap</span><span class="o">.</span><span class="n">arity</span><span class="p">])</span>
+                    <span class="k">else</span><span class="p">:</span>
+                        <span class="n">odiag</span><span class="p">[</span><span class="n">row</span><span class="p">]</span><span class="o">.</span><span class="n">insert</span><span class="p">(</span><span class="n">colmap</span><span class="o">.</span><span class="n">values</span><span class="p">[</span><span class="n">d</span> <span class="o">+</span> <span class="n">e</span><span class="o">*</span><span class="n">colmap</span><span class="o">.</span><span class="n">arity</span><span class="p">])</span>
+</pre></div>
+</div>
+</section>
+<section id="solving-a-linear-system">
+<span id="solving"></span><h2>Solving a linear system<a class="headerlink" href="#solving-a-linear-system" title="Link to this heading">¶</a></h2>
+<p>PyOP2 provides a <code class="xref py py-class docutils literal notranslate"><span class="pre">Solver</span></code>, wrapping the <a class="reference external" href="http://www.mcs.anl.gov/petsc/">PETSc</a> <a class="reference external" href="http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/KSP/">KSP</a> Krylov
+solvers which support various iterative methods such as Conjugate Gradients
+(CG), Generalized Minimal Residual (GMRES), a stabilized version of
+BiConjugate Gradient Squared (BiCGStab) and others. The solvers are
+complemented with a range of preconditioners from <a class="reference external" href="http://www.mcs.anl.gov/petsc/">PETSc</a>’s <a class="reference external" href="http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/PC/">PC</a> collection,
+which includes Jacobi, incomplete Cholesky and LU decompositions and various
+multigrid based preconditioners.</p>
+<p>The choice of solver and preconditioner type and other parameters uses
+<a class="reference external" href="http://www.mcs.anl.gov/petsc/">PETSc</a>’s configuration mechanism documented in the <a class="reference external" href="http://www.mcs.anl.gov/petsc/petsc-dev/docs/manual.pdf">PETSc manual</a>. Options
+are pased to the <code class="xref py py-class docutils literal notranslate"><span class="pre">Solver</span></code> via the keyword argument
+<code class="docutils literal notranslate"><span class="pre">parameters</span></code> taking a dictionary of arguments or directly via keyword
+arguments. The solver type is chosen as <code class="docutils literal notranslate"><span class="pre">ksp_type</span></code>, the preconditioner as
+<code class="docutils literal notranslate"><span class="pre">pc_type</span></code> with the defaults <code class="docutils literal notranslate"><span class="pre">cg</span></code> and <code class="docutils literal notranslate"><span class="pre">jacobi</span></code>.</p>
+<p>Solving a linear system of the matrix <code class="docutils literal notranslate"><span class="pre">A</span></code> assembled above and the right-hand
+side vector <code class="docutils literal notranslate"><span class="pre">b</span></code> for a solution vector <code class="docutils literal notranslate"><span class="pre">x</span></code> is done with a call to
+<code class="xref py py-meth docutils literal notranslate"><span class="pre">solve()</span></code>, where solver and preconditioner are chosen as
+<code class="docutils literal notranslate"><span class="pre">gmres</span></code> and <code class="docutils literal notranslate"><span class="pre">ilu</span></code>:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">x</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Dat</span><span class="p">(</span><span class="n">nodes</span><span class="p">,</span> <span class="n">dtype</span><span class="o">=</span><span class="n">np</span><span class="o">.</span><span class="n">float64</span><span class="p">)</span>
+
+<span class="n">solver</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Solver</span><span class="p">(</span><span class="n">ksp_type</span><span class="o">=</span><span class="s1">&#39;gmres&#39;</span><span class="p">,</span> <span class="n">pc_type</span><span class="o">=</span><span class="s1">&#39;ilu&#39;</span><span class="p">)</span>
+<span class="n">solver</span><span class="o">.</span><span class="n">solve</span><span class="p">(</span><span class="n">A</span><span class="p">,</span> <span class="n">x</span><span class="p">,</span> <span class="n">b</span><span class="p">)</span>
+</pre></div>
+</div>
+</section>
+<section id="gpu-matrix-assembly">
+<span id="gpu-assembly"></span><h2>GPU matrix assembly<a class="headerlink" href="#gpu-matrix-assembly" title="Link to this heading">¶</a></h2>
+<p>In a <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> assembling a <code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code> on the GPU, the
+local contributions are first computed for all elements of the iteration set
+and stored in global memory in a structure-of-arrays (SoA) data layout such
+that all threads can write the data out in a coalesced manner. For the example
+above, the generated CUDA wrapper code is as follows, again omitting
+initialisation and staging code described in <a class="reference internal" href="backends.html#cuda-backend"><span class="std std-ref">CUDA backend</span></a>.  The user
+kernel only computes a single element in the local iteration space as detailed
+in <a class="reference internal" href="kernels.html#local-iteration-spaces"><span class="std std-ref">Local iteration spaces</span></a>.</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="n">__global__</span><span class="w"> </span><span class="kt">void</span><span class="w"> </span><span class="n">__mat_kernel_stub</span><span class="p">(...,</span>
+<span class="w">                                  </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">arg0</span><span class="p">,</span><span class="w">    </span><span class="c1">// local matrix data array</span>
+<span class="w">                                  </span><span class="kt">int</span><span class="w"> </span><span class="n">arg0_offset</span><span class="p">,</span><span class="w"> </span><span class="c1">// offset into the array</span>
+<span class="w">                                  </span><span class="p">...</span><span class="w"> </span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">  </span><span class="p">...</span><span class="w"> </span><span class="c1">// omitted initialisation and shared memory staging code</span>
+<span class="w">  </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">threadIdx</span><span class="p">.</span><span class="n">x</span><span class="p">;</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="n">nelem</span><span class="p">;</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">+=</span><span class="w"> </span><span class="n">blockDim</span><span class="p">.</span><span class="n">x</span><span class="w"> </span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">    </span><span class="p">...</span><span class="w"> </span><span class="c1">// omitted staging code</span>
+<span class="w">    </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">i0</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span><span class="w"> </span><span class="n">i0</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="mi">3</span><span class="p">;</span><span class="w"> </span><span class="o">++</span><span class="n">i0</span><span class="w"> </span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">      </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="w"> </span><span class="kt">int</span><span class="w"> </span><span class="n">i1</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span><span class="w"> </span><span class="n">i1</span><span class="w"> </span><span class="o">&lt;</span><span class="w"> </span><span class="mi">3</span><span class="p">;</span><span class="w"> </span><span class="o">++</span><span class="n">i1</span><span class="w"> </span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">        </span><span class="n">mass_cell_integral_0_otherwise</span><span class="p">(</span>
+<span class="w">          </span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="p">(</span><span class="o">*</span><span class="p">)[</span><span class="mi">1</span><span class="p">])(</span><span class="n">arg0</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">arg0_offset</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">idx</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">9</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">i0</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">3</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">i1</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="mi">1</span><span class="p">),</span>
+<span class="w">          </span><span class="p">...,</span><span class="w"> </span><span class="n">i0</span><span class="p">,</span><span class="w"> </span><span class="n">i1</span><span class="p">);</span>
+<span class="w">      </span><span class="p">}</span>
+<span class="w">    </span><span class="p">}</span>
+<span class="w">  </span><span class="p">}</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+<p>A separate CUDA kernel given below is launched afterwards to compress the data
+into a sparse matrix in CSR storage format. Only the values array needs to be
+computed, since the row pointer and column indices have already been computed
+when building the sparsity on the host and subsequently transferred to GPU
+memory. Memory for the local contributions and the values array only needs to
+be allocated on the GPU.</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="n">__global__</span><span class="w"> </span><span class="kt">void</span><span class="w"> </span><span class="n">__lma_to_csr</span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">lmadata</span><span class="p">,</span><span class="w">  </span><span class="c1">// local matrix data array</span>
+<span class="w">                             </span><span class="kt">double</span><span class="w"> </span><span class="o">*</span><span class="n">csrdata</span><span class="p">,</span><span class="w">  </span><span class="c1">// CSR values array</span>
+<span class="w">                             </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">rowptr</span><span class="p">,</span><span class="w">      </span><span class="c1">// CSR row pointer array</span>
+<span class="w">                             </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">colidx</span><span class="p">,</span><span class="w">      </span><span class="c1">// CSR column indices array</span>
+<span class="w">                             </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">rowmap</span><span class="p">,</span><span class="w">      </span><span class="c1">// row map array</span>
+<span class="w">                             </span><span class="kt">int</span><span class="w"> </span><span class="n">rowmapdim</span><span class="p">,</span><span class="w">    </span><span class="c1">// row map arity</span>
+<span class="w">                             </span><span class="kt">int</span><span class="w"> </span><span class="o">*</span><span class="n">colmap</span><span class="p">,</span><span class="w">      </span><span class="c1">// column map array</span>
+<span class="w">                             </span><span class="kt">int</span><span class="w"> </span><span class="n">colmapdim</span><span class="p">,</span><span class="w">    </span><span class="c1">// column map arity</span>
+<span class="w">                             </span><span class="kt">int</span><span class="w"> </span><span class="n">nelems</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">nentries_per_ele</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">rowmapdim</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">colmapdim</span><span class="p">;</span>
+<span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">n</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">threadIdx</span><span class="p">.</span><span class="n">x</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">blockIdx</span><span class="p">.</span><span class="n">x</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">blockDim</span><span class="p">.</span><span class="n">x</span><span class="p">;</span>
+<span class="w">  </span><span class="k">if</span><span class="w"> </span><span class="p">(</span><span class="w"> </span><span class="n">n</span><span class="w"> </span><span class="o">&gt;=</span><span class="w"> </span><span class="n">nelems</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">nentries_per_ele</span><span class="w"> </span><span class="p">)</span><span class="w"> </span><span class="k">return</span><span class="p">;</span>
+
+<span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">e</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">n</span><span class="w"> </span><span class="o">/</span><span class="w"> </span><span class="n">nentries_per_ele</span><span class="p">;</span><span class="w">                        </span><span class="c1">// set element</span>
+<span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="n">n</span><span class="w"> </span><span class="o">-</span><span class="w"> </span><span class="n">e</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">nentries_per_ele</span><span class="p">)</span><span class="w"> </span><span class="o">/</span><span class="w"> </span><span class="n">rowmapdim</span><span class="p">;</span><span class="w">      </span><span class="c1">// local row</span>
+<span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">j</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="p">(</span><span class="n">n</span><span class="w"> </span><span class="o">-</span><span class="w"> </span><span class="n">e</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">nentries_per_ele</span><span class="w"> </span><span class="o">-</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">colmapdim</span><span class="p">);</span><span class="w">  </span><span class="c1">// local column</span>
+
+<span class="w">  </span><span class="c1">// Compute position in values array</span>
+<span class="w">  </span><span class="kt">int</span><span class="w"> </span><span class="n">offset</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">pos</span><span class="p">(</span><span class="n">rowmap</span><span class="p">[</span><span class="n">e</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">rowmapdim</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">i</span><span class="p">],</span><span class="w"> </span><span class="n">colmap</span><span class="p">[</span><span class="n">e</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">colmapdim</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">j</span><span class="p">],</span>
+<span class="w">                   </span><span class="n">rowptr</span><span class="p">,</span><span class="w"> </span><span class="n">colidx</span><span class="p">);</span>
+<span class="w">  </span><span class="n">__atomic_add</span><span class="p">(</span><span class="n">csrdata</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">offset</span><span class="p">,</span><span class="w"> </span><span class="n">lmadata</span><span class="p">[</span><span class="n">n</span><span class="p">]);</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+</section>
+<section id="gpu-linear-algebra">
+<span id="gpu-solve"></span><h2>GPU linear algebra<a class="headerlink" href="#gpu-linear-algebra" title="Link to this heading">¶</a></h2>
+<p>Linear algebra on the GPU with the <code class="docutils literal notranslate"><span class="pre">cuda</span></code> backend uses the <a class="reference external" href="http://cusplibrary.github.io">Cusp</a> library,
+which does not support all solvers and preconditioners provided by <a class="reference external" href="http://www.mcs.anl.gov/petsc/">PETSc</a>. The
+interface to the user is the same as for the <code class="docutils literal notranslate"><span class="pre">sequential</span></code> and <code class="docutils literal notranslate"><span class="pre">openmp</span></code>
+backends. Supported solver types are CG (<code class="docutils literal notranslate"><span class="pre">cg</span></code>), GMRES (<code class="docutils literal notranslate"><span class="pre">gmres</span></code>) and
+BiCGStab (<code class="docutils literal notranslate"><span class="pre">bicgstab</span></code>), with preconditioners of types Jacobi (<code class="docutils literal notranslate"><span class="pre">jacobi</span></code>),
+Bridson approximate inverse (<code class="docutils literal notranslate"><span class="pre">ainv</span></code>) and asymptotic multigrid (<code class="docutils literal notranslate"><span class="pre">amg</span></code>). An
+exception is raised if an unsupported solver or preconditioner type is
+requested.  A <a class="reference external" href="http://cusplibrary.github.io">Cusp</a> solver with the chosen parameters is automatically
+generated when <code class="xref py py-func docutils literal notranslate"><span class="pre">solve()</span></code> is called.</p>
+<div class="admonition note">
+<p class="admonition-title">Note</p>
+<p>Distributed parallel linear algebra operations with MPI are currently not
+supported by the <code class="docutils literal notranslate"><span class="pre">cuda</span></code> backend.</p>
+</div>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">PyOP2 Linear Algebra Interface</a><ul>
+<li><a class="reference internal" href="#sparse-matrix-storage-formats">Sparse Matrix Storage Formats</a></li>
+<li><a class="reference internal" href="#matrix-assembly">Matrix assembly</a></li>
+<li><a class="reference internal" href="#building-a-sparsity-pattern">Building a sparsity pattern</a></li>
+<li><a class="reference internal" href="#solving-a-linear-system">Solving a linear system</a></li>
+<li><a class="reference internal" href="#gpu-matrix-assembly">GPU matrix assembly</a></li>
+<li><a class="reference internal" href="#gpu-linear-algebra">GPU linear algebra</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="backends.html"
+                          title="previous chapter">PyOP2 Backends</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="plan.html"
+                          title="next chapter">Parallel Execution Plan</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/linear_algebra.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="plan.html" title="Parallel Execution Plan"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="backends.html" title="PyOP2 Backends"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">PyOP2 Linear Algebra Interface</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/mixed.html b/mixed.html
new file mode 100644
index 000000000..622e98203
--- /dev/null
+++ b/mixed.html
@@ -0,0 +1,250 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>Mixed Types &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="MPI" href="mpi.html" />
+    <link rel="prev" title="Parallel Execution Plan" href="plan.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="mpi.html" title="MPI"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="plan.html" title="Parallel Execution Plan"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Mixed Types</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="mixed-types">
+<span id="mixed"></span><h1>Mixed Types<a class="headerlink" href="#mixed-types" title="Link to this heading">¶</a></h1>
+<p>When solving linear systems of equations as they arise for instance in the
+finite-element method (FEM), one is often interested in <em>coupled</em> solutions of
+more than one quantity. In fluid dynamics, a common example is solving a
+coupled system of velocity and pressure as it occurs in some formulations of
+the Navier-Stokes equations.</p>
+<section id="mixed-set-dataset-map-and-dat">
+<h2>Mixed Set, DataSet, Map and Dat<a class="headerlink" href="#mixed-set-dataset-map-and-dat" title="Link to this heading">¶</a></h2>
+<p>PyOP2 provides the mixed types <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedSet</span></code>
+<code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDataSet</span></code>, <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedMap</span></code> and
+<code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code> for a <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code>, <code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code>,
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> and <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> respectively. A mixed type is
+constructed from a list or other iterable of its base type and provides the
+same attributes and methods. Under most circumstances types and mixed types
+behave the same way and can be treated uniformly. Mixed types allow iteration
+over their constituent parts and for convenience the base types are also
+iterable, yielding themselves.</p>
+<p>A <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedSet</span></code> is defined from a list of sets:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">s1</span><span class="p">,</span> <span class="n">s2</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="n">N</span><span class="p">),</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="n">M</span><span class="p">)</span>
+<span class="n">ms</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedSet</span><span class="p">([</span><span class="n">s1</span><span class="p">,</span> <span class="n">s2</span><span class="p">])</span>
+</pre></div>
+</div>
+<p>There are a number of equivalent ways of defining a
+<code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDataSet</span></code>:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">mds</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDataSet</span><span class="p">([</span><span class="n">s1</span><span class="p">,</span> <span class="n">s2</span><span class="p">],</span> <span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="mi">2</span><span class="p">))</span>
+<span class="n">mds</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDataSet</span><span class="p">([</span><span class="n">s1</span><span class="o">**</span><span class="mi">1</span><span class="p">,</span> <span class="n">s2</span><span class="o">**</span><span class="mi">2</span><span class="p">])</span>
+<span class="n">mds</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDataSet</span><span class="p">(</span><span class="n">ms</span><span class="p">,</span> <span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="mi">2</span><span class="p">))</span>
+<span class="n">mds</span> <span class="o">=</span> <span class="n">ms</span><span class="o">**</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="mi">2</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>A <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code> with no associated data is defined in one of the
+following ways:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">md</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDat</span><span class="p">(</span><span class="n">mds</span><span class="p">)</span>
+<span class="n">md</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDat</span><span class="p">([</span><span class="n">s1</span><span class="o">**</span><span class="mi">1</span><span class="p">,</span> <span class="n">s2</span><span class="o">**</span><span class="mi">2</span><span class="p">])</span>
+<span class="n">md</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDat</span><span class="p">([</span><span class="n">op2</span><span class="o">.</span><span class="n">Dat</span><span class="p">(</span><span class="n">s1</span><span class="o">**</span><span class="mi">1</span><span class="p">),</span> <span class="n">op2</span><span class="o">.</span><span class="n">Dat</span><span class="p">(</span><span class="n">s2</span><span class="o">**</span><span class="mi">2</span><span class="p">)])</span>
+</pre></div>
+</div>
+<p>Finally, a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedMap</span></code> is defined from a list of maps, all of
+which must share the same source <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code>:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">it</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="n">S</span><span class="p">)</span>
+<span class="n">mm</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedMap</span><span class="p">([</span><span class="n">op2</span><span class="o">.</span><span class="n">Map</span><span class="p">(</span><span class="n">it</span><span class="p">,</span> <span class="n">s1</span><span class="p">,</span> <span class="mi">2</span><span class="p">),</span> <span class="n">op2</span><span class="o">.</span><span class="n">Map</span><span class="p">(</span><span class="n">it</span><span class="p">,</span> <span class="n">s2</span><span class="p">,</span> <span class="mi">3</span><span class="p">)])</span>
+</pre></div>
+</div>
+</section>
+<section id="block-sparsity-and-mat">
+<h2>Block Sparsity and Mat<a class="headerlink" href="#block-sparsity-and-mat" title="Link to this heading">¶</a></h2>
+<p>When declaring a <code class="xref py py-class docutils literal notranslate"><span class="pre">Sparsity</span></code> on pairs of mixed maps, the
+resulting sparsity pattern has a square block structure with as many block
+rows and columns as there are components in the <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDataSet</span></code>
+forming its row and column space. In the most general case a
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Sparsity</span></code> is constructed as follows:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">it</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="o">...</span><span class="p">)</span>  <span class="c1"># Iteration set</span>
+<span class="n">sr0</span><span class="p">,</span> <span class="n">sr1</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="o">...</span><span class="p">),</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="o">...</span><span class="p">)</span>  <span class="c1"># Sets for row spaces</span>
+<span class="n">sc0</span><span class="p">,</span> <span class="n">sc1</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="o">...</span><span class="p">),</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="o">...</span><span class="p">)</span>  <span class="c1"># Sets for column spaces</span>
+<span class="c1"># MixedMaps for the row and column spaces</span>
+<span class="n">mr</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedMap</span><span class="p">([</span><span class="n">op2</span><span class="o">.</span><span class="n">Map</span><span class="p">(</span><span class="n">it</span><span class="p">,</span> <span class="n">sr0</span><span class="p">,</span> <span class="o">...</span><span class="p">),</span> <span class="n">op2</span><span class="o">.</span><span class="n">Map</span><span class="p">(</span><span class="n">it</span><span class="p">,</span> <span class="n">sr1</span><span class="p">,</span> <span class="o">...</span><span class="p">)])</span>
+<span class="n">mc</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedMap</span><span class="p">([</span><span class="n">op2</span><span class="o">.</span><span class="n">Map</span><span class="p">(</span><span class="n">it</span><span class="p">,</span> <span class="n">sc0</span><span class="p">,</span> <span class="o">...</span><span class="p">),</span> <span class="n">op2</span><span class="o">.</span><span class="n">Map</span><span class="p">(</span><span class="n">it</span><span class="p">,</span> <span class="n">sc1</span><span class="p">,</span> <span class="o">...</span><span class="p">)])</span>
+<span class="c1"># MixedDataSets for the row and column spaces</span>
+<span class="n">dsr</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDataSet</span><span class="p">([</span><span class="n">sr0</span><span class="o">**</span><span class="mi">1</span><span class="p">,</span> <span class="n">sr1</span><span class="o">**</span><span class="mi">1</span><span class="p">])</span>
+<span class="n">dsc</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDataSet</span><span class="p">([</span><span class="n">sc0</span><span class="o">**</span><span class="mi">1</span><span class="p">,</span> <span class="n">sc1</span><span class="o">**</span><span class="mi">1</span><span class="p">])</span>
+<span class="c1"># Blocked sparsity</span>
+<span class="n">sparsity</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Sparsity</span><span class="p">((</span><span class="n">dsr</span><span class="p">,</span> <span class="n">dsc</span><span class="p">),</span> <span class="p">[(</span><span class="n">mr</span><span class="p">,</span> <span class="n">mc</span><span class="p">),</span> <span class="o">...</span><span class="p">])</span>
+</pre></div>
+</div>
+<p>The relationships of each component of the mixed maps and datasets to the
+blocks of the <code class="xref py py-class docutils literal notranslate"><span class="pre">Sparsity</span></code> is shown in the following diagram:</p>
+<figure class="align-center" id="id1">
+<img alt="_images/mixed_sparsity.svg" src="_images/mixed_sparsity.svg" /><figcaption>
+<p><span class="caption-text">The contribution of sets, maps and datasets to the blocked sparsity.</span><a class="headerlink" href="#id1" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+<p>Block sparsity patterns are computed separately for each block as described in
+<a class="reference internal" href="linear_algebra.html#sparsity-pattern"><span class="std std-ref">Building a sparsity pattern</span></a> and the same validity rules apply. A
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code> defined on a block <code class="xref py py-class docutils literal notranslate"><span class="pre">Sparsity</span></code> has the same
+block structure, which is implemented using a <a class="reference external" href="http://www.mcs.anl.gov/petsc/">PETSc</a> <a class="reference external" href="http://www.mcs.anl.gov/petsc/petsc-current/docs/manualpages/Mat/MATNEST.html">MATNEST</a>.</p>
+</section>
+<section id="mixed-assembly">
+<h2>Mixed Assembly<a class="headerlink" href="#mixed-assembly" title="Link to this heading">¶</a></h2>
+<p>When assembling into a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code> or a block
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code>, the <code class="xref py py-class docutils literal notranslate"><span class="pre">Kernel</span></code> produces a local tensor of the
+same block structure, which is a combination of <a class="reference internal" href="kernels.html#local-iteration-spaces"><span class="std std-ref">Local iteration spaces</span></a>
+of all its subblocks. This is entirely transparent to the kernel however,
+which sees the combined local iteration space.  PyOP2 ensures that indirectly
+accessed data is gathered and scattered via the correct maps and packed
+together into a contiguous vector to be passed to the kernel. Contributions
+from the local tensor are assembled into the correct blocks of the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code> or <code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code>.</p>
+<p>Consider the following example <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> assembling a block
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code>:</p>
+<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="n">it</span><span class="p">,</span> <span class="n">cells</span><span class="p">,</span> <span class="n">nodes</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="o">...</span><span class="p">),</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="o">...</span><span class="p">),</span> <span class="n">op2</span><span class="o">.</span><span class="n">Set</span><span class="p">(</span><span class="o">...</span><span class="p">)</span>
+<span class="n">mds</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDataSet</span><span class="p">([</span><span class="n">nodes</span><span class="p">,</span> <span class="n">cells</span><span class="p">])</span>
+<span class="n">mmap</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedMap</span><span class="p">([</span><span class="n">op2</span><span class="o">.</span><span class="n">Map</span><span class="p">(</span><span class="n">it</span><span class="p">,</span> <span class="n">nodes</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="o">...</span><span class="p">),</span> <span class="n">op2</span><span class="o">.</span><span class="n">Map</span><span class="p">(</span><span class="n">it</span><span class="p">,</span> <span class="n">cells</span><span class="p">,</span> <span class="mi">1</span><span class="p">,</span> <span class="o">...</span><span class="p">)])</span>
+<span class="n">mat</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">Mat</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">Sparsity</span><span class="p">(</span><span class="n">mds</span><span class="p">,</span> <span class="n">mmap</span><span class="p">))</span>
+<span class="n">d</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDat</span><span class="p">(</span><span class="n">mds</span><span class="p">)</span>
+
+<span class="n">op2</span><span class="o">.</span><span class="n">par_loop</span><span class="p">(</span><span class="n">kernel</span><span class="p">,</span> <span class="n">it</span><span class="p">,</span>
+             <span class="n">mat</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">INC</span><span class="p">,</span> <span class="p">(</span><span class="n">mmap</span><span class="p">[</span><span class="n">op2</span><span class="o">.</span><span class="n">i</span><span class="p">[</span><span class="mi">0</span><span class="p">]],</span> <span class="n">mmap</span><span class="p">[</span><span class="n">op2</span><span class="o">.</span><span class="n">i</span><span class="p">[</span><span class="mi">1</span><span class="p">]])),</span>
+             <span class="n">d</span><span class="p">(</span><span class="n">op2</span><span class="o">.</span><span class="n">read</span><span class="p">,</span> <span class="n">mmap</span><span class="p">))</span>
+</pre></div>
+</div>
+<p>The <code class="docutils literal notranslate"><span class="pre">kernel</span></code> for this <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> assembles a 3x3 local tensor
+and is passed an input vector of length 3 for each iteration set element:</p>
+<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="kt">void</span><span class="w"> </span><span class="nf">kernel</span><span class="p">(</span><span class="kt">double</span><span class="w"> </span><span class="n">v</span><span class="p">[</span><span class="mi">3</span><span class="p">][</span><span class="mi">3</span><span class="p">]</span><span class="w"> </span><span class="p">,</span><span class="w"> </span><span class="kt">double</span><span class="w"> </span><span class="o">**</span><span class="n">d</span><span class="w"> </span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
+<span class="w">  </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span><span class="w"> </span><span class="n">i</span><span class="o">&lt;</span><span class="mi">3</span><span class="p">;</span><span class="w"> </span><span class="n">i</span><span class="o">++</span><span class="p">)</span>
+<span class="w">    </span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="kt">int</span><span class="w"> </span><span class="n">j</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">0</span><span class="p">;</span><span class="w"> </span><span class="n">j</span><span class="o">&lt;</span><span class="mi">3</span><span class="p">;</span><span class="w"> </span><span class="n">j</span><span class="o">++</span><span class="p">)</span>
+<span class="w">      </span><span class="n">v</span><span class="p">[</span><span class="n">i</span><span class="p">][</span><span class="n">j</span><span class="p">]</span><span class="w"> </span><span class="o">+=</span><span class="w"> </span><span class="n">d</span><span class="p">[</span><span class="n">i</span><span class="p">][</span><span class="mi">0</span><span class="p">]</span><span class="w"> </span><span class="o">*</span><span class="w"> </span><span class="n">d</span><span class="p">[</span><span class="n">j</span><span class="p">][</span><span class="mi">0</span><span class="p">];</span>
+<span class="p">}</span>
+</pre></div>
+</div>
+<p>The top-left 2x2 block of the local tensor is assembled into the (0,0) block
+of the matrix, the top-right 2x1 block into (0,1), the bottom-left 1x2 block
+into (1,0) and finally the bottom-right 1x1 block into (1,1). Note that for
+the (0,0) block only the first component of the <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code> is
+read and for the (1,1) block only the second component. For the (0,1) and
+(1,0) blocks, both components of the <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code> are accessed.</p>
+<p>This diagram illustrates the assembly of the block <code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code>:</p>
+<figure class="align-center" id="id2">
+<img alt="_images/mixed_assembly.svg" src="_images/mixed_assembly.svg" /><figcaption>
+<p><span class="caption-text">Assembling into the blocks of a global matrix <span class="math">A</span>: block
+<span class="math">A^{0,0}</span> uses maps <span class="math">\iota^{1,0}</span> and <span class="math">\iota^{2,0}</span>,
+<span class="math">A^{0,1}</span> uses <span class="math">\iota^{1,0}</span> and <span class="math">\iota^{2,1}</span>,
+<span class="math">A^{1,0}</span> uses <span class="math">\iota^{1,1}</span> and <span class="math">\iota^{2,0}</span> and finally
+<span class="math">A^{1,1}</span> uses <span class="math">\iota^{1,1}</span> and <span class="math">\iota^{2,1}</span> for the row
+and column spaces respectively.</span><a class="headerlink" href="#id2" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">Mixed Types</a><ul>
+<li><a class="reference internal" href="#mixed-set-dataset-map-and-dat">Mixed Set, DataSet, Map and Dat</a></li>
+<li><a class="reference internal" href="#block-sparsity-and-mat">Block Sparsity and Mat</a></li>
+<li><a class="reference internal" href="#mixed-assembly">Mixed Assembly</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="plan.html"
+                          title="previous chapter">Parallel Execution Plan</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="mpi.html"
+                          title="next chapter">MPI</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/mixed.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="mpi.html" title="MPI"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="plan.html" title="Parallel Execution Plan"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Mixed Types</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/mpi.html b/mpi.html
new file mode 100644
index 000000000..d86ea37d4
--- /dev/null
+++ b/mpi.html
@@ -0,0 +1,234 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>MPI &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="Caching in PyOP2" href="caching.html" />
+    <link rel="prev" title="Mixed Types" href="mixed.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="caching.html" title="Caching in PyOP2"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="mixed.html" title="Mixed Types"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">MPI</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="mpi">
+<span id="id1"></span><h1>MPI<a class="headerlink" href="#mpi" title="Link to this heading">¶</a></h1>
+<p>Distributed parallel computations with MPI in PyOP2 require the mesh to be
+partitioned among the processors. To be able to compute over entities on their
+boundaries, partitions need to access data owned by neighboring processors.
+This region, called the <em>halo</em>, needs to be kept up to date and is therefore
+exchanged between the processors as required.</p>
+<section id="local-numbering">
+<h2>Local Numbering<a class="headerlink" href="#local-numbering" title="Link to this heading">¶</a></h2>
+<p>The partition of each <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> local to each process consists of
+entities <em>owned</em> by the process and the <em>halo</em>, which are entities owned by
+other processes but required to compute on the boundary of the owned entities.
+Each of these sections is again divided into two sections required to
+efficiently overlap communication and computation and avoid communication
+during matrix assembly as described below. Each locally stored
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> entitity therefore belongs to one of four categories:</p>
+<ul class="simple">
+<li><p><strong>Core</strong>: Entities owned by this processor which can be processed without
+accessing halo data.</p></li>
+<li><p><strong>Owned</strong>: Entities owned by this processor which access halo data when
+processed.</p></li>
+<li><p><strong>Exec halo</strong>: Off-processor entities which are redundantly executed over
+because they touch owned entities.</p></li>
+<li><p><strong>Non-exec halo</strong>: Off-processor entities which are not processed, but read
+when computing the exec halo.</p></li>
+</ul>
+<p>The following diagram illustrates the four sections for a mesh distributed
+among two processors:</p>
+<figure class="align-center" id="id2">
+<img alt="_images/pyop2_mpi_mesh.svg" src="_images/pyop2_mpi_mesh.svg" /><figcaption>
+<p><span class="caption-text">A mesh distributed among two processors with the entities of each mesh
+partition divided into <em>core</em>, <em>owned</em>, <em>exec halo</em> and <em>non-exec halo</em>.
+Matching halo sections are highlighted in matching colours. The owned
+section of process 0 correspondonds to the non-exec section of process 1.</span><a class="headerlink" href="#id2" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+<p>For data defined on the <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> to be stored contiguously per
+section, local <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> entities must be numbered such that core
+entities are first, followed by owned, exec halo and non-exec halo in that
+order. A good partitioning maximises the size of the core section and
+minimises the halo regions. We can therefore assume that the vast majority of
+local <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> entities are in the core section.</p>
+</section>
+<section id="computation-communication-overlap">
+<h2>Computation-communication Overlap<a class="headerlink" href="#computation-communication-overlap" title="Link to this heading">¶</a></h2>
+<p>The ordering of <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> entities into four sections allow for a
+very efficient overlap of computation and communication. Core entities that do
+not access any halo data can be processed entirely without access to halo data
+immediately after the halo exchange has been initiated. Execution over the
+owned and exec halo regions requires up to date halo data and can only start
+once the halo exchange is completed.  Depending on the latency and bandwidth
+of communication and the size of the core section relative to the halo, the
+halo exchange may complete before the computation on the core section.</p>
+<p>The entire process is given below:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">halo_exchange_begin</span><span class="p">()</span>                      <span class="c1"># Initiate halo exchange</span>
+<span class="n">maybe_set_dat_dirty</span><span class="p">()</span>                      <span class="c1"># Mark Dats as modified</span>
+<span class="n">compute_if_not_empty</span><span class="p">(</span><span class="n">itset</span><span class="o">.</span><span class="n">core_part</span><span class="p">)</span>      <span class="c1"># Compute core region</span>
+<span class="n">halo_exchange_end</span><span class="p">()</span>                        <span class="c1"># Wait for halo exchange</span>
+<span class="n">compute_if_not_empty</span><span class="p">(</span><span class="n">itset</span><span class="o">.</span><span class="n">owned_part</span><span class="p">)</span>     <span class="c1"># Compute owned region</span>
+<span class="n">reduction_begin</span><span class="p">()</span>                          <span class="c1"># Initiate reductions</span>
+<span class="k">if</span> <span class="n">needs_exec_halo</span><span class="p">:</span>                        <span class="c1"># Any indirect Dat not READ?</span>
+    <span class="n">compute_if_not_empty</span><span class="p">(</span><span class="n">itset</span><span class="o">.</span><span class="n">exec_part</span><span class="p">)</span>  <span class="c1"># Compute exec halo region</span>
+<span class="n">reduction_end</span><span class="p">()</span>                            <span class="c1"># Wait for reductions</span>
+<span class="n">maybe_set_halo_update_needed</span><span class="p">()</span>             <span class="c1"># Mark halos as out of date</span>
+<span class="n">assemble</span><span class="p">()</span>                                 <span class="c1"># Finalise matrix assembly</span>
+</pre></div>
+</div>
+<p>Any reductions depend on data from the core and owned sections and are
+initiated as soon as the owned section has been processed and execute
+concurrently with computation on the exec halo. Similar to
+<cite>halo_exchange_begin</cite> and <cite>halo_exchange_end</cite>, <cite>reduction_begin</cite> and
+<cite>reduction_end</cite> do no work at all if none of the <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>
+arguments requires a reduction. If the <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> assembles a
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code>, the matrix assembly is finalised at the end.</p>
+<p>By dividing entities into sections according to their relation to the halo,
+there is no need to check whether or not a given entity touches the halo or
+not during computations on each section. This avoids branching in kernels or
+wrapper code and allows launching separate kernels for GPU execution of each
+section. The <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code> execution therefore has the above
+structure for all backends.</p>
+</section>
+<section id="halo-exchange">
+<h2>Halo exchange<a class="headerlink" href="#halo-exchange" title="Link to this heading">¶</a></h2>
+<p>Exchanging halo data is only required if the halo data is actually read, which
+is the case for <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> arguments to a <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>
+used in <code class="xref py py-data docutils literal notranslate"><span class="pre">pyop2.READ</span></code> or <code class="xref py py-data docutils literal notranslate"><span class="pre">pyop2.RW</span></code> mode.  PyOP2 keeps track
+whether or not the halo region may have been modified. This is the case for
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Dats</span></code> used in <code class="xref py py-data docutils literal notranslate"><span class="pre">pyop2.INC</span></code>, <code class="xref py py-data docutils literal notranslate"><span class="pre">pyop2.WRITE</span></code> or
+<code class="xref py py-data docutils literal notranslate"><span class="pre">pyop2.RW</span></code> mode or when a <code class="xref py py-class docutils literal notranslate"><span class="pre">Solver</span></code> or a user requests
+access to the data. A halo exchange is triggered only for halos marked as out
+of date.</p>
+</section>
+<section id="distributed-assembly">
+<h2>Distributed Assembly<a class="headerlink" href="#distributed-assembly" title="Link to this heading">¶</a></h2>
+<p>For an MPI distributed matrix or vector, assembling owned entities at the
+boundary can contribute to off-process degrees of freedom and vice versa.</p>
+<p>There are different ways of accounting for these off-process contributions.
+<a class="reference external" href="http://www.mcs.anl.gov/petsc/">PETSc</a> supports insertion and subsequent communication of off-process matrix
+and vector entries, however its implementation is not thread safe. Concurrent
+insertion into <a class="reference external" href="http://www.mcs.anl.gov/petsc/">PETSc</a> MPI matrices <em>is</em> thread safe if off-process insertions
+are not cached and concurrent writes to rows are avoided, which is done
+through colouring as described in <a class="reference internal" href="plan.html#plan-colouring"><span class="std std-ref">Colouring</span></a>.</p>
+<p>PyOP2 therefore disables <a class="reference external" href="http://www.mcs.anl.gov/petsc/">PETSc</a>’s off-process insertion feature and instead
+redundantly computes over all off process entities that touch local dofs,
+which is the <em>exec halo</em> section described above. The price for this is
+maintaining a larger halo, since we also need halo data, the <em>non-exec halo</em>
+section, to perform the redundant computation. Halos grow by about a factor
+two, however in practice this is still small compared to the interior region
+of a partition and the main cost of halo exchange is the latency, which is
+independent of the exchanged data volume.</p>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">MPI</a><ul>
+<li><a class="reference internal" href="#local-numbering">Local Numbering</a></li>
+<li><a class="reference internal" href="#computation-communication-overlap">Computation-communication Overlap</a></li>
+<li><a class="reference internal" href="#halo-exchange">Halo exchange</a></li>
+<li><a class="reference internal" href="#distributed-assembly">Distributed Assembly</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="mixed.html"
+                          title="previous chapter">Mixed Types</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="caching.html"
+                          title="next chapter">Caching in PyOP2</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/mpi.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="caching.html" title="Caching in PyOP2"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="mixed.html" title="Mixed Types"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">MPI</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/objects.inv b/objects.inv
new file mode 100644
index 000000000..4f3717994
Binary files /dev/null and b/objects.inv differ
diff --git a/plan.html b/plan.html
new file mode 100644
index 000000000..bbcac2487
--- /dev/null
+++ b/plan.html
@@ -0,0 +1,187 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>Parallel Execution Plan &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="Mixed Types" href="mixed.html" />
+    <link rel="prev" title="PyOP2 Linear Algebra Interface" href="linear_algebra.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="mixed.html" title="Mixed Types"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="linear_algebra.html" title="PyOP2 Linear Algebra Interface"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Parallel Execution Plan</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="parallel-execution-plan">
+<span id="plan"></span><h1>Parallel Execution Plan<a class="headerlink" href="#parallel-execution-plan" title="Link to this heading">¶</a></h1>
+<p>For all PyOP2 backends with the exception of sequential, a parallel execution
+plan is computed for each <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>. It contains information
+guiding the code generator on how to partition, stage and colour the data for
+efficient parallel processing.</p>
+<section id="partitioning">
+<span id="plan-partitioning"></span><h2>Partitioning<a class="headerlink" href="#partitioning" title="Link to this heading">¶</a></h2>
+<p>The iteration set is split into a number of equally sized and contiguous
+mini-partitions such that the working set of each mini-partition fits into
+shared memory or last level cache. This is unrelated to the partitioning
+required for MPI as described in <a class="reference internal" href="mpi.html#mpi"><span class="std std-ref">MPI</span></a>.</p>
+</section>
+<section id="local-renumbering-and-staging">
+<span id="plan-renumbering"></span><h2>Local Renumbering and Staging<a class="headerlink" href="#local-renumbering-and-staging" title="Link to this heading">¶</a></h2>
+<p>While a mini-partition is a contiguous chunk of the iteration set, the
+indirectly accessed data it references is not necessarily contiguous. For each
+mini-partition and unique <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>-<code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> pair, a
+mapping from local indices within the partition to global indices is
+constructed as the sorted array of unique <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> indices accessed
+by this partition. At the same time, a global-to-local mapping is constructed
+as its inverse.</p>
+<p>Data for indirectly accessed <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> arguments is staged in shared
+device memory as described in <a class="reference internal" href="backends.html#backends"><span class="std std-ref">PyOP2 Backends</span></a>. For each partition, the
+local-to-global mapping indicates where data to be staged in is read from and
+the global-to-local mapping gives the location in shared memory data has been
+staged at. The amount of shared memory required is computed from the size of
+the local-to-global mapping.</p>
+</section>
+<section id="colouring">
+<span id="plan-colouring"></span><h2>Colouring<a class="headerlink" href="#colouring" title="Link to this heading">¶</a></h2>
+<p>A two-level colouring is used to avoid race conditions. Partitions are
+coloured such that partitions of the same colour can be executed concurrently
+and threads executing on a partition in parallel are coloured such that no two
+threads indirectly reference the same data. Only <code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>
+arguments performing an indirect reduction or assembling a matrix require
+colouring. Matrices are coloured per row.</p>
+<p>For each element of a <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> indirectly accessed in a
+<code class="xref py py-func docutils literal notranslate"><span class="pre">par_loop()</span></code>, a bit vector is used to record which colours
+indirectly reference it. To colour each thread within a partition, the
+algorithm proceeds as follows:</p>
+<ol class="arabic simple">
+<li><p>Loop over all indirectly accessed arguments and collect the colours of all
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> elements referenced by the current thread in a bit mask.</p></li>
+<li><p>Choose the next available colour as the colour of the current thread.</p></li>
+<li><p>Loop over all <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> elements indirectly accessed by the
+current thread again and set the new colour in their colour mask.</p></li>
+</ol>
+<p>Since the bit mask is a 32-bit integer, up to 32 colours can be processed in a
+single pass, which is sufficient for most applications. If not all threads can
+be coloured with 32 distinct colours, the mask is reset and another pass is
+made, where each newly allocated colour is offset by 32. Should another pass
+be required, the offset is increased to 64 and so on until all threads are
+coloured.</p>
+<figure class="align-center" id="id1">
+<img alt="_images/pyop2_colouring.svg" src="_images/pyop2_colouring.svg" /><figcaption>
+<p><span class="caption-text">Thread colouring within a mini-partition for a <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> on
+vertices indirectly accessed in a computation over the edges. The edges are
+coloured such that no two edges touch the same vertex within the partition.</span><a class="headerlink" href="#id1" title="Link to this image">¶</a></p>
+</figcaption>
+</figure>
+<p>The colouring of mini-partitions is done in the same way, except that all
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> elements indirectly accessed by the entire partition are
+referenced, not only those accessed by a single thread.</p>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">Parallel Execution Plan</a><ul>
+<li><a class="reference internal" href="#partitioning">Partitioning</a></li>
+<li><a class="reference internal" href="#local-renumbering-and-staging">Local Renumbering and Staging</a></li>
+<li><a class="reference internal" href="#colouring">Colouring</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="linear_algebra.html"
+                          title="previous chapter">PyOP2 Linear Algebra Interface</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="mixed.html"
+                          title="next chapter">Mixed Types</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/plan.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="mixed.html" title="Mixed Types"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="linear_algebra.html" title="PyOP2 Linear Algebra Interface"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Parallel Execution Plan</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/profiling.html b/profiling.html
new file mode 100644
index 000000000..044fa9709
--- /dev/null
+++ b/profiling.html
@@ -0,0 +1,287 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>Profiling &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="pyop2 user documentation" href="user.html" />
+    <link rel="prev" title="Caching in PyOP2" href="caching.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="user.html" title="pyop2 user documentation"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="caching.html" title="Caching in PyOP2"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Profiling</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="profiling">
+<h1>Profiling<a class="headerlink" href="#profiling" title="Link to this heading">¶</a></h1>
+<section id="profiling-pyop2-programs">
+<h2>Profiling PyOP2 programs<a class="headerlink" href="#profiling-pyop2-programs" title="Link to this heading">¶</a></h2>
+<p>Profiling a PyOP2 program is as simple as profiling any other Python
+code. You can profile the jacobi demo in the PyOP2 <code class="docutils literal notranslate"><span class="pre">demo</span></code> folder as
+follows:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">python</span> <span class="o">-</span><span class="n">m</span> <span class="n">cProfile</span> <span class="o">-</span><span class="n">o</span> <span class="n">jacobi</span><span class="o">.</span><span class="n">dat</span> <span class="n">jacobi</span><span class="o">.</span><span class="n">py</span>
+</pre></div>
+</div>
+<p>This will run the entire program under <a class="reference external" href="https://docs.python.org/2/library/profile.html#cProfile">cProfile</a> and write the profiling
+data to <code class="docutils literal notranslate"><span class="pre">jacobi.dat</span></code>. Omitting <code class="docutils literal notranslate"><span class="pre">-o</span></code> will print a summary to stdout,
+which is not very helpful in most cases.</p>
+<section id="creating-a-graph">
+<h3>Creating a graph<a class="headerlink" href="#creating-a-graph" title="Link to this heading">¶</a></h3>
+<p>There is a much more intuitive way of representing the profiling data
+using the excellent <a class="reference external" href="https://code.google.com/p/jrfonseca/wiki/Gprof2Dot">gprof2dot</a> to generate a graph. Install from <a class="reference external" href="http://pypi.python.org/pypi/gprof2dot/">PyPI</a> with</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">sudo</span> <span class="n">pip</span> <span class="n">install</span> <span class="n">gprof2dot</span>
+</pre></div>
+</div>
+<p>Use as follows to create a PDF:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">gprof2dot</span> <span class="o">-</span><span class="n">f</span> <span class="n">pstats</span> <span class="o">-</span><span class="n">n</span> <span class="mi">1</span> <span class="n">jacobi</span><span class="o">.</span><span class="n">dat</span> <span class="o">|</span> <span class="n">dot</span> <span class="o">-</span><span class="n">Tpdf</span> <span class="o">-</span><span class="n">o</span> <span class="n">jacobi</span><span class="o">.</span><span class="n">pdf</span>
+</pre></div>
+</div>
+<p><code class="docutils literal notranslate"><span class="pre">-f</span> <span class="pre">pstats</span></code> tells <code class="docutils literal notranslate"><span class="pre">gprof2dot</span></code> that it is dealing with Python
+<a class="reference external" href="https://docs.python.org/2/library/profile.html#cProfile">cProfile</a> data (and not actual <em>gprof</em> data) and <code class="docutils literal notranslate"><span class="pre">-n</span> <span class="pre">1</span></code> ignores
+everything that makes up less than 1% of the total runtime - most likely
+you are not interested in that (the default is 0.5).</p>
+</section>
+<section id="consolidating-profiles-from-different-runs">
+<h3>Consolidating profiles from different runs<a class="headerlink" href="#consolidating-profiles-from-different-runs" title="Link to this heading">¶</a></h3>
+<p>To aggregate profiling data from different runs, save the following as
+<code class="docutils literal notranslate"><span class="pre">concat.py</span></code>:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="sd">&quot;&quot;&quot;Usage: concat.py PATTERN FILE&quot;&quot;&quot;</span>
+
+<span class="kn">import</span> <span class="nn">sys</span>
+<span class="kn">from</span> <span class="nn">glob</span> <span class="kn">import</span> <span class="n">glob</span>
+<span class="kn">from</span> <span class="nn">pstats</span> <span class="kn">import</span> <span class="n">Stats</span>
+
+<span class="k">if</span> <span class="nb">len</span><span class="p">(</span><span class="n">sys</span><span class="o">.</span><span class="n">argv</span><span class="p">)</span> <span class="o">!=</span> <span class="mi">3</span><span class="p">:</span>
+    <span class="nb">print</span> <span class="vm">__doc__</span>
+    <span class="n">sys</span><span class="o">.</span><span class="n">exit</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span>
+<span class="n">files</span> <span class="o">=</span> <span class="n">glob</span><span class="p">(</span><span class="n">sys</span><span class="o">.</span><span class="n">argv</span><span class="p">[</span><span class="mi">1</span><span class="p">])</span>
+<span class="n">s</span> <span class="o">=</span> <span class="n">Stats</span><span class="p">(</span><span class="n">files</span><span class="p">[</span><span class="mi">0</span><span class="p">])</span>
+<span class="k">for</span> <span class="n">f</span> <span class="ow">in</span> <span class="n">files</span><span class="p">[</span><span class="mi">1</span><span class="p">:]:</span> <span class="n">s</span><span class="o">.</span><span class="n">add</span><span class="p">(</span><span class="n">f</span><span class="p">)</span>
+<span class="n">s</span><span class="o">.</span><span class="n">dump_stats</span><span class="p">(</span><span class="n">sys</span><span class="o">.</span><span class="n">argv</span><span class="p">[</span><span class="mi">2</span><span class="p">])</span>
+</pre></div>
+</div>
+<p>With profiles from different runs named <code class="docutils literal notranslate"><span class="pre">&lt;basename&gt;.*.part</span></code>, use it
+as</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">python</span> <span class="n">concat</span><span class="o">.</span><span class="n">py</span> <span class="s1">&#39;&lt;basename&gt;.*.part&#39;</span> <span class="o">&lt;</span><span class="n">basename</span><span class="o">&gt;.</span><span class="n">dat</span>
+</pre></div>
+</div>
+<p>and then call <code class="docutils literal notranslate"><span class="pre">gprof2dot</span></code> as before.</p>
+</section>
+</section>
+<section id="using-pyop2-s-internal-timers">
+<h2>Using PyOP2’s internal timers<a class="headerlink" href="#using-pyop2-s-internal-timers" title="Link to this heading">¶</a></h2>
+<p>PyOP2 automatically times the execution of certain regions:</p>
+<ul class="simple">
+<li><p>Sparsity building</p></li>
+<li><p>Plan construction</p></li>
+<li><p>Parallel loop kernel execution</p></li>
+<li><p>Halo exchange</p></li>
+<li><p>Reductions</p></li>
+<li><p>PETSc Krylov solver</p></li>
+</ul>
+<p>To output those timings, call <code class="xref py py-func docutils literal notranslate"><span class="pre">summary()</span></code> in your
+PyOP2 program or run with the environment variable
+<code class="docutils literal notranslate"><span class="pre">PYOP2_PRINT_SUMMARY</span></code> set to 1.</p>
+<p>To query e.g. the timer for parallel loop execution programatically,
+use the <code class="xref py py-func docutils literal notranslate"><span class="pre">timing()</span></code> helper:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="kn">from</span> <span class="nn">pyop2</span> <span class="kn">import</span> <span class="n">timing</span>
+<span class="n">timing</span><span class="p">(</span><span class="s2">&quot;ParLoop compute&quot;</span><span class="p">)</span>               <span class="c1"># get total time</span>
+<span class="n">timing</span><span class="p">(</span><span class="s2">&quot;ParLoop compute&quot;</span><span class="p">,</span> <span class="n">total</span><span class="o">=</span><span class="kc">False</span><span class="p">)</span>  <span class="c1"># get average time per call</span>
+</pre></div>
+</div>
+<p>To add additional timers to your own code, you can use the
+<a class="reference internal" href="pyop2.html#pyop2.profiling.timed_region" title="pyop2.profiling.timed_region"><code class="xref py py-func docutils literal notranslate"><span class="pre">timed_region()</span></code></a> and
+<a class="reference internal" href="pyop2.html#pyop2.profiling.timed_function" title="pyop2.profiling.timed_function"><code class="xref py py-func docutils literal notranslate"><span class="pre">timed_function()</span></code></a> helpers:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="kn">from</span> <span class="nn">pyop2.profiling</span> <span class="kn">import</span> <span class="n">timed_region</span><span class="p">,</span> <span class="n">timed_function</span>
+
+<span class="k">with</span> <span class="n">timed_region</span><span class="p">(</span><span class="s2">&quot;my code&quot;</span><span class="p">):</span>
+    <span class="c1"># my code</span>
+
+<span class="nd">@timed_function</span><span class="p">(</span><span class="s2">&quot;my function&quot;</span><span class="p">)</span>
+<span class="k">def</span> <span class="nf">my_func</span><span class="p">():</span>
+    <span class="c1"># my func</span>
+</pre></div>
+</div>
+</section>
+<section id="line-by-line-profiling">
+<h2>Line-by-line profiling<a class="headerlink" href="#line-by-line-profiling" title="Link to this heading">¶</a></h2>
+<p>To get a line-by-line profile of a given function, install Robert Kern’s
+<a class="reference external" href="https://pythonhosted.org/line_profiler/">line profiler</a> and:</p>
+<ol class="arabic">
+<li><p>Import the <code class="xref py py-func docutils literal notranslate"><span class="pre">profile()</span></code> decorator:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="kn">from</span> <span class="nn">pyop2.profiling</span> <span class="kn">import</span> <span class="n">profile</span>
+</pre></div>
+</div>
+</li>
+<li><p>Decorate the function to profile with <code class="docutils literal notranslate"><span class="pre">&#64;profile</span></code></p></li>
+<li><p>Run your script with <code class="docutils literal notranslate"><span class="pre">kernprof.py</span> <span class="pre">-l</span> <span class="pre">&lt;script.py&gt;</span></code></p></li>
+<li><p>Generate an annotated source file with</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">python</span> <span class="o">-</span><span class="n">m</span> <span class="n">line_profiler</span> <span class="o">&lt;</span><span class="n">script</span><span class="o">.</span><span class="n">py</span><span class="o">.</span><span class="n">lprof</span><span class="o">&gt;</span>
+</pre></div>
+</div>
+</li>
+</ol>
+<p>Note that <code class="docutils literal notranslate"><span class="pre">kernprof.py</span></code> injects the <code class="docutils literal notranslate"><span class="pre">&#64;profile</span></code> decorator into the
+Python builtins namespace. PyOP2 provides a passthrough version of this
+decorator which does nothing if <code class="docutils literal notranslate"><span class="pre">profile</span></code> is not found in
+<code class="docutils literal notranslate"><span class="pre">__builtins__</span></code>. This means you can run your script regularly without
+having to remove the decorators again.</p>
+<p>The <code class="xref py py-func docutils literal notranslate"><span class="pre">profile()</span></code> decorator also works with the
+memory profiler (see below). PyOP2 therefore provides the
+<code class="xref py py-func docutils literal notranslate"><span class="pre">lineprof()</span></code> decorator which is only enabled when
+running with <code class="docutils literal notranslate"><span class="pre">kernprof.py</span></code>.</p>
+<p>A number of PyOP2 internal functions are decorated such that running
+your PyOP2 application with <code class="docutils literal notranslate"><span class="pre">kernprof.py</span></code> will produce a line-by-line
+profile of the parallel loop computation (but not the generated code!).</p>
+</section>
+<section id="memory-profiling">
+<h2>Memory profiling<a class="headerlink" href="#memory-profiling" title="Link to this heading">¶</a></h2>
+<p>To profile the memory usage of your application, install Fabian
+Pedregosa’s <a class="reference external" href="https://github.com/fabianp/memory_profiler">memory profiler</a> and:</p>
+<ol class="arabic">
+<li><p>Import the <code class="xref py py-func docutils literal notranslate"><span class="pre">profile()</span></code> decorator:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="kn">from</span> <span class="nn">pyop2.profiling</span> <span class="kn">import</span> <span class="n">profile</span>
+</pre></div>
+</div>
+</li>
+<li><p>Decorate the function to profile with <code class="docutils literal notranslate"><span class="pre">&#64;profile</span></code>.</p></li>
+<li><p>Run your script with</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">python</span> <span class="o">-</span><span class="n">m</span> <span class="n">memory_profiler</span> <span class="o">&lt;</span><span class="n">script</span><span class="o">.</span><span class="n">py</span><span class="o">&gt;</span>
+</pre></div>
+</div>
+<p>to get a line-by-line memory profile of your function.</p>
+</li>
+<li><p>Run your script with</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">memprof</span> <span class="n">run</span> <span class="o">--</span><span class="n">python</span> <span class="o">&lt;</span><span class="n">script</span><span class="o">.</span><span class="n">py</span><span class="o">&gt;</span>
+</pre></div>
+</div>
+<p>to record memory usage of your program over time.</p>
+</li>
+<li><p>Generate a plot of the memory profile with <code class="docutils literal notranslate"><span class="pre">memprof</span> <span class="pre">plot</span></code>.</p></li>
+</ol>
+<p>Note that <code class="docutils literal notranslate"><span class="pre">memprof</span></code> and <code class="docutils literal notranslate"><span class="pre">python</span> <span class="pre">-m</span> <span class="pre">memory_profiler</span></code> inject the
+<code class="docutils literal notranslate"><span class="pre">&#64;profile</span></code> decorator into the Python builtins namespace. PyOP2
+provides a passthrough version of this decorator which does nothing if
+<code class="docutils literal notranslate"><span class="pre">profile</span></code> is not found in <code class="docutils literal notranslate"><span class="pre">__builtins__</span></code>. This means you can run
+your script regularly without having to remove the decorators again.</p>
+<p>The <code class="xref py py-func docutils literal notranslate"><span class="pre">profile()</span></code> decorator also works with the line
+profiler (see below). PyOP2 therefore provides the
+<code class="xref py py-func docutils literal notranslate"><span class="pre">memprof()</span></code> decorator which is only enabled when
+running with <code class="docutils literal notranslate"><span class="pre">memprof</span></code>.</p>
+<p>A number of PyOP2 internal functions are decorated such that running
+your PyOP2 application with <code class="docutils literal notranslate"><span class="pre">memprof</span> <span class="pre">run</span></code> will produce a memory
+profile of the parallel loop computation (but not the generated code!).</p>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">Profiling</a><ul>
+<li><a class="reference internal" href="#profiling-pyop2-programs">Profiling PyOP2 programs</a><ul>
+<li><a class="reference internal" href="#creating-a-graph">Creating a graph</a></li>
+<li><a class="reference internal" href="#consolidating-profiles-from-different-runs">Consolidating profiles from different runs</a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#using-pyop2-s-internal-timers">Using PyOP2’s internal timers</a></li>
+<li><a class="reference internal" href="#line-by-line-profiling">Line-by-line profiling</a></li>
+<li><a class="reference internal" href="#memory-profiling">Memory profiling</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="caching.html"
+                          title="previous chapter">Caching in PyOP2</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="user.html"
+                          title="next chapter">pyop2 user documentation</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/profiling.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="user.html" title="pyop2 user documentation"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="caching.html" title="Caching in PyOP2"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Profiling</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/py-modindex.html b/py-modindex.html
new file mode 100644
index 000000000..df1671940
--- /dev/null
+++ b/py-modindex.html
@@ -0,0 +1,173 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
+    <title>Python Module Index &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+ 
+
+
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="#" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Python Module Index</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+
+   <h1>Python Module Index</h1>
+
+   <div class="modindex-jumpbox">
+   <a href="#cap-p"><strong>p</strong></a>
+   </div>
+
+   <table class="indextable modindextable">
+     <tr class="pcap"><td></td><td>&#160;</td><td></td></tr>
+     <tr class="cap" id="cap-p"><td></td><td>
+       <strong>p</strong></td><td></td></tr>
+     <tr>
+       <td><img src="_static/minus.png" class="toggler"
+              id="toggle-1" style="display: none" alt="-" /></td>
+       <td>
+       <code class="xref">pyop2</code></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.html#module-pyop2.configuration"><code class="xref">pyop2.configuration</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.html#module-pyop2.datatypes"><code class="xref">pyop2.datatypes</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.html#module-pyop2.exceptions"><code class="xref">pyop2.exceptions</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.html#module-pyop2.logger"><code class="xref">pyop2.logger</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.html#module-pyop2.mpi"><code class="xref">pyop2.mpi</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.html#module-pyop2.profiling"><code class="xref">pyop2.profiling</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.types.html#module-pyop2.types.access"><code class="xref">pyop2.types.access</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.types.html#module-pyop2.types.dat"><code class="xref">pyop2.types.dat</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.types.html#module-pyop2.types.data_carrier"><code class="xref">pyop2.types.data_carrier</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.types.html#module-pyop2.types.dataset"><code class="xref">pyop2.types.dataset</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.types.html#module-pyop2.types.glob"><code class="xref">pyop2.types.glob</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.types.html#module-pyop2.types.halo"><code class="xref">pyop2.types.halo</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.types.html#module-pyop2.types.map"><code class="xref">pyop2.types.map</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.types.html#module-pyop2.types.set"><code class="xref">pyop2.types.set</code></a></td><td>
+       <em></em></td></tr>
+     <tr class="cg-1">
+       <td></td>
+       <td>&#160;&#160;&#160;
+       <a href="pyop2.html#module-pyop2.utils"><code class="xref">pyop2.utils</code></a></td><td>
+       <em></em></td></tr>
+   </table>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="#" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Python Module Index</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/pyop2.codegen.html b/pyop2.codegen.html
new file mode 100644
index 000000000..ce87878cb
--- /dev/null
+++ b/pyop2.codegen.html
@@ -0,0 +1,155 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>pyop2.codegen package &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="pyop2.types package" href="pyop2.types.html" />
+    <link rel="prev" title="pyop2 package" href="pyop2.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="pyop2.types.html" title="pyop2.types package"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="pyop2.html" title="pyop2 package"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+          <li class="nav-item nav-item-1"><a href="pyop2.html" accesskey="U">pyop2 package</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">pyop2.codegen package</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="pyop2-codegen-package">
+<h1>pyop2.codegen package<a class="headerlink" href="#pyop2-codegen-package" title="Link to this heading">¶</a></h1>
+<section id="submodules">
+<h2>Submodules<a class="headerlink" href="#submodules" title="Link to this heading">¶</a></h2>
+</section>
+<section id="pyop2-codegen-builder-module">
+<h2>pyop2.codegen.builder module<a class="headerlink" href="#pyop2-codegen-builder-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="pyop2-codegen-loopycompat-module">
+<h2>pyop2.codegen.loopycompat module<a class="headerlink" href="#pyop2-codegen-loopycompat-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="pyop2-codegen-node-module">
+<h2>pyop2.codegen.node module<a class="headerlink" href="#pyop2-codegen-node-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="pyop2-codegen-optimise-module">
+<h2>pyop2.codegen.optimise module<a class="headerlink" href="#pyop2-codegen-optimise-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="pyop2-codegen-rep2loopy-module">
+<h2>pyop2.codegen.rep2loopy module<a class="headerlink" href="#pyop2-codegen-rep2loopy-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="pyop2-codegen-representation-module">
+<h2>pyop2.codegen.representation module<a class="headerlink" href="#pyop2-codegen-representation-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="module-contents">
+<h2>Module contents<a class="headerlink" href="#module-contents" title="Link to this heading">¶</a></h2>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">pyop2.codegen package</a><ul>
+<li><a class="reference internal" href="#submodules">Submodules</a></li>
+<li><a class="reference internal" href="#pyop2-codegen-builder-module">pyop2.codegen.builder module</a></li>
+<li><a class="reference internal" href="#pyop2-codegen-loopycompat-module">pyop2.codegen.loopycompat module</a></li>
+<li><a class="reference internal" href="#pyop2-codegen-node-module">pyop2.codegen.node module</a></li>
+<li><a class="reference internal" href="#pyop2-codegen-optimise-module">pyop2.codegen.optimise module</a></li>
+<li><a class="reference internal" href="#pyop2-codegen-rep2loopy-module">pyop2.codegen.rep2loopy module</a></li>
+<li><a class="reference internal" href="#pyop2-codegen-representation-module">pyop2.codegen.representation module</a></li>
+<li><a class="reference internal" href="#module-contents">Module contents</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="pyop2.html"
+                          title="previous chapter">pyop2 package</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="pyop2.types.html"
+                          title="next chapter">pyop2.types package</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/pyop2.codegen.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="pyop2.types.html" title="pyop2.types package"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="pyop2.html" title="pyop2 package"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+          <li class="nav-item nav-item-1"><a href="pyop2.html" >pyop2 package</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">pyop2.codegen package</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/pyop2.html b/pyop2.html
new file mode 100644
index 000000000..16d585745
--- /dev/null
+++ b/pyop2.html
@@ -0,0 +1,1160 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>pyop2 package &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="pyop2.codegen package" href="pyop2.codegen.html" />
+    <link rel="prev" title="pyop2 user documentation" href="user.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="pyop2.codegen.html" title="pyop2.codegen package"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="user.html" title="pyop2 user documentation"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">pyop2 package</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="pyop2-package">
+<h1>pyop2 package<a class="headerlink" href="#pyop2-package" title="Link to this heading">¶</a></h1>
+<section id="subpackages">
+<h2>Subpackages<a class="headerlink" href="#subpackages" title="Link to this heading">¶</a></h2>
+<div class="toctree-wrapper compound">
+<ul>
+<li class="toctree-l1"><a class="reference internal" href="pyop2.codegen.html">pyop2.codegen package</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.codegen.html#submodules">Submodules</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.codegen.html#pyop2-codegen-builder-module">pyop2.codegen.builder module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.codegen.html#pyop2-codegen-loopycompat-module">pyop2.codegen.loopycompat module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.codegen.html#pyop2-codegen-node-module">pyop2.codegen.node module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.codegen.html#pyop2-codegen-optimise-module">pyop2.codegen.optimise module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.codegen.html#pyop2-codegen-rep2loopy-module">pyop2.codegen.rep2loopy module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.codegen.html#pyop2-codegen-representation-module">pyop2.codegen.representation module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.codegen.html#module-contents">Module contents</a></li>
+</ul>
+</li>
+<li class="toctree-l1"><a class="reference internal" href="pyop2.types.html">pyop2.types package</a><ul>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.types.html#submodules">Submodules</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.types.html#module-pyop2.types.access">pyop2.types.access module</a><ul>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.Access"><code class="docutils literal notranslate"><span class="pre">Access</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.Access.READ"><code class="docutils literal notranslate"><span class="pre">Access.READ</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.Access.WRITE"><code class="docutils literal notranslate"><span class="pre">Access.WRITE</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.Access.RW"><code class="docutils literal notranslate"><span class="pre">Access.RW</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.Access.INC"><code class="docutils literal notranslate"><span class="pre">Access.INC</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.Access.MIN"><code class="docutils literal notranslate"><span class="pre">Access.MIN</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.Access.MAX"><code class="docutils literal notranslate"><span class="pre">Access.MAX</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.READ"><code class="docutils literal notranslate"><span class="pre">READ</span></code></a></li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.WRITE"><code class="docutils literal notranslate"><span class="pre">WRITE</span></code></a></li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.RW"><code class="docutils literal notranslate"><span class="pre">RW</span></code></a></li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.INC"><code class="docutils literal notranslate"><span class="pre">INC</span></code></a></li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.MIN"><code class="docutils literal notranslate"><span class="pre">MIN</span></code></a></li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.access.MAX"><code class="docutils literal notranslate"><span class="pre">MAX</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.types.html#module-pyop2.types.dat">pyop2.types.dat module</a><ul>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat"><code class="docutils literal notranslate"><span class="pre">AbstractDat</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.split"><code class="docutils literal notranslate"><span class="pre">AbstractDat.split</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.dataset"><code class="docutils literal notranslate"><span class="pre">AbstractDat.dataset</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.dim"><code class="docutils literal notranslate"><span class="pre">AbstractDat.dim</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.cdim"><code class="docutils literal notranslate"><span class="pre">AbstractDat.cdim</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.data"><code class="docutils literal notranslate"><span class="pre">AbstractDat.data</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.data_with_halos"><code class="docutils literal notranslate"><span class="pre">AbstractDat.data_with_halos</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.data_ro"><code class="docutils literal notranslate"><span class="pre">AbstractDat.data_ro</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.data_ro_with_halos"><code class="docutils literal notranslate"><span class="pre">AbstractDat.data_ro_with_halos</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.data_wo"><code class="docutils literal notranslate"><span class="pre">AbstractDat.data_wo</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.data_wo_with_halos"><code class="docutils literal notranslate"><span class="pre">AbstractDat.data_wo_with_halos</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.save"><code class="docutils literal notranslate"><span class="pre">AbstractDat.save()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.load"><code class="docutils literal notranslate"><span class="pre">AbstractDat.load()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.shape"><code class="docutils literal notranslate"><span class="pre">AbstractDat.shape</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.dtype"><code class="docutils literal notranslate"><span class="pre">AbstractDat.dtype</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.nbytes"><code class="docutils literal notranslate"><span class="pre">AbstractDat.nbytes</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.zero"><code class="docutils literal notranslate"><span class="pre">AbstractDat.zero()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.copy"><code class="docutils literal notranslate"><span class="pre">AbstractDat.copy()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.inner"><code class="docutils literal notranslate"><span class="pre">AbstractDat.inner()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.norm"><code class="docutils literal notranslate"><span class="pre">AbstractDat.norm</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.global_to_local_begin"><code class="docutils literal notranslate"><span class="pre">AbstractDat.global_to_local_begin()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.global_to_local_end"><code class="docutils literal notranslate"><span class="pre">AbstractDat.global_to_local_end()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.local_to_global_begin"><code class="docutils literal notranslate"><span class="pre">AbstractDat.local_to_global_begin()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.local_to_global_end"><code class="docutils literal notranslate"><span class="pre">AbstractDat.local_to_global_end()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.frozen_halo"><code class="docutils literal notranslate"><span class="pre">AbstractDat.frozen_halo()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.freeze_halo"><code class="docutils literal notranslate"><span class="pre">AbstractDat.freeze_halo()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.AbstractDat.unfreeze_halo"><code class="docutils literal notranslate"><span class="pre">AbstractDat.unfreeze_halo()</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.DatView"><code class="docutils literal notranslate"><span class="pre">DatView</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.DatView.cdim"><code class="docutils literal notranslate"><span class="pre">DatView.cdim</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.DatView.dim"><code class="docutils literal notranslate"><span class="pre">DatView.dim</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.DatView.shape"><code class="docutils literal notranslate"><span class="pre">DatView.shape</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.DatView.halo_valid"><code class="docutils literal notranslate"><span class="pre">DatView.halo_valid</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.DatView.data"><code class="docutils literal notranslate"><span class="pre">DatView.data</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.DatView.data_ro"><code class="docutils literal notranslate"><span class="pre">DatView.data_ro</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.DatView.data_wo"><code class="docutils literal notranslate"><span class="pre">DatView.data_wo</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.DatView.data_with_halos"><code class="docutils literal notranslate"><span class="pre">DatView.data_with_halos</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.DatView.data_ro_with_halos"><code class="docutils literal notranslate"><span class="pre">DatView.data_ro_with_halos</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.DatView.data_wo_with_halos"><code class="docutils literal notranslate"><span class="pre">DatView.data_wo_with_halos</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.Dat"><code class="docutils literal notranslate"><span class="pre">Dat</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.Dat.vec_context"><code class="docutils literal notranslate"><span class="pre">Dat.vec_context()</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat"><code class="docutils literal notranslate"><span class="pre">MixedDat</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.dat_version"><code class="docutils literal notranslate"><span class="pre">MixedDat.dat_version</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.increment_dat_version"><code class="docutils literal notranslate"><span class="pre">MixedDat.increment_dat_version()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.dtype"><code class="docutils literal notranslate"><span class="pre">MixedDat.dtype</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.split"><code class="docutils literal notranslate"><span class="pre">MixedDat.split</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.dataset"><code class="docutils literal notranslate"><span class="pre">MixedDat.dataset</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.data"><code class="docutils literal notranslate"><span class="pre">MixedDat.data</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.data_with_halos"><code class="docutils literal notranslate"><span class="pre">MixedDat.data_with_halos</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.data_ro"><code class="docutils literal notranslate"><span class="pre">MixedDat.data_ro</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.data_ro_with_halos"><code class="docutils literal notranslate"><span class="pre">MixedDat.data_ro_with_halos</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.data_wo"><code class="docutils literal notranslate"><span class="pre">MixedDat.data_wo</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.data_wo_with_halos"><code class="docutils literal notranslate"><span class="pre">MixedDat.data_wo_with_halos</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.halo_valid"><code class="docutils literal notranslate"><span class="pre">MixedDat.halo_valid</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.global_to_local_begin"><code class="docutils literal notranslate"><span class="pre">MixedDat.global_to_local_begin()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.global_to_local_end"><code class="docutils literal notranslate"><span class="pre">MixedDat.global_to_local_end()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.local_to_global_begin"><code class="docutils literal notranslate"><span class="pre">MixedDat.local_to_global_begin()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.local_to_global_end"><code class="docutils literal notranslate"><span class="pre">MixedDat.local_to_global_end()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.freeze_halo"><code class="docutils literal notranslate"><span class="pre">MixedDat.freeze_halo()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.unfreeze_halo"><code class="docutils literal notranslate"><span class="pre">MixedDat.unfreeze_halo()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.zero"><code class="docutils literal notranslate"><span class="pre">MixedDat.zero()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.nbytes"><code class="docutils literal notranslate"><span class="pre">MixedDat.nbytes</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.copy"><code class="docutils literal notranslate"><span class="pre">MixedDat.copy()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.inner"><code class="docutils literal notranslate"><span class="pre">MixedDat.inner()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.MixedDat.vec_context"><code class="docutils literal notranslate"><span class="pre">MixedDat.vec_context()</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.dat.frozen_halo"><code class="docutils literal notranslate"><span class="pre">frozen_halo</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.types.html#module-pyop2.types.data_carrier">pyop2.types.data_carrier module</a><ul>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier"><code class="docutils literal notranslate"><span class="pre">DataCarrier</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier.dtype"><code class="docutils literal notranslate"><span class="pre">DataCarrier.dtype</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier.ctype"><code class="docutils literal notranslate"><span class="pre">DataCarrier.ctype</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier.name"><code class="docutils literal notranslate"><span class="pre">DataCarrier.name</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier.dim"><code class="docutils literal notranslate"><span class="pre">DataCarrier.dim</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier.cdim"><code class="docutils literal notranslate"><span class="pre">DataCarrier.cdim</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.DataCarrier.increment_dat_version"><code class="docutils literal notranslate"><span class="pre">DataCarrier.increment_dat_version()</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.EmptyDataMixin"><code class="docutils literal notranslate"><span class="pre">EmptyDataMixin</span></code></a></li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.VecAccessMixin"><code class="docutils literal notranslate"><span class="pre">VecAccessMixin</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.VecAccessMixin.dat_version"><code class="docutils literal notranslate"><span class="pre">VecAccessMixin.dat_version</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.VecAccessMixin.vec_context"><code class="docutils literal notranslate"><span class="pre">VecAccessMixin.vec_context()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.VecAccessMixin.vec"><code class="docutils literal notranslate"><span class="pre">VecAccessMixin.vec</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.VecAccessMixin.vec_wo"><code class="docutils literal notranslate"><span class="pre">VecAccessMixin.vec_wo</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.data_carrier.VecAccessMixin.vec_ro"><code class="docutils literal notranslate"><span class="pre">VecAccessMixin.vec_ro</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.types.html#module-pyop2.types.dataset">pyop2.types.dataset module</a><ul>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.DataSet"><code class="docutils literal notranslate"><span class="pre">DataSet</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.DataSet.dim"><code class="docutils literal notranslate"><span class="pre">DataSet.dim</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.DataSet.cdim"><code class="docutils literal notranslate"><span class="pre">DataSet.cdim</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.DataSet.name"><code class="docutils literal notranslate"><span class="pre">DataSet.name</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.DataSet.set"><code class="docutils literal notranslate"><span class="pre">DataSet.set</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.DataSet.lgmap"><code class="docutils literal notranslate"><span class="pre">DataSet.lgmap</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.DataSet.scalar_lgmap"><code class="docutils literal notranslate"><span class="pre">DataSet.scalar_lgmap</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.DataSet.unblocked_lgmap"><code class="docutils literal notranslate"><span class="pre">DataSet.unblocked_lgmap</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.DataSet.field_ises"><code class="docutils literal notranslate"><span class="pre">DataSet.field_ises</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.DataSet.local_ises"><code class="docutils literal notranslate"><span class="pre">DataSet.local_ises</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.DataSet.layout_vec"><code class="docutils literal notranslate"><span class="pre">DataSet.layout_vec</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.DataSet.dm"><code class="docutils literal notranslate"><span class="pre">DataSet.dm</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.dim"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.dim</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.cdim"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.cdim</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.name"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.name</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.set"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.set</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.size"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.size</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.lgmap"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.lgmap</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.unblocked_lgmap"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.unblocked_lgmap</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.local_ises"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.local_ises</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.layout_vec"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.layout_vec</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.GlobalDataSet.dm"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.dm</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.MixedDataSet"><code class="docutils literal notranslate"><span class="pre">MixedDataSet</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.split"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.split</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.dim"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.dim</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.cdim"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.cdim</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.name"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.name</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.set"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.set</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.layout_vec"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.layout_vec</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.lgmap"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.lgmap</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.dataset.MixedDataSet.unblocked_lgmap"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.unblocked_lgmap</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.types.html#module-pyop2.types.glob">pyop2.types.glob module</a><ul>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.shape"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.shape</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.dtype"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.dtype</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.data_ro"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.data_ro</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.data_wo"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.data_wo</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.data"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.data</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.data_with_halos"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.data_with_halos</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.data_ro_with_halos"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.data_ro_with_halos</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.data_wo_with_halos"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.data_wo_with_halos</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.halo_valid"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.halo_valid</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.copy"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.copy()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.split"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.split</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.nbytes"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.nbytes</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.SetFreeDataCarrier.inner"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.inner()</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Global"><code class="docutils literal notranslate"><span class="pre">Global</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Global.dataset"><code class="docutils literal notranslate"><span class="pre">Global.dataset</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Global.duplicate"><code class="docutils literal notranslate"><span class="pre">Global.duplicate()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Global.zero"><code class="docutils literal notranslate"><span class="pre">Global.zero()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Global.global_to_local_begin"><code class="docutils literal notranslate"><span class="pre">Global.global_to_local_begin()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Global.global_to_local_end"><code class="docutils literal notranslate"><span class="pre">Global.global_to_local_end()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Global.local_to_global_begin"><code class="docutils literal notranslate"><span class="pre">Global.local_to_global_begin()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Global.local_to_global_end"><code class="docutils literal notranslate"><span class="pre">Global.local_to_global_end()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Global.frozen_halo"><code class="docutils literal notranslate"><span class="pre">Global.frozen_halo()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Global.freeze_halo"><code class="docutils literal notranslate"><span class="pre">Global.freeze_halo()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Global.unfreeze_halo"><code class="docutils literal notranslate"><span class="pre">Global.unfreeze_halo()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Global.vec_context"><code class="docutils literal notranslate"><span class="pre">Global.vec_context()</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Constant"><code class="docutils literal notranslate"><span class="pre">Constant</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.glob.Constant.duplicate"><code class="docutils literal notranslate"><span class="pre">Constant.duplicate()</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.types.html#module-pyop2.types.halo">pyop2.types.halo module</a><ul>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.halo.Halo"><code class="docutils literal notranslate"><span class="pre">Halo</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.halo.Halo.comm"><code class="docutils literal notranslate"><span class="pre">Halo.comm</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.halo.Halo.local_to_global_numbering"><code class="docutils literal notranslate"><span class="pre">Halo.local_to_global_numbering</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.halo.Halo.global_to_local_begin"><code class="docutils literal notranslate"><span class="pre">Halo.global_to_local_begin()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.halo.Halo.global_to_local_end"><code class="docutils literal notranslate"><span class="pre">Halo.global_to_local_end()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.halo.Halo.local_to_global_begin"><code class="docutils literal notranslate"><span class="pre">Halo.local_to_global_begin()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.halo.Halo.local_to_global_end"><code class="docutils literal notranslate"><span class="pre">Halo.local_to_global_end()</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.types.html#module-pyop2.types.map">pyop2.types.map module</a><ul>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map"><code class="docutils literal notranslate"><span class="pre">Map</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.dtype"><code class="docutils literal notranslate"><span class="pre">Map.dtype</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.split"><code class="docutils literal notranslate"><span class="pre">Map.split</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.iterset"><code class="docutils literal notranslate"><span class="pre">Map.iterset</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.toset"><code class="docutils literal notranslate"><span class="pre">Map.toset</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.arity"><code class="docutils literal notranslate"><span class="pre">Map.arity</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.arities"><code class="docutils literal notranslate"><span class="pre">Map.arities</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.arange"><code class="docutils literal notranslate"><span class="pre">Map.arange</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.values"><code class="docutils literal notranslate"><span class="pre">Map.values</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.values_with_halo"><code class="docutils literal notranslate"><span class="pre">Map.values_with_halo</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.name"><code class="docutils literal notranslate"><span class="pre">Map.name</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.offset"><code class="docutils literal notranslate"><span class="pre">Map.offset</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.offset_quotient"><code class="docutils literal notranslate"><span class="pre">Map.offset_quotient</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.Map.flattened_maps"><code class="docutils literal notranslate"><span class="pre">Map.flattened_maps</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.PermutedMap"><code class="docutils literal notranslate"><span class="pre">PermutedMap</span></code></a></li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.ComposedMap"><code class="docutils literal notranslate"><span class="pre">ComposedMap</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.ComposedMap.values"><code class="docutils literal notranslate"><span class="pre">ComposedMap.values</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.ComposedMap.values_with_halo"><code class="docutils literal notranslate"><span class="pre">ComposedMap.values_with_halo</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.ComposedMap.flattened_maps"><code class="docutils literal notranslate"><span class="pre">ComposedMap.flattened_maps</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap"><code class="docutils literal notranslate"><span class="pre">MixedMap</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap.split"><code class="docutils literal notranslate"><span class="pre">MixedMap.split</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap.iterset"><code class="docutils literal notranslate"><span class="pre">MixedMap.iterset</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap.toset"><code class="docutils literal notranslate"><span class="pre">MixedMap.toset</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap.arity"><code class="docutils literal notranslate"><span class="pre">MixedMap.arity</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap.arities"><code class="docutils literal notranslate"><span class="pre">MixedMap.arities</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap.arange"><code class="docutils literal notranslate"><span class="pre">MixedMap.arange</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap.values"><code class="docutils literal notranslate"><span class="pre">MixedMap.values</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap.values_with_halo"><code class="docutils literal notranslate"><span class="pre">MixedMap.values_with_halo</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap.name"><code class="docutils literal notranslate"><span class="pre">MixedMap.name</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap.offset"><code class="docutils literal notranslate"><span class="pre">MixedMap.offset</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap.offset_quotient"><code class="docutils literal notranslate"><span class="pre">MixedMap.offset_quotient</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.map.MixedMap.flattened_maps"><code class="docutils literal notranslate"><span class="pre">MixedMap.flattened_maps</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.types.html#pyop2-types-mat-module">pyop2.types.mat module</a></li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.types.html#module-pyop2.types.set">pyop2.types.set module</a><ul>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set"><code class="docutils literal notranslate"><span class="pre">Set</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.core_size"><code class="docutils literal notranslate"><span class="pre">Set.core_size</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.size"><code class="docutils literal notranslate"><span class="pre">Set.size</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.total_size"><code class="docutils literal notranslate"><span class="pre">Set.total_size</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.sizes"><code class="docutils literal notranslate"><span class="pre">Set.sizes</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.core_part"><code class="docutils literal notranslate"><span class="pre">Set.core_part</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.owned_part"><code class="docutils literal notranslate"><span class="pre">Set.owned_part</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.name"><code class="docutils literal notranslate"><span class="pre">Set.name</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.halo"><code class="docutils literal notranslate"><span class="pre">Set.halo</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.partition_size"><code class="docutils literal notranslate"><span class="pre">Set.partition_size</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.layers"><code class="docutils literal notranslate"><span class="pre">Set.layers</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.intersection"><code class="docutils literal notranslate"><span class="pre">Set.intersection()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.union"><code class="docutils literal notranslate"><span class="pre">Set.union()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.difference"><code class="docutils literal notranslate"><span class="pre">Set.difference()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Set.symmetric_difference"><code class="docutils literal notranslate"><span class="pre">Set.symmetric_difference()</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.GlobalSet"><code class="docutils literal notranslate"><span class="pre">GlobalSet</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.GlobalSet.core_size"><code class="docutils literal notranslate"><span class="pre">GlobalSet.core_size</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.GlobalSet.size"><code class="docutils literal notranslate"><span class="pre">GlobalSet.size</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.GlobalSet.total_size"><code class="docutils literal notranslate"><span class="pre">GlobalSet.total_size</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.GlobalSet.sizes"><code class="docutils literal notranslate"><span class="pre">GlobalSet.sizes</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.GlobalSet.name"><code class="docutils literal notranslate"><span class="pre">GlobalSet.name</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.GlobalSet.halo"><code class="docutils literal notranslate"><span class="pre">GlobalSet.halo</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.GlobalSet.partition_size"><code class="docutils literal notranslate"><span class="pre">GlobalSet.partition_size</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.ExtrudedSet"><code class="docutils literal notranslate"><span class="pre">ExtrudedSet</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.ExtrudedSet.parent"><code class="docutils literal notranslate"><span class="pre">ExtrudedSet.parent</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.ExtrudedSet.layers"><code class="docutils literal notranslate"><span class="pre">ExtrudedSet.layers</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.ExtrudedSet.layers_array"><code class="docutils literal notranslate"><span class="pre">ExtrudedSet.layers_array</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Subset"><code class="docutils literal notranslate"><span class="pre">Subset</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Subset.superset"><code class="docutils literal notranslate"><span class="pre">Subset.superset</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Subset.indices"><code class="docutils literal notranslate"><span class="pre">Subset.indices</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Subset.owned_indices"><code class="docutils literal notranslate"><span class="pre">Subset.owned_indices</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Subset.layers_array"><code class="docutils literal notranslate"><span class="pre">Subset.layers_array</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Subset.intersection"><code class="docutils literal notranslate"><span class="pre">Subset.intersection()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Subset.union"><code class="docutils literal notranslate"><span class="pre">Subset.union()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Subset.difference"><code class="docutils literal notranslate"><span class="pre">Subset.difference()</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.Subset.symmetric_difference"><code class="docutils literal notranslate"><span class="pre">Subset.symmetric_difference()</span></code></a></li>
+</ul>
+</li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.SetPartition"><code class="docutils literal notranslate"><span class="pre">SetPartition</span></code></a></li>
+<li class="toctree-l3"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.MixedSet"><code class="docutils literal notranslate"><span class="pre">MixedSet</span></code></a><ul>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.MixedSet.split"><code class="docutils literal notranslate"><span class="pre">MixedSet.split</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.MixedSet.core_size"><code class="docutils literal notranslate"><span class="pre">MixedSet.core_size</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.MixedSet.size"><code class="docutils literal notranslate"><span class="pre">MixedSet.size</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.MixedSet.total_size"><code class="docutils literal notranslate"><span class="pre">MixedSet.total_size</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.MixedSet.sizes"><code class="docutils literal notranslate"><span class="pre">MixedSet.sizes</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.MixedSet.name"><code class="docutils literal notranslate"><span class="pre">MixedSet.name</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.MixedSet.halo"><code class="docutils literal notranslate"><span class="pre">MixedSet.halo</span></code></a></li>
+<li class="toctree-l4"><a class="reference internal" href="pyop2.types.html#pyop2.types.set.MixedSet.layers"><code class="docutils literal notranslate"><span class="pre">MixedSet.layers</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li class="toctree-l2"><a class="reference internal" href="pyop2.types.html#module-contents">Module contents</a></li>
+</ul>
+</li>
+</ul>
+</div>
+</section>
+<section id="submodules">
+<h2>Submodules<a class="headerlink" href="#submodules" title="Link to this heading">¶</a></h2>
+</section>
+<section id="pyop2-caching-module">
+<h2>pyop2.caching module<a class="headerlink" href="#pyop2-caching-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="pyop2-compilation-module">
+<h2>pyop2.compilation module<a class="headerlink" href="#pyop2-compilation-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="module-pyop2.configuration">
+<span id="pyop2-configuration-module"></span><h2>pyop2.configuration module<a class="headerlink" href="#module-pyop2.configuration" title="Link to this heading">¶</a></h2>
+<p>PyOP2 global configuration.</p>
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.configuration.Configuration">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.configuration.</span></span><span class="sig-name descname"><span class="pre">Configuration</span></span><a class="headerlink" href="#pyop2.configuration.Configuration" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">dict</span></code></p>
+<p>PyOP2 configuration parameters</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>cc</strong> – C compiler (executable name eg: <cite>gcc</cite>
+or path eg: <cite>/opt/gcc/bin/gcc</cite>).</p></li>
+<li><p><strong>cxx</strong> – C++ compiler (executable name eg: <cite>g++</cite>
+or path eg: <cite>/opt/gcc/bin/g++</cite>).</p></li>
+<li><p><strong>ld</strong> – Linker (executable name <cite>ld</cite>
+or path eg: <cite>/opt/gcc/bin/ld</cite>).</p></li>
+<li><p><strong>cflags</strong> – extra flags to be passed to the C compiler.</p></li>
+<li><p><strong>cxxflags</strong> – extra flags to be passed to the C++ compiler.</p></li>
+<li><p><strong>ldflags</strong> – extra flags to be passed to the linker.</p></li>
+<li><p><strong>simd_width</strong> – number of doubles in SIMD instructions
+(e.g. 4 for AVX2, 8 for AVX512).</p></li>
+<li><p><strong>debug</strong> – Turn on debugging for generated code (turns off
+compiler optimisations).</p></li>
+<li><p><strong>type_check</strong> – Should PyOP2 type-check API-calls?  (Default,
+yes)</p></li>
+<li><p><strong>check_src_hashes</strong> – Should PyOP2 check that generated code is
+the same on all processes?  (Default, yes).  Uses an allreduce.</p></li>
+<li><p><strong>cache_dir</strong> – Where should generated code be cached?</p></li>
+<li><p><strong>node_local_compilation</strong> – <p>Should generated code by compiled
+“node-local” (one process for each set of processes that share</p>
+<blockquote>
+<div><p>a filesystem)?  You should probably arrange to set cache_dir
+to a node-local filesystem too.</p>
+</div></blockquote>
+</p></li>
+<li><p><strong>log_level</strong> – How chatty should PyOP2 be?  Valid values
+are “DEBUG”, “INFO”, “WARNING”, “ERROR”, “CRITICAL”.</p></li>
+<li><p><strong>print_cache_size</strong> – Should PyOP2 print the size of caches at
+program exit?</p></li>
+<li><p><strong>matnest</strong> – Should matrices on mixed maps be built as nests? (Default yes)</p></li>
+<li><p><strong>block_sparsity</strong> – Should sparsity patterns on datasets with
+cdim &gt; 1 be built as block sparsities, or dof sparsities.  The
+former saves memory but changes which preconditioners are
+available for the resulting matrices.  (Default yes)</p></li>
+</ul>
+</dd>
+</dl>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.configuration.Configuration.cache_dir">
+<span class="sig-name descname"><span class="pre">cache_dir</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">'/tmp/pyop2-cache-uid1001'</span></em><a class="headerlink" href="#pyop2.configuration.Configuration.cache_dir" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.configuration.Configuration.DEFAULTS">
+<span class="sig-name descname"><span class="pre">DEFAULTS</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">{'block_sparsity':</span> <span class="pre">('PYOP2_BLOCK_SPARSITY',</span> <span class="pre">&lt;class</span> <span class="pre">'bool'&gt;,</span> <span class="pre">True),</span> <span class="pre">'cache_dir':</span> <span class="pre">('PYOP2_CACHE_DIR',</span> <span class="pre">&lt;class</span> <span class="pre">'str'&gt;,</span> <span class="pre">'/tmp/pyop2-cache-uid1001'),</span> <span class="pre">'cc':</span> <span class="pre">('PYOP2_CC',</span> <span class="pre">&lt;class</span> <span class="pre">'str'&gt;,</span> <span class="pre">''),</span> <span class="pre">'cflags':</span> <span class="pre">('PYOP2_CFLAGS',</span> <span class="pre">&lt;class</span> <span class="pre">'str'&gt;,</span> <span class="pre">''),</span> <span class="pre">'check_src_hashes':</span> <span class="pre">('PYOP2_CHECK_SRC_HASHES',</span> <span class="pre">&lt;class</span> <span class="pre">'bool'&gt;,</span> <span class="pre">True),</span> <span class="pre">'compute_kernel_flops':</span> <span class="pre">('PYOP2_COMPUTE_KERNEL_FLOPS',</span> <span class="pre">&lt;class</span> <span class="pre">'bool'&gt;,</span> <span class="pre">False),</span> <span class="pre">'cxx':</span> <span class="pre">('PYOP2_CXX',</span> <span class="pre">&lt;class</span> <span class="pre">'str'&gt;,</span> <span class="pre">''),</span> <span class="pre">'cxxflags':</span> <span class="pre">('PYOP2_CXXFLAGS',</span> <span class="pre">&lt;class</span> <span class="pre">'str'&gt;,</span> <span class="pre">''),</span> <span class="pre">'debug':</span> <span class="pre">('PYOP2_DEBUG',</span> <span class="pre">&lt;class</span> <span class="pre">'bool'&gt;,</span> <span class="pre">False),</span> <span class="pre">'ld':</span> <span class="pre">('PYOP2_LD',</span> <span class="pre">&lt;class</span> <span class="pre">'str'&gt;,</span> <span class="pre">''),</span> <span class="pre">'ldflags':</span> <span class="pre">('PYOP2_LDFLAGS',</span> <span class="pre">&lt;class</span> <span class="pre">'str'&gt;,</span> <span class="pre">''),</span> <span class="pre">'log_level':</span> <span class="pre">('PYOP2_LOG_LEVEL',</span> <span class="pre">(&lt;class</span> <span class="pre">'str'&gt;,</span> <span class="pre">&lt;class</span> <span class="pre">'int'&gt;),</span> <span class="pre">'WARNING'),</span> <span class="pre">'matnest':</span> <span class="pre">('PYOP2_MATNEST',</span> <span class="pre">&lt;class</span> <span class="pre">'bool'&gt;,</span> <span class="pre">True),</span> <span class="pre">'no_fork_available':</span> <span class="pre">('PYOP2_NO_FORK_AVAILABLE',</span> <span class="pre">&lt;class</span> <span class="pre">'bool'&gt;,</span> <span class="pre">False),</span> <span class="pre">'node_local_compilation':</span> <span class="pre">('PYOP2_NODE_LOCAL_COMPILATION',</span> <span class="pre">&lt;class</span> <span class="pre">'bool'&gt;,</span> <span class="pre">True),</span> <span class="pre">'print_cache_size':</span> <span class="pre">('PYOP2_PRINT_CACHE_SIZE',</span> <span class="pre">&lt;class</span> <span class="pre">'bool'&gt;,</span> <span class="pre">False),</span> <span class="pre">'simd_width':</span> <span class="pre">('PYOP2_SIMD_WIDTH',</span> <span class="pre">&lt;class</span> <span class="pre">'int'&gt;,</span> <span class="pre">4),</span> <span class="pre">'type_check':</span> <span class="pre">('PYOP2_TYPE_CHECK',</span> <span class="pre">&lt;class</span> <span class="pre">'bool'&gt;,</span> <span class="pre">True)}</span></em><a class="headerlink" href="#pyop2.configuration.Configuration.DEFAULTS" title="Link to this definition">¶</a></dt>
+<dd><p>Default values for PyOP2 configuration parameters</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.configuration.Configuration.reset">
+<span class="sig-name descname"><span class="pre">reset</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.configuration.Configuration.reset" title="Link to this definition">¶</a></dt>
+<dd><p>Reset the configuration parameters to the default values.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.configuration.Configuration.reconfigure">
+<span class="sig-name descname"><span class="pre">reconfigure</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.configuration.Configuration.reconfigure" title="Link to this definition">¶</a></dt>
+<dd><p>Update the configuration parameters with new values.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.configuration.Configuration.unsafe_reconfigure">
+<span class="sig-name descname"><span class="pre">unsafe_reconfigure</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.configuration.Configuration.unsafe_reconfigure" title="Link to this definition">¶</a></dt>
+<dd><p>“Unsafely reconfigure (just replacing the values)</p>
+</dd></dl>
+
+</dd></dl>
+
+</section>
+<section id="module-pyop2.datatypes">
+<span id="pyop2-datatypes-module"></span><h2>pyop2.datatypes module<a class="headerlink" href="#module-pyop2.datatypes" title="Link to this heading">¶</a></h2>
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.datatypes.as_cstr">
+<span class="sig-prename descclassname"><span class="pre">pyop2.datatypes.</span></span><span class="sig-name descname"><span class="pre">as_cstr</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dtype</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.datatypes.as_cstr" title="Link to this definition">¶</a></dt>
+<dd><p>Convert a numpy dtype like object to a C type as a string.</p>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.datatypes.as_ctypes">
+<span class="sig-prename descclassname"><span class="pre">pyop2.datatypes.</span></span><span class="sig-name descname"><span class="pre">as_ctypes</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dtype</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.datatypes.as_ctypes" title="Link to this definition">¶</a></dt>
+<dd><p>Convert a numpy dtype like object to a ctypes type.</p>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.datatypes.as_numpy_dtype">
+<span class="sig-prename descclassname"><span class="pre">pyop2.datatypes.</span></span><span class="sig-name descname"><span class="pre">as_numpy_dtype</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dtype</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.datatypes.as_numpy_dtype" title="Link to this definition">¶</a></dt>
+<dd><p>Convert a dtype-like object into a numpy dtype.</p>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.datatypes.dtype_limits">
+<span class="sig-prename descclassname"><span class="pre">pyop2.datatypes.</span></span><span class="sig-name descname"><span class="pre">dtype_limits</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dtype</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.datatypes.dtype_limits" title="Link to this definition">¶</a></dt>
+<dd><p>Attempt to determine the min and max values of a datatype.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>dtype</strong> – A numpy datatype.</p>
+</dd>
+<dt class="field-even">Returns<span class="colon">:</span></dt>
+<dd class="field-even"><p>a 2-tuple of min, max</p>
+</dd>
+<dt class="field-odd">Raises<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>ValueError</strong> – If numeric limits could not be determined.</p>
+</dd>
+</dl>
+</dd></dl>
+
+</section>
+<section id="module-pyop2.exceptions">
+<span id="pyop2-exceptions-module"></span><h2>pyop2.exceptions module<a class="headerlink" href="#module-pyop2.exceptions" title="Link to this heading">¶</a></h2>
+<p>OP2 exception types</p>
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.DataTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">DataTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.DataTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for data.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.DimTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">DimTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.DimTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for dimension.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.ArityTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">ArityTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.ArityTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for arity.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.IndexTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">IndexTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.IndexTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for index.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.NameTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">NameTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.NameTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for name.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.SetTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">SetTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.SetTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for <code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.op2.Set</span></code>.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.SizeTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">SizeTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.SizeTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for size.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.SubsetIndexOutOfBounds">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">SubsetIndexOutOfBounds</span></span><a class="headerlink" href="#pyop2.exceptions.SubsetIndexOutOfBounds" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Out of bound index.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.SparsityTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">SparsityTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.SparsityTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for <code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.op2.Sparsity</span></code>.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.MapTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">MapTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.MapTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for <code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.op2.Map</span></code>.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.DataSetTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">DataSetTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.DataSetTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for <code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.op2.DataSet</span></code>.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.MatTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">MatTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.MatTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for <code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.op2.Mat</span></code>.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.DatTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">DatTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.DatTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for <code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.op2.Dat</span></code>.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.KernelTypeError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">KernelTypeError</span></span><a class="headerlink" href="#pyop2.exceptions.KernelTypeError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">TypeError</span></code></p>
+<p>Invalid type for <code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.op2.Kernel</span></code>.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.DataValueError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">DataValueError</span></span><a class="headerlink" href="#pyop2.exceptions.DataValueError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">ValueError</span></code></p>
+<p>Illegal value for data.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.IndexValueError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">IndexValueError</span></span><a class="headerlink" href="#pyop2.exceptions.IndexValueError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">ValueError</span></code></p>
+<p>Illegal value for index.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.ModeValueError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">ModeValueError</span></span><a class="headerlink" href="#pyop2.exceptions.ModeValueError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">ValueError</span></code></p>
+<p>Illegal value for mode.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.IterateValueError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">IterateValueError</span></span><a class="headerlink" href="#pyop2.exceptions.IterateValueError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">ValueError</span></code></p>
+<p>Illegal value for iterate.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.SetValueError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">SetValueError</span></span><a class="headerlink" href="#pyop2.exceptions.SetValueError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">ValueError</span></code></p>
+<p>Illegal value for <code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.op2.Set</span></code>.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.MapValueError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">MapValueError</span></span><a class="headerlink" href="#pyop2.exceptions.MapValueError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">ValueError</span></code></p>
+<p>Illegal value for <code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.op2.Map</span></code>.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.ConfigurationError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">ConfigurationError</span></span><a class="headerlink" href="#pyop2.exceptions.ConfigurationError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">RuntimeError</span></code></p>
+<p>Illegal configuration value or type.</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.CompilationError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">CompilationError</span></span><a class="headerlink" href="#pyop2.exceptions.CompilationError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">RuntimeError</span></code></p>
+<p>Error during JIT compilation</p>
+</dd></dl>
+
+<dl class="py exception">
+<dt class="sig sig-object py" id="pyop2.exceptions.SparsityFormatError">
+<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.exceptions.</span></span><span class="sig-name descname"><span class="pre">SparsityFormatError</span></span><a class="headerlink" href="#pyop2.exceptions.SparsityFormatError" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">ValueError</span></code></p>
+<p>Unable to produce a sparsity for this matrix format.</p>
+</dd></dl>
+
+</section>
+<section id="pyop2-global-kernel-module">
+<h2>pyop2.global_kernel module<a class="headerlink" href="#pyop2-global-kernel-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="pyop2-local-kernel-module">
+<h2>pyop2.local_kernel module<a class="headerlink" href="#pyop2-local-kernel-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="module-pyop2.logger">
+<span id="pyop2-logger-module"></span><h2>pyop2.logger module<a class="headerlink" href="#module-pyop2.logger" title="Link to this heading">¶</a></h2>
+<p>The PyOP2 logger, based on the Python standard library logging module.</p>
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.logger.set_log_level">
+<span class="sig-prename descclassname"><span class="pre">pyop2.logger.</span></span><span class="sig-name descname"><span class="pre">set_log_level</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">level</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.logger.set_log_level" title="Link to this definition">¶</a></dt>
+<dd><p>Set the log level of the PyOP2 logger.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>level</strong> – the log level. Valid values: DEBUG, INFO, WARNING, ERROR, CRITICAL</p>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.logger.log">
+<span class="sig-prename descclassname"><span class="pre">pyop2.logger.</span></span><span class="sig-name descname"><span class="pre">log</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">level</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">msg</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.logger.log" title="Link to this definition">¶</a></dt>
+<dd><p>Print ‘msg % args’ with the severity ‘level’.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>level</strong> – the log level. Valid values: DEBUG, INFO, WARNING, ERROR, CRITICAL</p></li>
+<li><p><strong>msg</strong> – the message</p></li>
+</ul>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.logger.progress">
+<span class="sig-prename descclassname"><span class="pre">pyop2.logger.</span></span><span class="sig-name descname"><span class="pre">progress</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">level</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">msg</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.logger.progress" title="Link to this definition">¶</a></dt>
+<dd><p>A context manager to print a progress message.</p>
+<p>The block is wrapped in <code class="docutils literal notranslate"><span class="pre">msg...</span></code>, <code class="docutils literal notranslate"><span class="pre">msg...done</span></code> log messages
+with an appropriate indent (to distinguish nested message).</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>level</strong> – the log level.  See <a class="reference internal" href="#pyop2.logger.log" title="pyop2.logger.log"><code class="xref py py-func docutils literal notranslate"><span class="pre">log()</span></code></a> for valid values</p></li>
+<li><p><strong>msg</strong> – the message.</p></li>
+</ul>
+</dd>
+</dl>
+<p>See <a class="reference internal" href="#pyop2.logger.log" title="pyop2.logger.log"><code class="xref py py-func docutils literal notranslate"><span class="pre">log()</span></code></a> for more details.</p>
+</dd></dl>
+
+</section>
+<section id="module-pyop2.mpi">
+<span id="pyop2-mpi-module"></span><h2>pyop2.mpi module<a class="headerlink" href="#module-pyop2.mpi" title="Link to this heading">¶</a></h2>
+<p>PyOP2 MPI communicator.</p>
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.mpi.internal_comm">
+<span class="sig-prename descclassname"><span class="pre">pyop2.mpi.</span></span><span class="sig-name descname"><span class="pre">internal_comm</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">comm</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.mpi.internal_comm" title="Link to this definition">¶</a></dt>
+<dd><p>Creates an internal comm from the user comm.
+If comm is None, create an internal communicator from COMM_WORLD
+:arg comm: A communicator or None</p>
+<dl class="field-list simple">
+<dt class="field-odd">Returns pyop2_comm<span class="colon">:</span></dt>
+<dd class="field-odd"><p>A PyOP2 internal communicator</p>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.mpi.is_pyop2_comm">
+<span class="sig-prename descclassname"><span class="pre">pyop2.mpi.</span></span><span class="sig-name descname"><span class="pre">is_pyop2_comm</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">comm</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.mpi.is_pyop2_comm" title="Link to this definition">¶</a></dt>
+<dd><p>Returns <code class="docutils literal notranslate"><span class="pre">True</span></code> if <code class="docutils literal notranslate"><span class="pre">comm</span></code> is a PyOP2 communicator,
+False if <cite>comm</cite> another communicator.
+Raises exception if <code class="docutils literal notranslate"><span class="pre">comm</span></code> is not a communicator.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>comm</strong> – Communicator to query</p>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.mpi.incref">
+<span class="sig-prename descclassname"><span class="pre">pyop2.mpi.</span></span><span class="sig-name descname"><span class="pre">incref</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">comm</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.mpi.incref" title="Link to this definition">¶</a></dt>
+<dd><p>Increment communicator reference count</p>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.mpi.decref">
+<span class="sig-prename descclassname"><span class="pre">pyop2.mpi.</span></span><span class="sig-name descname"><span class="pre">decref</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">comm</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.mpi.decref" title="Link to this definition">¶</a></dt>
+<dd><p>Decrement communicator reference count</p>
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.mpi.temp_internal_comm">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.mpi.</span></span><span class="sig-name descname"><span class="pre">temp_internal_comm</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">comm</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.mpi.temp_internal_comm" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></p>
+<p>Use a PyOP2 internal communicator and
+increment and decrement the internal comm.
+:arg comm: Any communicator</p>
+</dd></dl>
+
+</section>
+<section id="pyop2-op2-module">
+<h2>pyop2.op2 module<a class="headerlink" href="#pyop2-op2-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="pyop2-parloop-module">
+<h2>pyop2.parloop module<a class="headerlink" href="#pyop2-parloop-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="module-pyop2.profiling">
+<span id="pyop2-profiling-module"></span><h2>pyop2.profiling module<a class="headerlink" href="#module-pyop2.profiling" title="Link to this heading">¶</a></h2>
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.profiling.timed_stage">
+<span class="sig-prename descclassname"><span class="pre">pyop2.profiling.</span></span><span class="sig-name descname"><span class="pre">timed_stage</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.profiling.timed_stage" title="Link to this definition">¶</a></dt>
+<dd><p>Enter a code Stage, this is a PETSc log Stage.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>name</strong> – The name of the stage.</p>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.profiling.timed_region">
+<span class="sig-prename descclassname"><span class="pre">pyop2.profiling.</span></span><span class="sig-name descname"><span class="pre">timed_region</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.profiling.timed_region" title="Link to this definition">¶</a></dt>
+<dd><p>Time a code region, this a PETSc log Event.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>name</strong> – The name of the region.</p>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.profiling.timed_function">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.profiling.</span></span><span class="sig-name descname"><span class="pre">timed_function</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.profiling.timed_function" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></p>
+</dd></dl>
+
+</section>
+<section id="pyop2-sparsity-module">
+<h2>pyop2.sparsity module<a class="headerlink" href="#pyop2-sparsity-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="module-pyop2.utils">
+<span id="pyop2-utils-module"></span><h2>pyop2.utils module<a class="headerlink" href="#module-pyop2.utils" title="Link to this heading">¶</a></h2>
+<p>Common utility classes/functions.</p>
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.utils.cached_property">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">cached_property</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">fget</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">doc</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.cached_property" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></p>
+<p>A read-only &#64;property that is only evaluated once. The value is cached
+on the object itself rather than the function or class; this should prevent
+memory leakage.</p>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.utils.as_tuple">
+<span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">as_tuple</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">item</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">type</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">length</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">allow_none</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">False</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.as_tuple" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.utils.as_type">
+<span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">as_type</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">obj</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">typ</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.as_type" title="Link to this definition">¶</a></dt>
+<dd><p>Return obj if it is of dtype typ, otherwise return a copy type-cast to
+typ.</p>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.utils.tuplify">
+<span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">tuplify</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">xs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.tuplify" title="Link to this definition">¶</a></dt>
+<dd><p>Turn a data structure into a tuple tree.</p>
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.utils.validate_base">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">validate_base</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">checks</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.validate_base" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></p>
+<p>Decorator to validate arguments</p>
+<p>Formal parameters that don’t exist in the definition of the function
+being decorated as well as actual arguments not being present when
+the validation is called are silently ignored.</p>
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.utils.validate_base.check_args">
+<span class="sig-name descname"><span class="pre">check_args</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.validate_base.check_args" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.utils.validate_type">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">validate_type</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">checks</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.validate_type" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.utils.validate_base" title="pyop2.utils.validate_base"><code class="xref py py-class docutils literal notranslate"><span class="pre">validate_base</span></code></a></p>
+<p>Decorator to validate argument types</p>
+<p>The decorator expects one or more arguments, which are 3-tuples of
+(name, type, exception), where name is the argument name in the
+function being decorated, type is the argument type to be validated
+and exception is the exception type to be raised if validation fails.</p>
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.utils.validate_type.check_arg">
+<span class="sig-name descname"><span class="pre">check_arg</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">arg</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">argtype</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">exception</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.validate_type.check_arg" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.utils.validate_in">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">validate_in</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">checks</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.validate_in" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.utils.validate_base" title="pyop2.utils.validate_base"><code class="xref py py-class docutils literal notranslate"><span class="pre">validate_base</span></code></a></p>
+<p>Decorator to validate argument is in a set of valid argument values</p>
+<p>The decorator expects one or more arguments, which are 3-tuples of
+(name, list, exception), where name is the argument name in the
+function being decorated, list is the list of valid argument values
+and exception is the exception type to be raised if validation fails.</p>
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.utils.validate_in.check_arg">
+<span class="sig-name descname"><span class="pre">check_arg</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">arg</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">values</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">exception</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.validate_in.check_arg" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.utils.validate_range">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">validate_range</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">checks</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.validate_range" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.utils.validate_base" title="pyop2.utils.validate_base"><code class="xref py py-class docutils literal notranslate"><span class="pre">validate_base</span></code></a></p>
+<p>Decorator to validate argument value is in a given numeric range</p>
+<p>The decorator expects one or more arguments, which are 3-tuples of
+(name, range, exception), where name is the argument name in the
+function being decorated, range is a 2-tuple defining the valid argument
+range and exception is the exception type to be raised if validation
+fails.</p>
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.utils.validate_range.check_arg">
+<span class="sig-name descname"><span class="pre">check_arg</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">arg</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">range</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">exception</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.validate_range.check_arg" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.utils.validate_dtype">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">validate_dtype</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">checks</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.validate_dtype" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.utils.validate_base" title="pyop2.utils.validate_base"><code class="xref py py-class docutils literal notranslate"><span class="pre">validate_base</span></code></a></p>
+<p>Decorator to validate argument value is in a valid Numpy dtype</p>
+<p>The decorator expects one or more arguments, which are 3-tuples of
+(name, _, exception), where name is the argument name in the
+function being decorated, second argument is ignored and exception
+is the exception type to be raised if validation fails.</p>
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.utils.validate_dtype.check_arg">
+<span class="sig-name descname"><span class="pre">check_arg</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">arg</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">ignored</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">exception</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.validate_dtype.check_arg" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.utils.verify_reshape">
+<span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">verify_reshape</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">data</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">dtype</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">shape</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">allow_none</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">False</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.verify_reshape" title="Link to this definition">¶</a></dt>
+<dd><p>Verify data is of type dtype and try to reshaped to shape.</p>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.utils.align">
+<span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">align</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">bytes</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">alignment</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">16</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.align" title="Link to this definition">¶</a></dt>
+<dd><p>Align BYTES to a multiple of ALIGNMENT</p>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.utils.flatten">
+<span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">flatten</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">iterable</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.flatten" title="Link to this definition">¶</a></dt>
+<dd><p>Flatten a given nested iterable.</p>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.utils.parser">
+<span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">parser</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">description</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">group</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">False</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.parser" title="Link to this definition">¶</a></dt>
+<dd><p>Create default argparse.ArgumentParser parser for pyop2 programs.</p>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.utils.parse_args">
+<span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">parse_args</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.parse_args" title="Link to this definition">¶</a></dt>
+<dd><p>Return parsed arguments as variables for later use.</p>
+<p>ARGS and KWARGS are passed into the parser instantiation.
+The only recognised options are <cite>group</cite> and <cite>description</cite>.</p>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.utils.trim">
+<span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">trim</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">docstring</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.trim" title="Link to this definition">¶</a></dt>
+<dd><p>Trim a docstring according to <a class="reference external" href="http://www.python.org/dev/peps/pep-0257/#handling-docstring-indentation">PEP 257</a>.</p>
+</dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.utils.strip">
+<span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">strip</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">code</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.strip" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py function">
+<dt class="sig sig-object py" id="pyop2.utils.get_petsc_dir">
+<span class="sig-prename descclassname"><span class="pre">pyop2.utils.</span></span><span class="sig-name descname"><span class="pre">get_petsc_dir</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.utils.get_petsc_dir" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</section>
+<section id="pyop2-version-module">
+<h2>pyop2.version module<a class="headerlink" href="#pyop2-version-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="module-contents">
+<h2>Module contents<a class="headerlink" href="#module-contents" title="Link to this heading">¶</a></h2>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">pyop2 package</a><ul>
+<li><a class="reference internal" href="#subpackages">Subpackages</a></li>
+<li><a class="reference internal" href="#submodules">Submodules</a></li>
+<li><a class="reference internal" href="#pyop2-caching-module">pyop2.caching module</a></li>
+<li><a class="reference internal" href="#pyop2-compilation-module">pyop2.compilation module</a></li>
+<li><a class="reference internal" href="#module-pyop2.configuration">pyop2.configuration module</a><ul>
+<li><a class="reference internal" href="#pyop2.configuration.Configuration"><code class="docutils literal notranslate"><span class="pre">Configuration</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.configuration.Configuration.cache_dir"><code class="docutils literal notranslate"><span class="pre">Configuration.cache_dir</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.configuration.Configuration.DEFAULTS"><code class="docutils literal notranslate"><span class="pre">Configuration.DEFAULTS</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.configuration.Configuration.reset"><code class="docutils literal notranslate"><span class="pre">Configuration.reset()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.configuration.Configuration.reconfigure"><code class="docutils literal notranslate"><span class="pre">Configuration.reconfigure()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.configuration.Configuration.unsafe_reconfigure"><code class="docutils literal notranslate"><span class="pre">Configuration.unsafe_reconfigure()</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#module-pyop2.datatypes">pyop2.datatypes module</a><ul>
+<li><a class="reference internal" href="#pyop2.datatypes.as_cstr"><code class="docutils literal notranslate"><span class="pre">as_cstr()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.datatypes.as_ctypes"><code class="docutils literal notranslate"><span class="pre">as_ctypes()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.datatypes.as_numpy_dtype"><code class="docutils literal notranslate"><span class="pre">as_numpy_dtype()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.datatypes.dtype_limits"><code class="docutils literal notranslate"><span class="pre">dtype_limits()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#module-pyop2.exceptions">pyop2.exceptions module</a><ul>
+<li><a class="reference internal" href="#pyop2.exceptions.DataTypeError"><code class="docutils literal notranslate"><span class="pre">DataTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.DimTypeError"><code class="docutils literal notranslate"><span class="pre">DimTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.ArityTypeError"><code class="docutils literal notranslate"><span class="pre">ArityTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.IndexTypeError"><code class="docutils literal notranslate"><span class="pre">IndexTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.NameTypeError"><code class="docutils literal notranslate"><span class="pre">NameTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.SetTypeError"><code class="docutils literal notranslate"><span class="pre">SetTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.SizeTypeError"><code class="docutils literal notranslate"><span class="pre">SizeTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.SubsetIndexOutOfBounds"><code class="docutils literal notranslate"><span class="pre">SubsetIndexOutOfBounds</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.SparsityTypeError"><code class="docutils literal notranslate"><span class="pre">SparsityTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.MapTypeError"><code class="docutils literal notranslate"><span class="pre">MapTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.DataSetTypeError"><code class="docutils literal notranslate"><span class="pre">DataSetTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.MatTypeError"><code class="docutils literal notranslate"><span class="pre">MatTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.DatTypeError"><code class="docutils literal notranslate"><span class="pre">DatTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.KernelTypeError"><code class="docutils literal notranslate"><span class="pre">KernelTypeError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.DataValueError"><code class="docutils literal notranslate"><span class="pre">DataValueError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.IndexValueError"><code class="docutils literal notranslate"><span class="pre">IndexValueError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.ModeValueError"><code class="docutils literal notranslate"><span class="pre">ModeValueError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.IterateValueError"><code class="docutils literal notranslate"><span class="pre">IterateValueError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.SetValueError"><code class="docutils literal notranslate"><span class="pre">SetValueError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.MapValueError"><code class="docutils literal notranslate"><span class="pre">MapValueError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.ConfigurationError"><code class="docutils literal notranslate"><span class="pre">ConfigurationError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.CompilationError"><code class="docutils literal notranslate"><span class="pre">CompilationError</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.exceptions.SparsityFormatError"><code class="docutils literal notranslate"><span class="pre">SparsityFormatError</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2-global-kernel-module">pyop2.global_kernel module</a></li>
+<li><a class="reference internal" href="#pyop2-local-kernel-module">pyop2.local_kernel module</a></li>
+<li><a class="reference internal" href="#module-pyop2.logger">pyop2.logger module</a><ul>
+<li><a class="reference internal" href="#pyop2.logger.set_log_level"><code class="docutils literal notranslate"><span class="pre">set_log_level()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.logger.log"><code class="docutils literal notranslate"><span class="pre">log()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.logger.progress"><code class="docutils literal notranslate"><span class="pre">progress()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#module-pyop2.mpi">pyop2.mpi module</a><ul>
+<li><a class="reference internal" href="#pyop2.mpi.internal_comm"><code class="docutils literal notranslate"><span class="pre">internal_comm()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.mpi.is_pyop2_comm"><code class="docutils literal notranslate"><span class="pre">is_pyop2_comm()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.mpi.incref"><code class="docutils literal notranslate"><span class="pre">incref()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.mpi.decref"><code class="docutils literal notranslate"><span class="pre">decref()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.mpi.temp_internal_comm"><code class="docutils literal notranslate"><span class="pre">temp_internal_comm</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2-op2-module">pyop2.op2 module</a></li>
+<li><a class="reference internal" href="#pyop2-parloop-module">pyop2.parloop module</a></li>
+<li><a class="reference internal" href="#module-pyop2.profiling">pyop2.profiling module</a><ul>
+<li><a class="reference internal" href="#pyop2.profiling.timed_stage"><code class="docutils literal notranslate"><span class="pre">timed_stage()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.profiling.timed_region"><code class="docutils literal notranslate"><span class="pre">timed_region()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.profiling.timed_function"><code class="docutils literal notranslate"><span class="pre">timed_function</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2-sparsity-module">pyop2.sparsity module</a></li>
+<li><a class="reference internal" href="#module-pyop2.utils">pyop2.utils module</a><ul>
+<li><a class="reference internal" href="#pyop2.utils.cached_property"><code class="docutils literal notranslate"><span class="pre">cached_property</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.utils.as_tuple"><code class="docutils literal notranslate"><span class="pre">as_tuple()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.utils.as_type"><code class="docutils literal notranslate"><span class="pre">as_type()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.utils.tuplify"><code class="docutils literal notranslate"><span class="pre">tuplify()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.utils.validate_base"><code class="docutils literal notranslate"><span class="pre">validate_base</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.utils.validate_base.check_args"><code class="docutils literal notranslate"><span class="pre">validate_base.check_args()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.utils.validate_type"><code class="docutils literal notranslate"><span class="pre">validate_type</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.utils.validate_type.check_arg"><code class="docutils literal notranslate"><span class="pre">validate_type.check_arg()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.utils.validate_in"><code class="docutils literal notranslate"><span class="pre">validate_in</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.utils.validate_in.check_arg"><code class="docutils literal notranslate"><span class="pre">validate_in.check_arg()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.utils.validate_range"><code class="docutils literal notranslate"><span class="pre">validate_range</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.utils.validate_range.check_arg"><code class="docutils literal notranslate"><span class="pre">validate_range.check_arg()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.utils.validate_dtype"><code class="docutils literal notranslate"><span class="pre">validate_dtype</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.utils.validate_dtype.check_arg"><code class="docutils literal notranslate"><span class="pre">validate_dtype.check_arg()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.utils.verify_reshape"><code class="docutils literal notranslate"><span class="pre">verify_reshape()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.utils.align"><code class="docutils literal notranslate"><span class="pre">align()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.utils.flatten"><code class="docutils literal notranslate"><span class="pre">flatten()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.utils.parser"><code class="docutils literal notranslate"><span class="pre">parser()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.utils.parse_args"><code class="docutils literal notranslate"><span class="pre">parse_args()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.utils.trim"><code class="docutils literal notranslate"><span class="pre">trim()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.utils.strip"><code class="docutils literal notranslate"><span class="pre">strip()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.utils.get_petsc_dir"><code class="docutils literal notranslate"><span class="pre">get_petsc_dir()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2-version-module">pyop2.version module</a></li>
+<li><a class="reference internal" href="#module-contents">Module contents</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="user.html"
+                          title="previous chapter">pyop2 user documentation</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="pyop2.codegen.html"
+                          title="next chapter">pyop2.codegen package</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/pyop2.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="pyop2.codegen.html" title="pyop2.codegen package"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="user.html" title="pyop2 user documentation"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">pyop2 package</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/pyop2.types.html b/pyop2.types.html
new file mode 100644
index 000000000..f33bd5004
--- /dev/null
+++ b/pyop2.types.html
@@ -0,0 +1,2452 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>pyop2.types package &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="prev" title="pyop2.codegen package" href="pyop2.codegen.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="pyop2.codegen.html" title="pyop2.codegen package"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+          <li class="nav-item nav-item-1"><a href="pyop2.html" accesskey="U">pyop2 package</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">pyop2.types package</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="pyop2-types-package">
+<h1>pyop2.types package<a class="headerlink" href="#pyop2-types-package" title="Link to this heading">¶</a></h1>
+<section id="submodules">
+<h2>Submodules<a class="headerlink" href="#submodules" title="Link to this heading">¶</a></h2>
+</section>
+<section id="module-pyop2.types.access">
+<span id="pyop2-types-access-module"></span><h2>pyop2.types.access module<a class="headerlink" href="#module-pyop2.types.access" title="Link to this heading">¶</a></h2>
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.access.Access">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.access.</span></span><span class="sig-name descname"><span class="pre">Access</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">value</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.access.Access" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">IntEnum</span></code></p>
+<p>An enumeration.</p>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.access.Access.READ">
+<span class="sig-name descname"><span class="pre">READ</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">1</span></em><a class="headerlink" href="#pyop2.types.access.Access.READ" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.access.Access.WRITE">
+<span class="sig-name descname"><span class="pre">WRITE</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">2</span></em><a class="headerlink" href="#pyop2.types.access.Access.WRITE" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.access.Access.RW">
+<span class="sig-name descname"><span class="pre">RW</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">3</span></em><a class="headerlink" href="#pyop2.types.access.Access.RW" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.access.Access.INC">
+<span class="sig-name descname"><span class="pre">INC</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">4</span></em><a class="headerlink" href="#pyop2.types.access.Access.INC" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.access.Access.MIN">
+<span class="sig-name descname"><span class="pre">MIN</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">5</span></em><a class="headerlink" href="#pyop2.types.access.Access.MIN" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.access.Access.MAX">
+<span class="sig-name descname"><span class="pre">MAX</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">6</span></em><a class="headerlink" href="#pyop2.types.access.Access.MAX" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py data">
+<dt class="sig sig-object py" id="pyop2.types.access.READ">
+<span class="sig-prename descclassname"><span class="pre">pyop2.types.access.</span></span><span class="sig-name descname"><span class="pre">READ</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">Access.READ</span></em><a class="headerlink" href="#pyop2.types.access.READ" title="Link to this definition">¶</a></dt>
+<dd><p>The <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code>, <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>, or <code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code> is accessed read-only.</p>
+</dd></dl>
+
+<dl class="py data">
+<dt class="sig sig-object py" id="pyop2.types.access.WRITE">
+<span class="sig-prename descclassname"><span class="pre">pyop2.types.access.</span></span><span class="sig-name descname"><span class="pre">WRITE</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">Access.WRITE</span></em><a class="headerlink" href="#pyop2.types.access.WRITE" title="Link to this definition">¶</a></dt>
+<dd><p>The  <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code>, <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>, or <code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code> is accessed write-only,
+and OP2 is not required to handle write conflicts.</p>
+</dd></dl>
+
+<dl class="py data">
+<dt class="sig sig-object py" id="pyop2.types.access.RW">
+<span class="sig-prename descclassname"><span class="pre">pyop2.types.access.</span></span><span class="sig-name descname"><span class="pre">RW</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">Access.RW</span></em><a class="headerlink" href="#pyop2.types.access.RW" title="Link to this definition">¶</a></dt>
+<dd><p>The  <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code>, <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>, or <code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code> is accessed for reading
+and writing, and OP2 is not required to handle write conflicts.</p>
+</dd></dl>
+
+<dl class="py data">
+<dt class="sig sig-object py" id="pyop2.types.access.INC">
+<span class="sig-prename descclassname"><span class="pre">pyop2.types.access.</span></span><span class="sig-name descname"><span class="pre">INC</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">Access.INC</span></em><a class="headerlink" href="#pyop2.types.access.INC" title="Link to this definition">¶</a></dt>
+<dd><p>The kernel computes increments to be summed onto a <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code>,
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>, or <code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code>. OP2 is responsible for managing the write
+conflicts caused.</p>
+</dd></dl>
+
+<dl class="py data">
+<dt class="sig sig-object py" id="pyop2.types.access.MIN">
+<span class="sig-prename descclassname"><span class="pre">pyop2.types.access.</span></span><span class="sig-name descname"><span class="pre">MIN</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">Access.MIN</span></em><a class="headerlink" href="#pyop2.types.access.MIN" title="Link to this definition">¶</a></dt>
+<dd><p>The kernel contributes to a reduction into a <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code> using a <code class="docutils literal notranslate"><span class="pre">min</span></code>
+operation. OP2 is responsible for reducing over the different kernel
+invocations.</p>
+</dd></dl>
+
+<dl class="py data">
+<dt class="sig sig-object py" id="pyop2.types.access.MAX">
+<span class="sig-prename descclassname"><span class="pre">pyop2.types.access.</span></span><span class="sig-name descname"><span class="pre">MAX</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">Access.MAX</span></em><a class="headerlink" href="#pyop2.types.access.MAX" title="Link to this definition">¶</a></dt>
+<dd><p>The kernel contributes to a reduction into a <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code> using a <code class="docutils literal notranslate"><span class="pre">max</span></code>
+operation. OP2 is responsible for reducing over the different kernel
+invocations.</p>
+</dd></dl>
+
+</section>
+<section id="module-pyop2.types.dat">
+<span id="pyop2-types-dat-module"></span><h2>pyop2.types.dat module<a class="headerlink" href="#module-pyop2.types.dat" title="Link to this heading">¶</a></h2>
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.dat.</span></span><span class="sig-name descname"><span class="pre">AbstractDat</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dataset</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">data</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">dtype</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">name</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.data_carrier.DataCarrier" title="pyop2.types.data_carrier.DataCarrier"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataCarrier</span></code></a>, <a class="reference internal" href="#pyop2.types.data_carrier.EmptyDataMixin" title="pyop2.types.data_carrier.EmptyDataMixin"><code class="xref py py-class docutils literal notranslate"><span class="pre">EmptyDataMixin</span></code></a>, <code class="xref py py-class docutils literal notranslate"><span class="pre">ABC</span></code></p>
+<p>OP2 vector data. A <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> holds values on every element of a
+<code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code>.o</p>
+<p>If a <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> is passed as the <code class="docutils literal notranslate"><span class="pre">dataset</span></code> argument, rather
+than a <code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code>, the <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> is created with a default
+<code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code> dimension of 1.</p>
+<p>If a <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> is passed as the <code class="docutils literal notranslate"><span class="pre">dataset</span></code> argument, a copy is
+returned.</p>
+<p>It is permissible to pass <cite>None</cite> as the <cite>data</cite> argument.  In this
+case, allocation of the data buffer is postponed until it is
+accessed.</p>
+<div class="admonition note">
+<p class="admonition-title">Note</p>
+<p>If the data buffer is not passed in, it is implicitly
+initialised to be zero.</p>
+</div>
+<p>When a <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> is passed to <code class="xref py py-func docutils literal notranslate"><span class="pre">pyop2.op2.par_loop()</span></code>, the map via
+which indirection occurs and the access descriptor are passed by
+calling the <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a>. For instance, if a <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> named <code class="docutils literal notranslate"><span class="pre">D</span></code> is
+to be accessed for reading via a <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> named <code class="docutils literal notranslate"><span class="pre">M</span></code>, this is
+accomplished by</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">D</span><span class="p">(</span><span class="n">pyop2</span><span class="o">.</span><span class="n">READ</span><span class="p">,</span> <span class="n">M</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>The <code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code> through which indirection occurs can be indexed
+using the index notation described in the documentation for the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code>. Direct access to a Dat is accomplished by
+omitting the path argument.</p>
+<p><a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> objects support the pointwise linear algebra operations
+<code class="docutils literal notranslate"><span class="pre">+=</span></code>, <code class="docutils literal notranslate"><span class="pre">*=</span></code>, <code class="docutils literal notranslate"><span class="pre">-=</span></code>, <code class="docutils literal notranslate"><span class="pre">/=</span></code>, where <code class="docutils literal notranslate"><span class="pre">*=</span></code> and <code class="docutils literal notranslate"><span class="pre">/=</span></code> also support
+multiplication / division by a scalar.</p>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.split">
+<span class="sig-name descname"><span class="pre">split</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.split" title="Link to this definition">¶</a></dt>
+<dd><p>Tuple containing only this <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a>.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.dataset">
+<span class="sig-name descname"><span class="pre">dataset</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.dataset" title="Link to this definition">¶</a></dt>
+<dd><p><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code> on which the Dat is defined.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.dim">
+<span class="sig-name descname"><span class="pre">dim</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.dim" title="Link to this definition">¶</a></dt>
+<dd><p>The shape of the values for each element of the object.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.cdim">
+<span class="sig-name descname"><span class="pre">cdim</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.cdim" title="Link to this definition">¶</a></dt>
+<dd><p>The scalar number of values for each member of the object. This is
+the product of the dim tuple.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.data">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.data" title="Link to this definition">¶</a></dt>
+<dd><p>Numpy array containing the data values.</p>
+<p>With this accessor you are claiming that you will modify
+the values you get back.  If you only need to look at the
+values, use <a class="reference internal" href="#pyop2.types.dat.AbstractDat.data_ro" title="pyop2.types.dat.AbstractDat.data_ro"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data_ro()</span></code></a> instead.</p>
+<p>This only shows local values, to see the halo values too use
+<a class="reference internal" href="#pyop2.types.dat.AbstractDat.data_with_halos" title="pyop2.types.dat.AbstractDat.data_with_halos"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data_with_halos()</span></code></a>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.data_with_halos">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_with_halos</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.data_with_halos" title="Link to this definition">¶</a></dt>
+<dd><p>A view of this <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a>s data.</p>
+<p>This accessor marks the <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> as dirty, see
+<a class="reference internal" href="#pyop2.types.dat.AbstractDat.data" title="pyop2.types.dat.AbstractDat.data"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data()</span></code></a> for more details on the semantics.</p>
+<p>With this accessor, you get to see up to date halo values, but
+you should not try and modify them, because they will be
+overwritten by the next halo exchange.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.data_ro">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_ro</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.data_ro" title="Link to this definition">¶</a></dt>
+<dd><p>Numpy array containing the data values.  Read-only.</p>
+<p>With this accessor you are not allowed to modify the values
+you get back.  If you need to do so, use <a class="reference internal" href="#pyop2.types.dat.AbstractDat.data" title="pyop2.types.dat.AbstractDat.data"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data()</span></code></a> instead.</p>
+<p>This only shows local values, to see the halo values too use
+<a class="reference internal" href="#pyop2.types.dat.AbstractDat.data_ro_with_halos" title="pyop2.types.dat.AbstractDat.data_ro_with_halos"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data_ro_with_halos()</span></code></a>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.data_ro_with_halos">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_ro_with_halos</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.data_ro_with_halos" title="Link to this definition">¶</a></dt>
+<dd><p>A view of this <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a>s data.</p>
+<p>This accessor does not mark the <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> as dirty, and is
+a read only view, see <a class="reference internal" href="#pyop2.types.dat.AbstractDat.data_ro" title="pyop2.types.dat.AbstractDat.data_ro"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data_ro()</span></code></a> for more details on the
+semantics.</p>
+<p>With this accessor, you get to see up to date halo values, but
+you should not try and modify them, because they will be
+overwritten by the next halo exchange.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.data_wo">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_wo</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.data_wo" title="Link to this definition">¶</a></dt>
+<dd><p>Numpy array containing the data values that is only valid for writing to.</p>
+<p>This only shows local values, to see the halo values too use
+<a class="reference internal" href="#pyop2.types.dat.AbstractDat.data_wo_with_halos" title="pyop2.types.dat.AbstractDat.data_wo_with_halos"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data_wo_with_halos()</span></code></a>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.data_wo_with_halos">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_wo_with_halos</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.data_wo_with_halos" title="Link to this definition">¶</a></dt>
+<dd><p>Return a write-only view of all the data values.</p>
+<p>This method, unlike <a class="reference internal" href="#pyop2.types.dat.AbstractDat.data_with_halos" title="pyop2.types.dat.AbstractDat.data_with_halos"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data_with_halos()</span></code></a>, avoids a halo exchange
+if the halo is dirty.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.save">
+<span class="sig-name descname"><span class="pre">save</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">filename</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.save" title="Link to this definition">¶</a></dt>
+<dd><p>Write the data array to file <code class="docutils literal notranslate"><span class="pre">filename</span></code> in NumPy format.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.load">
+<span class="sig-name descname"><span class="pre">load</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">filename</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.load" title="Link to this definition">¶</a></dt>
+<dd><p>Read the data stored in file <code class="docutils literal notranslate"><span class="pre">filename</span></code> into a NumPy array
+and store the values in <code class="xref py py-meth docutils literal notranslate"><span class="pre">_data()</span></code>.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.shape">
+<span class="sig-name descname"><span class="pre">shape</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.shape" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.dtype">
+<span class="sig-name descname"><span class="pre">dtype</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.dtype" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.nbytes">
+<span class="sig-name descname"><span class="pre">nbytes</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.nbytes" title="Link to this definition">¶</a></dt>
+<dd><p>Return an estimate of the size of the data associated with this
+<a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> in bytes. This will be the correct size of the data
+payload, but does not take into account the (presumably small)
+overhead of the object and its metadata.</p>
+<p>Note that this is the process local memory usage, not the sum
+over all MPI processes.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.zero">
+<span class="sig-name descname"><span class="pre">zero</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">subset</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.zero" title="Link to this definition">¶</a></dt>
+<dd><p>Zero the data associated with this <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a></p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>subset</strong> – A <code class="xref py py-class docutils literal notranslate"><span class="pre">Subset</span></code> of entries to zero (optional).</p>
+</dd>
+</dl>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.copy">
+<span class="sig-name descname"><span class="pre">copy</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">subset</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.copy" title="Link to this definition">¶</a></dt>
+<dd><p>Copy the data in this <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> into another.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>other</strong> – The destination <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a></p></li>
+<li><p><strong>subset</strong> – A <code class="xref py py-class docutils literal notranslate"><span class="pre">Subset</span></code> of elements to copy (optional)</p></li>
+</ul>
+</dd>
+</dl>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.inner">
+<span class="sig-name descname"><span class="pre">inner</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.inner" title="Link to this definition">¶</a></dt>
+<dd><p>Compute the l2 inner product of the flattened <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a></p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>other</strong> – the other <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> to compute the inner
+product against. The complex conjugate of this is taken.</p>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.norm">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">norm</span></span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.norm" title="Link to this definition">¶</a></dt>
+<dd><p>Compute the l2 norm of this <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a></p>
+<div class="admonition note">
+<p class="admonition-title">Note</p>
+<p>This acts on the flattened data (see also <a class="reference internal" href="#pyop2.types.dat.AbstractDat.inner" title="pyop2.types.dat.AbstractDat.inner"><code class="xref py py-meth docutils literal notranslate"><span class="pre">inner()</span></code></a>).</p>
+</div>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.global_to_local_begin">
+<span class="sig-name descname"><span class="pre">global_to_local_begin</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.global_to_local_begin" title="Link to this definition">¶</a></dt>
+<dd><p>Begin a halo exchange from global to ghosted representation.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>access_mode</strong> – Mode with which the data will subsequently
+be accessed.</p>
+</dd>
+</dl>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.global_to_local_end">
+<span class="sig-name descname"><span class="pre">global_to_local_end</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.global_to_local_end" title="Link to this definition">¶</a></dt>
+<dd><p>End a halo exchange from global to ghosted representation.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>access_mode</strong> – Mode with which the data will subsequently
+be accessed.</p>
+</dd>
+</dl>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.local_to_global_begin">
+<span class="sig-name descname"><span class="pre">local_to_global_begin</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">insert_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.local_to_global_begin" title="Link to this definition">¶</a></dt>
+<dd><p>Begin a halo exchange from ghosted to global representation.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>insert_mode</strong> – insertion mode (an access descriptor)</p>
+</dd>
+</dl>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.local_to_global_end">
+<span class="sig-name descname"><span class="pre">local_to_global_end</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">insert_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.local_to_global_end" title="Link to this definition">¶</a></dt>
+<dd><p>End a halo exchange from ghosted to global representation.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>insert_mode</strong> – insertion mode (an access descriptor)</p>
+</dd>
+</dl>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.frozen_halo">
+<span class="sig-name descname"><span class="pre">frozen_halo</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.frozen_halo" title="Link to this definition">¶</a></dt>
+<dd><p>Temporarily disable halo exchanges inside a context manager.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>access_mode</strong> – Mode with which the data will subsequently be accessed.</p>
+</dd>
+</dl>
+<p>This is useful in cases where one is repeatedly writing to a <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> with
+the same access descriptor since the intermediate updates can be skipped.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.freeze_halo">
+<span class="sig-name descname"><span class="pre">freeze_halo</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.freeze_halo" title="Link to this definition">¶</a></dt>
+<dd><p>Disable halo exchanges.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>access_mode</strong> – Mode with which the data will subsequently be accessed.</p>
+</dd>
+</dl>
+<p>Note that some bookkeeping is needed when freezing halos. Prefer to use the
+<code class="xref py py-meth docutils literal notranslate"><span class="pre">Dat.frozen_halo()</span></code> context manager.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.AbstractDat.unfreeze_halo">
+<span class="sig-name descname"><span class="pre">unfreeze_halo</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.AbstractDat.unfreeze_halo" title="Link to this definition">¶</a></dt>
+<dd><p>Re-enable halo exchanges.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.dat.DatView">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.dat.</span></span><span class="sig-name descname"><span class="pre">DatView</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dat</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">index</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.DatView" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.dat.AbstractDat" title="pyop2.types.dat.AbstractDat"><code class="xref py py-class docutils literal notranslate"><span class="pre">AbstractDat</span></code></a></p>
+<p>An indexed view into a <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a>.</p>
+<p>This object can be used like a <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> but the kernel will
+only see the requested index, rather than the full data.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>dat</strong> – The <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> to create a view into.</p></li>
+<li><p><strong>index</strong> – The component to select a view of.</p></li>
+</ul>
+</dd>
+</dl>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.DatView.cdim">
+<span class="sig-name descname"><span class="pre">cdim</span></span><a class="headerlink" href="#pyop2.types.dat.DatView.cdim" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.DatView.dim">
+<span class="sig-name descname"><span class="pre">dim</span></span><a class="headerlink" href="#pyop2.types.dat.DatView.dim" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.DatView.shape">
+<span class="sig-name descname"><span class="pre">shape</span></span><a class="headerlink" href="#pyop2.types.dat.DatView.shape" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.DatView.halo_valid">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">halo_valid</span></span><a class="headerlink" href="#pyop2.types.dat.DatView.halo_valid" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.DatView.data">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data</span></span><a class="headerlink" href="#pyop2.types.dat.DatView.data" title="Link to this definition">¶</a></dt>
+<dd><p>Numpy array containing the data values.</p>
+<p>With this accessor you are claiming that you will modify
+the values you get back.  If you only need to look at the
+values, use <a class="reference internal" href="#pyop2.types.dat.DatView.data_ro" title="pyop2.types.dat.DatView.data_ro"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data_ro()</span></code></a> instead.</p>
+<p>This only shows local values, to see the halo values too use
+<a class="reference internal" href="#pyop2.types.dat.DatView.data_with_halos" title="pyop2.types.dat.DatView.data_with_halos"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data_with_halos()</span></code></a>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.DatView.data_ro">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_ro</span></span><a class="headerlink" href="#pyop2.types.dat.DatView.data_ro" title="Link to this definition">¶</a></dt>
+<dd><p>Numpy array containing the data values.  Read-only.</p>
+<p>With this accessor you are not allowed to modify the values
+you get back.  If you need to do so, use <a class="reference internal" href="#pyop2.types.dat.DatView.data" title="pyop2.types.dat.DatView.data"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data()</span></code></a> instead.</p>
+<p>This only shows local values, to see the halo values too use
+<a class="reference internal" href="#pyop2.types.dat.DatView.data_ro_with_halos" title="pyop2.types.dat.DatView.data_ro_with_halos"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data_ro_with_halos()</span></code></a>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.DatView.data_wo">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_wo</span></span><a class="headerlink" href="#pyop2.types.dat.DatView.data_wo" title="Link to this definition">¶</a></dt>
+<dd><p>Numpy array containing the data values that is only valid for writing to.</p>
+<p>This only shows local values, to see the halo values too use
+<a class="reference internal" href="#pyop2.types.dat.DatView.data_wo_with_halos" title="pyop2.types.dat.DatView.data_wo_with_halos"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data_wo_with_halos()</span></code></a>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.DatView.data_with_halos">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_with_halos</span></span><a class="headerlink" href="#pyop2.types.dat.DatView.data_with_halos" title="Link to this definition">¶</a></dt>
+<dd><p>A view of this <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a>s data.</p>
+<p>This accessor marks the <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> as dirty, see
+<a class="reference internal" href="#pyop2.types.dat.DatView.data" title="pyop2.types.dat.DatView.data"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data()</span></code></a> for more details on the semantics.</p>
+<p>With this accessor, you get to see up to date halo values, but
+you should not try and modify them, because they will be
+overwritten by the next halo exchange.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.DatView.data_ro_with_halos">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_ro_with_halos</span></span><a class="headerlink" href="#pyop2.types.dat.DatView.data_ro_with_halos" title="Link to this definition">¶</a></dt>
+<dd><p>A view of this <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a>s data.</p>
+<p>This accessor does not mark the <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> as dirty, and is
+a read only view, see <a class="reference internal" href="#pyop2.types.dat.DatView.data_ro" title="pyop2.types.dat.DatView.data_ro"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data_ro()</span></code></a> for more details on the
+semantics.</p>
+<p>With this accessor, you get to see up to date halo values, but
+you should not try and modify them, because they will be
+overwritten by the next halo exchange.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.DatView.data_wo_with_halos">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_wo_with_halos</span></span><a class="headerlink" href="#pyop2.types.dat.DatView.data_wo_with_halos" title="Link to this definition">¶</a></dt>
+<dd><p>Return a write-only view of all the data values.</p>
+<p>This method, unlike <a class="reference internal" href="#pyop2.types.dat.DatView.data_with_halos" title="pyop2.types.dat.DatView.data_with_halos"><code class="xref py py-meth docutils literal notranslate"><span class="pre">data_with_halos()</span></code></a>, avoids a halo exchange
+if the halo is dirty.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.dat.Dat">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.dat.</span></span><span class="sig-name descname"><span class="pre">Dat</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.Dat" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.dat.AbstractDat" title="pyop2.types.dat.AbstractDat"><code class="xref py py-class docutils literal notranslate"><span class="pre">AbstractDat</span></code></a>, <a class="reference internal" href="#pyop2.types.data_carrier.VecAccessMixin" title="pyop2.types.data_carrier.VecAccessMixin"><code class="xref py py-class docutils literal notranslate"><span class="pre">VecAccessMixin</span></code></a></p>
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.Dat.vec_context">
+<span class="sig-name descname"><span class="pre">vec_context</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.Dat.vec_context" title="Link to this definition">¶</a></dt>
+<dd><p>A context manager for a <code class="xref py py-class docutils literal notranslate"><span class="pre">PETSc.Vec</span></code> from a <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a>.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>access</strong> – Access descriptor: READ, WRITE, or RW.</p>
+</dd>
+</dl>
+</dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.dat.</span></span><span class="sig-name descname"><span class="pre">MixedDat</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">mdset_or_dats</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.MixedDat" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.dat.AbstractDat" title="pyop2.types.dat.AbstractDat"><code class="xref py py-class docutils literal notranslate"><span class="pre">AbstractDat</span></code></a>, <a class="reference internal" href="#pyop2.types.data_carrier.VecAccessMixin" title="pyop2.types.data_carrier.VecAccessMixin"><code class="xref py py-class docutils literal notranslate"><span class="pre">VecAccessMixin</span></code></a></p>
+<p>A container for a bag of <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a>s.</p>
+<p>Initialized either from a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDataSet</span></code>, a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedSet</span></code>, or
+an iterable of <code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code>s and/or <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code>s, where all the
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code>s are implcitly upcast to <code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code>s</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">mdat</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDat</span><span class="p">(</span><span class="n">mdset</span><span class="p">)</span>
+<span class="n">mdat</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDat</span><span class="p">([</span><span class="n">dset1</span><span class="p">,</span> <span class="o">...</span><span class="p">,</span> <span class="n">dsetN</span><span class="p">])</span>
+</pre></div>
+</div>
+<p>or from an iterable of <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a>s</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">mdat</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDat</span><span class="p">([</span><span class="n">dat1</span><span class="p">,</span> <span class="o">...</span><span class="p">,</span> <span class="n">datN</span><span class="p">])</span>
+</pre></div>
+</div>
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.dat_version">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">dat_version</span></span><a class="headerlink" href="#pyop2.types.dat.MixedDat.dat_version" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.increment_dat_version">
+<span class="sig-name descname"><span class="pre">increment_dat_version</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.MixedDat.increment_dat_version" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.dtype">
+<span class="sig-name descname"><span class="pre">dtype</span></span><a class="headerlink" href="#pyop2.types.dat.MixedDat.dtype" title="Link to this definition">¶</a></dt>
+<dd><p>The NumPy dtype of the data.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.split">
+<span class="sig-name descname"><span class="pre">split</span></span><a class="headerlink" href="#pyop2.types.dat.MixedDat.split" title="Link to this definition">¶</a></dt>
+<dd><p>The underlying tuple of <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a>s.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.dataset">
+<span class="sig-name descname"><span class="pre">dataset</span></span><a class="headerlink" href="#pyop2.types.dat.MixedDat.dataset" title="Link to this definition">¶</a></dt>
+<dd><p><code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDataSet</span></code>s this <a class="reference internal" href="#pyop2.types.dat.MixedDat" title="pyop2.types.dat.MixedDat"><code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code></a> is defined on.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.data">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data</span></span><a class="headerlink" href="#pyop2.types.dat.MixedDat.data" title="Link to this definition">¶</a></dt>
+<dd><p>Numpy arrays containing the data excluding halos.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.data_with_halos">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_with_halos</span></span><a class="headerlink" href="#pyop2.types.dat.MixedDat.data_with_halos" title="Link to this definition">¶</a></dt>
+<dd><p>Numpy arrays containing the data including halos.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.data_ro">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_ro</span></span><a class="headerlink" href="#pyop2.types.dat.MixedDat.data_ro" title="Link to this definition">¶</a></dt>
+<dd><p>Numpy arrays with read-only data excluding halos.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.data_ro_with_halos">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_ro_with_halos</span></span><a class="headerlink" href="#pyop2.types.dat.MixedDat.data_ro_with_halos" title="Link to this definition">¶</a></dt>
+<dd><p>Numpy arrays with read-only data including halos.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.data_wo">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_wo</span></span><a class="headerlink" href="#pyop2.types.dat.MixedDat.data_wo" title="Link to this definition">¶</a></dt>
+<dd><p>Numpy arrays with read-only data excluding halos.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.data_wo_with_halos">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_wo_with_halos</span></span><a class="headerlink" href="#pyop2.types.dat.MixedDat.data_wo_with_halos" title="Link to this definition">¶</a></dt>
+<dd><p>Numpy arrays with read-only data including halos.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.halo_valid">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">halo_valid</span></span><a class="headerlink" href="#pyop2.types.dat.MixedDat.halo_valid" title="Link to this definition">¶</a></dt>
+<dd><p>Does this Dat have up to date halos?</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.global_to_local_begin">
+<span class="sig-name descname"><span class="pre">global_to_local_begin</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.MixedDat.global_to_local_begin" title="Link to this definition">¶</a></dt>
+<dd><p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.global_to_local_end">
+<span class="sig-name descname"><span class="pre">global_to_local_end</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.MixedDat.global_to_local_end" title="Link to this definition">¶</a></dt>
+<dd><p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.local_to_global_begin">
+<span class="sig-name descname"><span class="pre">local_to_global_begin</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">insert_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.MixedDat.local_to_global_begin" title="Link to this definition">¶</a></dt>
+<dd><p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.local_to_global_end">
+<span class="sig-name descname"><span class="pre">local_to_global_end</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">insert_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.MixedDat.local_to_global_end" title="Link to this definition">¶</a></dt>
+<dd><p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.freeze_halo">
+<span class="sig-name descname"><span class="pre">freeze_halo</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.MixedDat.freeze_halo" title="Link to this definition">¶</a></dt>
+<dd><p>Disable halo exchanges.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.unfreeze_halo">
+<span class="sig-name descname"><span class="pre">unfreeze_halo</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.MixedDat.unfreeze_halo" title="Link to this definition">¶</a></dt>
+<dd><p>Re-enable halo exchanges.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.zero">
+<span class="sig-name descname"><span class="pre">zero</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">subset</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.MixedDat.zero" title="Link to this definition">¶</a></dt>
+<dd><p>Zero the data associated with this <a class="reference internal" href="#pyop2.types.dat.MixedDat" title="pyop2.types.dat.MixedDat"><code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code></a>.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>subset</strong> – optional subset of entries to zero (not implemented).</p>
+</dd>
+</dl>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.nbytes">
+<span class="sig-name descname"><span class="pre">nbytes</span></span><a class="headerlink" href="#pyop2.types.dat.MixedDat.nbytes" title="Link to this definition">¶</a></dt>
+<dd><p>Return an estimate of the size of the data associated with this
+<a class="reference internal" href="#pyop2.types.dat.MixedDat" title="pyop2.types.dat.MixedDat"><code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code></a> in bytes. This will be the correct size of the data
+payload, but does not take into account the (presumably small)
+overhead of the object and its metadata.</p>
+<p>Note that this is the process local memory usage, not the sum
+over all MPI processes.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.copy">
+<span class="sig-name descname"><span class="pre">copy</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">subset</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.MixedDat.copy" title="Link to this definition">¶</a></dt>
+<dd><p>Copy the data in this <a class="reference internal" href="#pyop2.types.dat.MixedDat" title="pyop2.types.dat.MixedDat"><code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code></a> into another.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>other</strong> – The destination <a class="reference internal" href="#pyop2.types.dat.MixedDat" title="pyop2.types.dat.MixedDat"><code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code></a></p></li>
+<li><p><strong>subset</strong> – Subsets are not supported, this must be <code class="xref py py-class docutils literal notranslate"><span class="pre">None</span></code></p></li>
+</ul>
+</dd>
+</dl>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.inner">
+<span class="sig-name descname"><span class="pre">inner</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.MixedDat.inner" title="Link to this definition">¶</a></dt>
+<dd><p>Compute the l2 inner product.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>other</strong> – the other <a class="reference internal" href="#pyop2.types.dat.MixedDat" title="pyop2.types.dat.MixedDat"><code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code></a> to compute the inner product against</p>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.dat.MixedDat.vec_context">
+<span class="sig-name descname"><span class="pre">vec_context</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.MixedDat.vec_context" title="Link to this definition">¶</a></dt>
+<dd><p>A context manager scattering the arrays of all components of this
+<a class="reference internal" href="#pyop2.types.dat.MixedDat" title="pyop2.types.dat.MixedDat"><code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code></a> into a contiguous <code class="xref py py-class docutils literal notranslate"><span class="pre">PETSc.Vec</span></code> and reverse
+scattering to the original arrays when exiting the context.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>access</strong> – Access descriptor: READ, WRITE, or RW.</p>
+</dd>
+</dl>
+<div class="admonition note">
+<p class="admonition-title">Note</p>
+<p>The <code class="xref py py-class docutils literal notranslate"><span class="pre">Vec</span></code> obtained from this context is in
+the correct order to be left multiplied by a compatible
+<code class="xref py py-class docutils literal notranslate"><span class="pre">MixedMat</span></code>.  In parallel it is <em>not</em> just a
+concatenation of the underlying <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a>s.</p>
+</div>
+</dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.dat.frozen_halo">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.dat.</span></span><span class="sig-name descname"><span class="pre">frozen_halo</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dat</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">access_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dat.frozen_halo" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></p>
+<p>Context manager handling the freezing and unfreezing of halos.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>dat</strong> – The <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> whose halo is to be frozen.</p></li>
+<li><p><strong>access_mode</strong> – Mode with which the <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code></a> will be accessed whilst
+its halo is frozen.</p></li>
+</ul>
+</dd>
+</dl>
+</dd></dl>
+
+</section>
+<section id="module-pyop2.types.data_carrier">
+<span id="pyop2-types-data-carrier-module"></span><h2>pyop2.types.data_carrier module<a class="headerlink" href="#module-pyop2.types.data_carrier" title="Link to this heading">¶</a></h2>
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.DataCarrier">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.data_carrier.</span></span><span class="sig-name descname"><span class="pre">DataCarrier</span></span><a class="headerlink" href="#pyop2.types.data_carrier.DataCarrier" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">ABC</span></code></p>
+<p>Abstract base class for OP2 data.</p>
+<p>Actual objects will be <a class="reference internal" href="#pyop2.types.data_carrier.DataCarrier" title="pyop2.types.data_carrier.DataCarrier"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataCarrier</span></code></a> objects of rank 0
+(<code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code>), rank 1 (<code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code>), or rank 2
+(<code class="xref py py-class docutils literal notranslate"><span class="pre">Mat</span></code>)</p>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.DataCarrier.dtype">
+<span class="sig-name descname"><span class="pre">dtype</span></span><a class="headerlink" href="#pyop2.types.data_carrier.DataCarrier.dtype" title="Link to this definition">¶</a></dt>
+<dd><p>The Python type of the data.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.DataCarrier.ctype">
+<span class="sig-name descname"><span class="pre">ctype</span></span><a class="headerlink" href="#pyop2.types.data_carrier.DataCarrier.ctype" title="Link to this definition">¶</a></dt>
+<dd><p>The c type of the data.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.DataCarrier.name">
+<span class="sig-name descname"><span class="pre">name</span></span><a class="headerlink" href="#pyop2.types.data_carrier.DataCarrier.name" title="Link to this definition">¶</a></dt>
+<dd><p>User-defined label.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.DataCarrier.dim">
+<span class="sig-name descname"><span class="pre">dim</span></span><a class="headerlink" href="#pyop2.types.data_carrier.DataCarrier.dim" title="Link to this definition">¶</a></dt>
+<dd><p>The shape tuple of the values for each element of the object.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.DataCarrier.cdim">
+<span class="sig-name descname"><span class="pre">cdim</span></span><a class="headerlink" href="#pyop2.types.data_carrier.DataCarrier.cdim" title="Link to this definition">¶</a></dt>
+<dd><p>The scalar number of values for each member of the object. This is
+the product of the dim tuple.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.DataCarrier.increment_dat_version">
+<span class="sig-name descname"><span class="pre">increment_dat_version</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.data_carrier.DataCarrier.increment_dat_version" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.EmptyDataMixin">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.data_carrier.</span></span><span class="sig-name descname"><span class="pre">EmptyDataMixin</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">data</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">dtype</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">shape</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.data_carrier.EmptyDataMixin" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">ABC</span></code></p>
+<p>A mixin for <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> and <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code> objects that takes
+care of allocating data on demand if the user has passed nothing
+in.</p>
+<p>Accessing the <code class="xref py py-attr docutils literal notranslate"><span class="pre">_data</span></code> property allocates a zeroed data array
+if it does not already exist.</p>
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.VecAccessMixin">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.data_carrier.</span></span><span class="sig-name descname"><span class="pre">VecAccessMixin</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">petsc_counter</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.data_carrier.VecAccessMixin" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">ABC</span></code></p>
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.VecAccessMixin.dat_version">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">dat_version</span></span><a class="headerlink" href="#pyop2.types.data_carrier.VecAccessMixin.dat_version" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.VecAccessMixin.vec_context">
+<em class="property"><span class="pre">abstract</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">vec_context</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.data_carrier.VecAccessMixin.vec_context" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.VecAccessMixin.vec">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">vec</span></span><a class="headerlink" href="#pyop2.types.data_carrier.VecAccessMixin.vec" title="Link to this definition">¶</a></dt>
+<dd><p>Context manager for a PETSc Vec appropriate for this Dat.</p>
+<p>You’re allowed to modify the data you get back from this view.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.VecAccessMixin.vec_wo">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">vec_wo</span></span><a class="headerlink" href="#pyop2.types.data_carrier.VecAccessMixin.vec_wo" title="Link to this definition">¶</a></dt>
+<dd><p>Context manager for a PETSc Vec appropriate for this Dat.</p>
+<p>You’re allowed to modify the data you get back from this view,
+but you cannot read from it.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.data_carrier.VecAccessMixin.vec_ro">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">vec_ro</span></span><a class="headerlink" href="#pyop2.types.data_carrier.VecAccessMixin.vec_ro" title="Link to this definition">¶</a></dt>
+<dd><p>Context manager for a PETSc Vec appropriate for this Dat.</p>
+<p>You’re not allowed to modify the data you get back from this view.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+</dd></dl>
+
+</section>
+<section id="module-pyop2.types.dataset">
+<span id="pyop2-types-dataset-module"></span><h2>pyop2.types.dataset module<a class="headerlink" href="#module-pyop2.types.dataset" title="Link to this heading">¶</a></h2>
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.dataset.DataSet">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.dataset.</span></span><span class="sig-name descname"><span class="pre">DataSet</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dataset.DataSet" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">ObjectCached</span></code></p>
+<p>PyOP2 Data Set</p>
+<p>Set used in the op2.Dat structures to specify the dimension of the data.</p>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.DataSet.dim">
+<span class="sig-name descname"><span class="pre">dim</span></span><a class="headerlink" href="#pyop2.types.dataset.DataSet.dim" title="Link to this definition">¶</a></dt>
+<dd><p>The shape tuple of the values for each element of the set.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.DataSet.cdim">
+<span class="sig-name descname"><span class="pre">cdim</span></span><a class="headerlink" href="#pyop2.types.dataset.DataSet.cdim" title="Link to this definition">¶</a></dt>
+<dd><p>The scalar number of values for each member of the set. This is
+the product of the dim tuple.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.DataSet.name">
+<span class="sig-name descname"><span class="pre">name</span></span><a class="headerlink" href="#pyop2.types.dataset.DataSet.name" title="Link to this definition">¶</a></dt>
+<dd><p>Returns the name of the data set.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.DataSet.set">
+<span class="sig-name descname"><span class="pre">set</span></span><a class="headerlink" href="#pyop2.types.dataset.DataSet.set" title="Link to this definition">¶</a></dt>
+<dd><p>Returns the parent set of the data set.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.DataSet.lgmap">
+<span class="sig-name descname"><span class="pre">lgmap</span></span><a class="headerlink" href="#pyop2.types.dataset.DataSet.lgmap" title="Link to this definition">¶</a></dt>
+<dd><p>A PETSc LGMap mapping process-local indices to global
+indices for this <a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a>.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.DataSet.scalar_lgmap">
+<span class="sig-name descname"><span class="pre">scalar_lgmap</span></span><a class="headerlink" href="#pyop2.types.dataset.DataSet.scalar_lgmap" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.DataSet.unblocked_lgmap">
+<span class="sig-name descname"><span class="pre">unblocked_lgmap</span></span><a class="headerlink" href="#pyop2.types.dataset.DataSet.unblocked_lgmap" title="Link to this definition">¶</a></dt>
+<dd><p>A PETSc LGMap mapping process-local indices to global
+indices for this <a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a> with a block size of 1.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.DataSet.field_ises">
+<span class="sig-name descname"><span class="pre">field_ises</span></span><a class="headerlink" href="#pyop2.types.dataset.DataSet.field_ises" title="Link to this definition">¶</a></dt>
+<dd><p>A list of PETSc ISes defining the global indices for each set in
+the DataSet.</p>
+<p>Used when extracting blocks from matrices for solvers.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.DataSet.local_ises">
+<span class="sig-name descname"><span class="pre">local_ises</span></span><a class="headerlink" href="#pyop2.types.dataset.DataSet.local_ises" title="Link to this definition">¶</a></dt>
+<dd><p>A list of PETSc ISes defining the local indices for each set in the DataSet.</p>
+<p>Used when extracting blocks from matrices for assembly.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.DataSet.layout_vec">
+<span class="sig-name descname"><span class="pre">layout_vec</span></span><a class="headerlink" href="#pyop2.types.dataset.DataSet.layout_vec" title="Link to this definition">¶</a></dt>
+<dd><p>A PETSc Vec compatible with the dof layout of this DataSet.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.DataSet.dm">
+<span class="sig-name descname"><span class="pre">dm</span></span><a class="headerlink" href="#pyop2.types.dataset.DataSet.dm" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.dataset.GlobalDataSet">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.dataset.</span></span><span class="sig-name descname"><span class="pre">GlobalDataSet</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dataset.GlobalDataSet" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a></p>
+<p>A proxy <a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a> for use in a <code class="xref py py-class docutils literal notranslate"><span class="pre">Sparsity</span></code> where the
+matrix has <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code> rows or columns.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>global</strong> – The <code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code> on which this object is based.</p>
+</dd>
+</dl>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.GlobalDataSet.dim">
+<span class="sig-name descname"><span class="pre">dim</span></span><a class="headerlink" href="#pyop2.types.dataset.GlobalDataSet.dim" title="Link to this definition">¶</a></dt>
+<dd><p>The shape tuple of the values for each element of the set.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.GlobalDataSet.cdim">
+<span class="sig-name descname"><span class="pre">cdim</span></span><a class="headerlink" href="#pyop2.types.dataset.GlobalDataSet.cdim" title="Link to this definition">¶</a></dt>
+<dd><p>The scalar number of values for each member of the set. This is
+the product of the dim tuple.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.GlobalDataSet.name">
+<span class="sig-name descname"><span class="pre">name</span></span><a class="headerlink" href="#pyop2.types.dataset.GlobalDataSet.name" title="Link to this definition">¶</a></dt>
+<dd><p>Returns the name of the data set.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.GlobalDataSet.set">
+<span class="sig-name descname"><span class="pre">set</span></span><a class="headerlink" href="#pyop2.types.dataset.GlobalDataSet.set" title="Link to this definition">¶</a></dt>
+<dd><p>Returns the parent set of the data set.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.GlobalDataSet.size">
+<span class="sig-name descname"><span class="pre">size</span></span><a class="headerlink" href="#pyop2.types.dataset.GlobalDataSet.size" title="Link to this definition">¶</a></dt>
+<dd><p>The number of local entries in the Dataset (1 on rank 0)</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.GlobalDataSet.lgmap">
+<span class="sig-name descname"><span class="pre">lgmap</span></span><a class="headerlink" href="#pyop2.types.dataset.GlobalDataSet.lgmap" title="Link to this definition">¶</a></dt>
+<dd><p>A PETSc LGMap mapping process-local indices to global
+indices for this <a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a>.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.GlobalDataSet.unblocked_lgmap">
+<span class="sig-name descname"><span class="pre">unblocked_lgmap</span></span><a class="headerlink" href="#pyop2.types.dataset.GlobalDataSet.unblocked_lgmap" title="Link to this definition">¶</a></dt>
+<dd><p>A PETSc LGMap mapping process-local indices to global
+indices for this <a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a> with a block size of 1.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.GlobalDataSet.local_ises">
+<span class="sig-name descname"><span class="pre">local_ises</span></span><a class="headerlink" href="#pyop2.types.dataset.GlobalDataSet.local_ises" title="Link to this definition">¶</a></dt>
+<dd><p>A list of PETSc ISes defining the local indices for each set in the DataSet.</p>
+<p>Used when extracting blocks from matrices for assembly.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.GlobalDataSet.layout_vec">
+<span class="sig-name descname"><span class="pre">layout_vec</span></span><a class="headerlink" href="#pyop2.types.dataset.GlobalDataSet.layout_vec" title="Link to this definition">¶</a></dt>
+<dd><p>A PETSc Vec compatible with the dof layout of this DataSet.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.GlobalDataSet.dm">
+<span class="sig-name descname"><span class="pre">dm</span></span><a class="headerlink" href="#pyop2.types.dataset.GlobalDataSet.dm" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.dataset.MixedDataSet">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.dataset.</span></span><span class="sig-name descname"><span class="pre">MixedDataSet</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.dataset.MixedDataSet" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a></p>
+<p>A container for a bag of <a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a>s.</p>
+<p>Initialized either from a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedSet</span></code> and an iterable or iterator of
+<code class="docutils literal notranslate"><span class="pre">dims</span></code> of corresponding length</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">mdset</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDataSet</span><span class="p">(</span><span class="n">mset</span><span class="p">,</span> <span class="p">[</span><span class="n">dim1</span><span class="p">,</span> <span class="o">...</span><span class="p">,</span> <span class="n">dimN</span><span class="p">])</span>
+</pre></div>
+</div>
+<p>or from a tuple of <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code>s and an iterable of <code class="docutils literal notranslate"><span class="pre">dims</span></code> of
+corresponding length</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">mdset</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDataSet</span><span class="p">([</span><span class="n">set1</span><span class="p">,</span> <span class="o">...</span><span class="p">,</span> <span class="n">setN</span><span class="p">],</span> <span class="p">[</span><span class="n">dim1</span><span class="p">,</span> <span class="o">...</span><span class="p">,</span> <span class="n">dimN</span><span class="p">])</span>
+</pre></div>
+</div>
+<p>If all <code class="docutils literal notranslate"><span class="pre">dims</span></code> are to be the same, they can also be given as an
+<code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code> for either of above invocations</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">mdset</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDataSet</span><span class="p">(</span><span class="n">mset</span><span class="p">,</span> <span class="n">dim</span><span class="p">)</span>
+<span class="n">mdset</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDataSet</span><span class="p">([</span><span class="n">set1</span><span class="p">,</span> <span class="o">...</span><span class="p">,</span> <span class="n">setN</span><span class="p">],</span> <span class="n">dim</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>Initialized from a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedSet</span></code> without explicitly specifying <code class="docutils literal notranslate"><span class="pre">dims</span></code>
+they default to 1</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">mdset</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDataSet</span><span class="p">(</span><span class="n">mset</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>Initialized from an iterable or iterator of <a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a>s and/or
+<code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code>s, where <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code>s are implicitly upcast to
+<a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a>s of dim 1</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">mdset</span> <span class="o">=</span> <span class="n">op2</span><span class="o">.</span><span class="n">MixedDataSet</span><span class="p">([</span><span class="n">dset1</span><span class="p">,</span> <span class="o">...</span><span class="p">,</span> <span class="n">dsetN</span><span class="p">])</span>
+</pre></div>
+</div>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>arg</strong> – a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedSet</span></code> or an iterable or a generator
+expression of <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code>s or <a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a>s or a
+mixture of both</p></li>
+<li><p><strong>dims</strong> – <cite>None</cite> (the default) or an <code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code> or an iterable or
+generator expression of <code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code>s, which <strong>must</strong> be
+of same length as <cite>arg</cite></p></li>
+</ul>
+</dd>
+</dl>
+<div class="admonition warning">
+<p class="admonition-title">Warning</p>
+<p>When using generator expressions for <code class="docutils literal notranslate"><span class="pre">arg</span></code> or <code class="docutils literal notranslate"><span class="pre">dims</span></code>, these
+<strong>must</strong> terminate or else will cause an infinite loop.</p>
+</div>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.MixedDataSet.split">
+<span class="sig-name descname"><span class="pre">split</span></span><a class="headerlink" href="#pyop2.types.dataset.MixedDataSet.split" title="Link to this definition">¶</a></dt>
+<dd><p>The underlying tuple of <a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a>s.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.MixedDataSet.dim">
+<span class="sig-name descname"><span class="pre">dim</span></span><a class="headerlink" href="#pyop2.types.dataset.MixedDataSet.dim" title="Link to this definition">¶</a></dt>
+<dd><p>The shape tuple of the values for each element of the sets.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.MixedDataSet.cdim">
+<span class="sig-name descname"><span class="pre">cdim</span></span><a class="headerlink" href="#pyop2.types.dataset.MixedDataSet.cdim" title="Link to this definition">¶</a></dt>
+<dd><p>The sum of the scalar number of values for each member of the sets.
+This is the sum of products of the dim tuples.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.MixedDataSet.name">
+<span class="sig-name descname"><span class="pre">name</span></span><a class="headerlink" href="#pyop2.types.dataset.MixedDataSet.name" title="Link to this definition">¶</a></dt>
+<dd><p>Returns the name of the data sets.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.MixedDataSet.set">
+<span class="sig-name descname"><span class="pre">set</span></span><a class="headerlink" href="#pyop2.types.dataset.MixedDataSet.set" title="Link to this definition">¶</a></dt>
+<dd><p>Returns the <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedSet</span></code> this <a class="reference internal" href="#pyop2.types.dataset.MixedDataSet" title="pyop2.types.dataset.MixedDataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDataSet</span></code></a> is
+defined on.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.MixedDataSet.layout_vec">
+<span class="sig-name descname"><span class="pre">layout_vec</span></span><a class="headerlink" href="#pyop2.types.dataset.MixedDataSet.layout_vec" title="Link to this definition">¶</a></dt>
+<dd><p>A PETSc Vec compatible with the dof layout of this MixedDataSet.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.MixedDataSet.lgmap">
+<span class="sig-name descname"><span class="pre">lgmap</span></span><a class="headerlink" href="#pyop2.types.dataset.MixedDataSet.lgmap" title="Link to this definition">¶</a></dt>
+<dd><p>A PETSc LGMap mapping process-local indices to global
+indices for this <a class="reference internal" href="#pyop2.types.dataset.MixedDataSet" title="pyop2.types.dataset.MixedDataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDataSet</span></code></a>.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.dataset.MixedDataSet.unblocked_lgmap">
+<span class="sig-name descname"><span class="pre">unblocked_lgmap</span></span><a class="headerlink" href="#pyop2.types.dataset.MixedDataSet.unblocked_lgmap" title="Link to this definition">¶</a></dt>
+<dd><p>A PETSc LGMap mapping process-local indices to global
+indices for this <a class="reference internal" href="#pyop2.types.dataset.DataSet" title="pyop2.types.dataset.DataSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataSet</span></code></a> with a block size of 1.</p>
+</dd></dl>
+
+</dd></dl>
+
+</section>
+<section id="module-pyop2.types.glob">
+<span id="pyop2-types-glob-module"></span><h2>pyop2.types.glob module<a class="headerlink" href="#module-pyop2.types.glob" title="Link to this heading">¶</a></h2>
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.glob.</span></span><span class="sig-name descname"><span class="pre">SetFreeDataCarrier</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dim</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">data</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">dtype</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">name</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.data_carrier.DataCarrier" title="pyop2.types.data_carrier.DataCarrier"><code class="xref py py-class docutils literal notranslate"><span class="pre">DataCarrier</span></code></a>, <a class="reference internal" href="#pyop2.types.data_carrier.EmptyDataMixin" title="pyop2.types.data_carrier.EmptyDataMixin"><code class="xref py py-class docutils literal notranslate"><span class="pre">EmptyDataMixin</span></code></a></p>
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.shape">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">shape</span></span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.shape" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.dtype">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">dtype</span></span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.dtype" title="Link to this definition">¶</a></dt>
+<dd><p>The Python type of the data.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.data_ro">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_ro</span></span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.data_ro" title="Link to this definition">¶</a></dt>
+<dd><p>Data array.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.data_wo">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_wo</span></span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.data_wo" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.data">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data</span></span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.data" title="Link to this definition">¶</a></dt>
+<dd><p>Data array.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.data_with_halos">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_with_halos</span></span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.data_with_halos" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.data_ro_with_halos">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_ro_with_halos</span></span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.data_ro_with_halos" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.data_wo_with_halos">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">data_wo_with_halos</span></span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.data_wo_with_halos" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.halo_valid">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">halo_valid</span></span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.halo_valid" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.copy">
+<span class="sig-name descname"><span class="pre">copy</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">subset</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.copy" title="Link to this definition">¶</a></dt>
+<dd><p>Copy the data in this <a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier" title="pyop2.types.glob.SetFreeDataCarrier"><code class="xref py py-class docutils literal notranslate"><span class="pre">SetFreeDataCarrier</span></code></a> into another.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>other</strong> – The destination <a class="reference internal" href="#pyop2.types.glob.Global" title="pyop2.types.glob.Global"><code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code></a></p></li>
+<li><p><strong>subset</strong> – A <code class="xref py py-class docutils literal notranslate"><span class="pre">Subset</span></code> of elements to copy (optional)</p></li>
+</ul>
+</dd>
+</dl>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.split">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">split</span></span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.split" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.nbytes">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">nbytes</span></span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.nbytes" title="Link to this definition">¶</a></dt>
+<dd><p>Return an estimate of the size of the data associated with this
+<a class="reference internal" href="#pyop2.types.glob.Global" title="pyop2.types.glob.Global"><code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code></a> in bytes. This will be the correct size of the
+data payload, but does not take into account the overhead of
+the object and its metadata. This renders this method of
+little statistical significance, however it is included to
+make the interface consistent.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.SetFreeDataCarrier.inner">
+<span class="sig-name descname"><span class="pre">inner</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.SetFreeDataCarrier.inner" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.glob.Global">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.glob.</span></span><span class="sig-name descname"><span class="pre">Global</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dim</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">data</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">dtype</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">name</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">comm</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Global" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier" title="pyop2.types.glob.SetFreeDataCarrier"><code class="xref py py-class docutils literal notranslate"><span class="pre">SetFreeDataCarrier</span></code></a>, <a class="reference internal" href="#pyop2.types.data_carrier.VecAccessMixin" title="pyop2.types.data_carrier.VecAccessMixin"><code class="xref py py-class docutils literal notranslate"><span class="pre">VecAccessMixin</span></code></a></p>
+<p>OP2 global value.</p>
+<p>When a <code class="docutils literal notranslate"><span class="pre">Global</span></code> is passed to a <code class="xref py py-func docutils literal notranslate"><span class="pre">pyop2.op2.par_loop()</span></code>, the access
+descriptor is passed by <cite>calling</cite> the <code class="docutils literal notranslate"><span class="pre">Global</span></code>.  For example, if
+a <code class="docutils literal notranslate"><span class="pre">Global</span></code> named <code class="docutils literal notranslate"><span class="pre">G</span></code> is to be accessed for reading, this is
+accomplished by:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">G</span><span class="p">(</span><span class="n">pyop2</span><span class="o">.</span><span class="n">READ</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>It is permissible to pass <cite>None</cite> as the <cite>data</cite> argument.  In this
+case, allocation of the data buffer is postponed until it is
+accessed.</p>
+<div class="admonition note">
+<p class="admonition-title">Note</p>
+<p>If the data buffer is not passed in, it is implicitly
+initialised to be zero.</p>
+</div>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.glob.Global.dataset">
+<span class="sig-name descname"><span class="pre">dataset</span></span><a class="headerlink" href="#pyop2.types.glob.Global.dataset" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.Global.duplicate">
+<span class="sig-name descname"><span class="pre">duplicate</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Global.duplicate" title="Link to this definition">¶</a></dt>
+<dd><p>Return a deep copy of self.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.Global.zero">
+<span class="sig-name descname"><span class="pre">zero</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">subset</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Global.zero" title="Link to this definition">¶</a></dt>
+<dd><p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.Global.global_to_local_begin">
+<span class="sig-name descname"><span class="pre">global_to_local_begin</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Global.global_to_local_begin" title="Link to this definition">¶</a></dt>
+<dd><p>Dummy halo operation for the case in which a <a class="reference internal" href="#pyop2.types.glob.Global" title="pyop2.types.glob.Global"><code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code></a> forms
+part of a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.Global.global_to_local_end">
+<span class="sig-name descname"><span class="pre">global_to_local_end</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Global.global_to_local_end" title="Link to this definition">¶</a></dt>
+<dd><p>Dummy halo operation for the case in which a <a class="reference internal" href="#pyop2.types.glob.Global" title="pyop2.types.glob.Global"><code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code></a> forms
+part of a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.Global.local_to_global_begin">
+<span class="sig-name descname"><span class="pre">local_to_global_begin</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">insert_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Global.local_to_global_begin" title="Link to this definition">¶</a></dt>
+<dd><p>Dummy halo operation for the case in which a <a class="reference internal" href="#pyop2.types.glob.Global" title="pyop2.types.glob.Global"><code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code></a> forms
+part of a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.Global.local_to_global_end">
+<span class="sig-name descname"><span class="pre">local_to_global_end</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">insert_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Global.local_to_global_end" title="Link to this definition">¶</a></dt>
+<dd><p>Dummy halo operation for the case in which a <a class="reference internal" href="#pyop2.types.glob.Global" title="pyop2.types.glob.Global"><code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code></a> forms
+part of a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.Global.frozen_halo">
+<span class="sig-name descname"><span class="pre">frozen_halo</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Global.frozen_halo" title="Link to this definition">¶</a></dt>
+<dd><p>Dummy halo operation for the case in which a <a class="reference internal" href="#pyop2.types.glob.Global" title="pyop2.types.glob.Global"><code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code></a> forms
+part of a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.Global.freeze_halo">
+<span class="sig-name descname"><span class="pre">freeze_halo</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Global.freeze_halo" title="Link to this definition">¶</a></dt>
+<dd><p>Dummy halo operation for the case in which a <a class="reference internal" href="#pyop2.types.glob.Global" title="pyop2.types.glob.Global"><code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code></a> forms
+part of a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.Global.unfreeze_halo">
+<span class="sig-name descname"><span class="pre">unfreeze_halo</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Global.unfreeze_halo" title="Link to this definition">¶</a></dt>
+<dd><p>Dummy halo operation for the case in which a <a class="reference internal" href="#pyop2.types.glob.Global" title="pyop2.types.glob.Global"><code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code></a> forms
+part of a <code class="xref py py-class docutils literal notranslate"><span class="pre">MixedDat</span></code>.</p>
+<p>This function is logically collective over MPI ranks, it is an
+error to call it on fewer than all the ranks in MPI communicator.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.Global.vec_context">
+<span class="sig-name descname"><span class="pre">vec_context</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">access</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Global.vec_context" title="Link to this definition">¶</a></dt>
+<dd><p>A context manager for a <code class="xref py py-class docutils literal notranslate"><span class="pre">PETSc.Vec</span></code> from a <a class="reference internal" href="#pyop2.types.glob.Global" title="pyop2.types.glob.Global"><code class="xref py py-class docutils literal notranslate"><span class="pre">Global</span></code></a>.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>access</strong> – Access descriptor: READ, WRITE, or RW.</p>
+</dd>
+</dl>
+</dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.glob.Constant">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.glob.</span></span><span class="sig-name descname"><span class="pre">Constant</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dim</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">data</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">dtype</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">name</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">comm</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Constant" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier" title="pyop2.types.glob.SetFreeDataCarrier"><code class="xref py py-class docutils literal notranslate"><span class="pre">SetFreeDataCarrier</span></code></a></p>
+<p>OP2 constant value.</p>
+<p>When a <code class="docutils literal notranslate"><span class="pre">Constant</span></code> is passed to a <code class="xref py py-func docutils literal notranslate"><span class="pre">pyop2.op2.par_loop()</span></code>, the access
+descriptor is always <code class="docutils literal notranslate"><span class="pre">Access.READ</span></code>. Used in cases where collective
+functionality is not required, or is not desirable.
+For example: objects with no associated mesh and do not have a
+communicator.</p>
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.glob.Constant.duplicate">
+<span class="sig-name descname"><span class="pre">duplicate</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.glob.Constant.duplicate" title="Link to this definition">¶</a></dt>
+<dd><p>Return a deep copy of self.</p>
+</dd></dl>
+
+</dd></dl>
+
+</section>
+<section id="module-pyop2.types.halo">
+<span id="pyop2-types-halo-module"></span><h2>pyop2.types.halo module<a class="headerlink" href="#module-pyop2.types.halo" title="Link to this heading">¶</a></h2>
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.halo.Halo">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.halo.</span></span><span class="sig-name descname"><span class="pre">Halo</span></span><a class="headerlink" href="#pyop2.types.halo.Halo" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">ABC</span></code></p>
+<p>A description of a halo associated with a <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.types.set.Set</span></code></a>.</p>
+<p>The halo object describes which <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.types.set.Set</span></code></a> elements are sent
+where, and which <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.types.set.Set</span></code></a> elements are received from where.</p>
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.halo.Halo.comm">
+<em class="property"><span class="pre">abstract</span><span class="w"> </span><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">comm</span></span><a class="headerlink" href="#pyop2.types.halo.Halo.comm" title="Link to this definition">¶</a></dt>
+<dd><p>The MPI communicator for this halo.</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.halo.Halo.local_to_global_numbering">
+<em class="property"><span class="pre">abstract</span><span class="w"> </span><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">local_to_global_numbering</span></span><a class="headerlink" href="#pyop2.types.halo.Halo.local_to_global_numbering" title="Link to this definition">¶</a></dt>
+<dd><p>The mapping from process-local to process-global numbers for this halo.</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.halo.Halo.global_to_local_begin">
+<em class="property"><span class="pre">abstract</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">global_to_local_begin</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dat</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">insert_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.halo.Halo.global_to_local_begin" title="Link to this definition">¶</a></dt>
+<dd><p>Begin an exchange from global (assembled) to local (ghosted) representation.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>dat</strong> – The <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.types.dat.Dat</span></code></a> to exchange.</p></li>
+<li><p><strong>insert_mode</strong> – The insertion mode.</p></li>
+</ul>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.halo.Halo.global_to_local_end">
+<em class="property"><span class="pre">abstract</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">global_to_local_end</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dat</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">insert_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.halo.Halo.global_to_local_end" title="Link to this definition">¶</a></dt>
+<dd><p>Finish an exchange from global (assembled) to local (ghosted) representation.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>dat</strong> – The <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.types.dat.Dat</span></code></a> to exchange.</p></li>
+<li><p><strong>insert_mode</strong> – The insertion mode.</p></li>
+</ul>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.halo.Halo.local_to_global_begin">
+<em class="property"><span class="pre">abstract</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">local_to_global_begin</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dat</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">insert_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.halo.Halo.local_to_global_begin" title="Link to this definition">¶</a></dt>
+<dd><p>Begin an exchange from local (ghosted) to global (assembled) representation.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>dat</strong> – The <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.types.dat.Dat</span></code></a> to exchange.</p></li>
+<li><p><strong>insert_mode</strong> – The insertion mode.</p></li>
+</ul>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.halo.Halo.local_to_global_end">
+<em class="property"><span class="pre">abstract</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">local_to_global_end</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">dat</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">insert_mode</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.halo.Halo.local_to_global_end" title="Link to this definition">¶</a></dt>
+<dd><p>Finish an exchange from local (ghosted) to global (assembled) representation.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>dat</strong> – The <a class="reference internal" href="#pyop2.types.dat.Dat" title="pyop2.types.dat.Dat"><code class="xref py py-class docutils literal notranslate"><span class="pre">pyop2.types.dat.Dat</span></code></a> to exchange.</p></li>
+<li><p><strong>insert_mode</strong> – The insertion mode.</p></li>
+</ul>
+</dd>
+</dl>
+</dd></dl>
+
+</dd></dl>
+
+</section>
+<section id="module-pyop2.types.map">
+<span id="pyop2-types-map-module"></span><h2>pyop2.types.map module<a class="headerlink" href="#module-pyop2.types.map" title="Link to this heading">¶</a></h2>
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.map.Map">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.map.</span></span><span class="sig-name descname"><span class="pre">Map</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">iterset</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">toset</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">arity</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">values</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">name</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">offset</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">offset_quotient</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.map.Map" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></p>
+<p>OP2 map, a relation between two <code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> objects.</p>
+<p>Each entry in the <code class="docutils literal notranslate"><span class="pre">iterset</span></code> maps to <code class="docutils literal notranslate"><span class="pre">arity</span></code> entries in the
+<code class="docutils literal notranslate"><span class="pre">toset</span></code>. When a map is used in a <code class="xref py py-func docutils literal notranslate"><span class="pre">pyop2.op2.par_loop()</span></code>, it is
+possible to use Python index notation to select an individual entry on the
+right hand side of this map. There are three possibilities:</p>
+<ul class="simple">
+<li><p>No index. All <code class="docutils literal notranslate"><span class="pre">arity</span></code> <code class="xref py py-class docutils literal notranslate"><span class="pre">Dat</span></code> entries will be passed to the
+kernel.</p></li>
+<li><p>An integer: <code class="docutils literal notranslate"><span class="pre">some_map[n]</span></code>. The <code class="docutils literal notranslate"><span class="pre">n</span></code> th entry of the
+map result will be passed to the kernel.</p></li>
+</ul>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.dtype">
+<span class="sig-name descname"><span class="pre">dtype</span></span><em class="property"><span class="w"> </span><span class="p"><span class="pre">=</span></span><span class="w"> </span><span class="pre">dtype('int32')</span></em><a class="headerlink" href="#pyop2.types.map.Map.dtype" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.split">
+<span class="sig-name descname"><span class="pre">split</span></span><a class="headerlink" href="#pyop2.types.map.Map.split" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.iterset">
+<span class="sig-name descname"><span class="pre">iterset</span></span><a class="headerlink" href="#pyop2.types.map.Map.iterset" title="Link to this definition">¶</a></dt>
+<dd><p><code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> mapped from.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.toset">
+<span class="sig-name descname"><span class="pre">toset</span></span><a class="headerlink" href="#pyop2.types.map.Map.toset" title="Link to this definition">¶</a></dt>
+<dd><p><code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code> mapped to.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.arity">
+<span class="sig-name descname"><span class="pre">arity</span></span><a class="headerlink" href="#pyop2.types.map.Map.arity" title="Link to this definition">¶</a></dt>
+<dd><p>Arity of the mapping: number of toset elements mapped to per
+iterset element.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.arities">
+<span class="sig-name descname"><span class="pre">arities</span></span><a class="headerlink" href="#pyop2.types.map.Map.arities" title="Link to this definition">¶</a></dt>
+<dd><p>Arity of the mapping: number of toset elements mapped to per
+iterset element.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Return type<span class="colon">:</span></dt>
+<dd class="field-odd"><p>tuple</p>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.arange">
+<span class="sig-name descname"><span class="pre">arange</span></span><a class="headerlink" href="#pyop2.types.map.Map.arange" title="Link to this definition">¶</a></dt>
+<dd><p>Tuple of arity offsets for each constituent <a class="reference internal" href="#pyop2.types.map.Map" title="pyop2.types.map.Map"><code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code></a>.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.values">
+<span class="sig-name descname"><span class="pre">values</span></span><a class="headerlink" href="#pyop2.types.map.Map.values" title="Link to this definition">¶</a></dt>
+<dd><p>Mapping array.</p>
+<p>This only returns the map values for local points, to see the
+halo points too, use <a class="reference internal" href="#pyop2.types.map.Map.values_with_halo" title="pyop2.types.map.Map.values_with_halo"><code class="xref py py-meth docutils literal notranslate"><span class="pre">values_with_halo()</span></code></a>.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.values_with_halo">
+<span class="sig-name descname"><span class="pre">values_with_halo</span></span><a class="headerlink" href="#pyop2.types.map.Map.values_with_halo" title="Link to this definition">¶</a></dt>
+<dd><p>Mapping array.</p>
+<p>This returns all map values (including halo points), see
+<a class="reference internal" href="#pyop2.types.map.Map.values" title="pyop2.types.map.Map.values"><code class="xref py py-meth docutils literal notranslate"><span class="pre">values()</span></code></a> if you only need to look at the local
+points.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.name">
+<span class="sig-name descname"><span class="pre">name</span></span><a class="headerlink" href="#pyop2.types.map.Map.name" title="Link to this definition">¶</a></dt>
+<dd><p>User-defined label</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.offset">
+<span class="sig-name descname"><span class="pre">offset</span></span><a class="headerlink" href="#pyop2.types.map.Map.offset" title="Link to this definition">¶</a></dt>
+<dd><p>The vertical offset.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.offset_quotient">
+<span class="sig-name descname"><span class="pre">offset_quotient</span></span><a class="headerlink" href="#pyop2.types.map.Map.offset_quotient" title="Link to this definition">¶</a></dt>
+<dd><p>The offset quotient.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.Map.flattened_maps">
+<span class="sig-name descname"><span class="pre">flattened_maps</span></span><a class="headerlink" href="#pyop2.types.map.Map.flattened_maps" title="Link to this definition">¶</a></dt>
+<dd><p>Return all component maps.</p>
+<p>This is useful to flatten nested :class:<a href="#id1"><span class="problematic" id="id2">`</span></a>ComposedMap`s.</p>
+</dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.map.PermutedMap">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.map.</span></span><span class="sig-name descname"><span class="pre">PermutedMap</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">map_</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">permutation</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.map.PermutedMap" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.map.Map" title="pyop2.types.map.Map"><code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code></a></p>
+<p>Composition of a standard <a class="reference internal" href="#pyop2.types.map.Map" title="pyop2.types.map.Map"><code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code></a> with a constant permutation.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>map</strong> – The map to permute.</p></li>
+<li><p><strong>permutation</strong> – The permutation of the map indices.</p></li>
+</ul>
+</dd>
+</dl>
+<p>Where normally staging to element data is performed as</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">local</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="k">global</span><span class="p">[</span><span class="nb">map</span><span class="p">[</span><span class="n">i</span><span class="p">]]</span>
+</pre></div>
+</div>
+<p>With a <a class="reference internal" href="#pyop2.types.map.PermutedMap" title="pyop2.types.map.PermutedMap"><code class="xref py py-class docutils literal notranslate"><span class="pre">PermutedMap</span></code></a> we instead get</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">local</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="k">global</span><span class="p">[</span><span class="nb">map</span><span class="p">[</span><span class="n">permutation</span><span class="p">[</span><span class="n">i</span><span class="p">]]]</span>
+</pre></div>
+</div>
+<p>This might be useful if your local kernel wants data in a
+different order to the one that the map provides, and you don’t
+want two global-sized data structures.</p>
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.map.ComposedMap">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.map.</span></span><span class="sig-name descname"><span class="pre">ComposedMap</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">maps_</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">name</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.map.ComposedMap" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.map.Map" title="pyop2.types.map.Map"><code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code></a></p>
+<p>Composition of :class:<a href="#id3"><span class="problematic" id="id4">`</span></a>Map`s, :class:<a href="#id5"><span class="problematic" id="id6">`</span></a>PermutedMap`s, and/or :class:<a href="#id7"><span class="problematic" id="id8">`</span></a>ComposedMap`s.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>maps</strong> – The maps to compose.</p>
+</dd>
+</dl>
+<p>Where normally staging to element data is performed as</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">local</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="k">global</span><span class="p">[</span><span class="nb">map</span><span class="p">[</span><span class="n">i</span><span class="p">]]</span>
+</pre></div>
+</div>
+<p>With a <a class="reference internal" href="#pyop2.types.map.ComposedMap" title="pyop2.types.map.ComposedMap"><code class="xref py py-class docutils literal notranslate"><span class="pre">ComposedMap</span></code></a> we instead get</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">local</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="k">global</span><span class="p">[</span><span class="n">maps_</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="n">maps_</span><span class="p">[</span><span class="mi">1</span><span class="p">][</span><span class="n">maps_</span><span class="p">[</span><span class="mi">2</span><span class="p">][</span><span class="o">...</span><span class="p">[</span><span class="n">i</span><span class="p">]]]]]</span>
+</pre></div>
+</div>
+<p>This might be useful if the map you want can be represented by
+a composition of existing maps.</p>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.ComposedMap.values">
+<span class="sig-name descname"><span class="pre">values</span></span><a class="headerlink" href="#pyop2.types.map.ComposedMap.values" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.ComposedMap.values_with_halo">
+<span class="sig-name descname"><span class="pre">values_with_halo</span></span><a class="headerlink" href="#pyop2.types.map.ComposedMap.values_with_halo" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.ComposedMap.flattened_maps">
+<span class="sig-name descname"><span class="pre">flattened_maps</span></span><a class="headerlink" href="#pyop2.types.map.ComposedMap.flattened_maps" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.map.</span></span><span class="sig-name descname"><span class="pre">MixedMap</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.map.MixedMap" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.map.Map" title="pyop2.types.map.Map"><code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code></a>, <code class="xref py py-class docutils literal notranslate"><span class="pre">ObjectCached</span></code></p>
+<p>A container for a bag of <a class="reference internal" href="#pyop2.types.map.Map" title="pyop2.types.map.Map"><code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code></a>s.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>maps</strong> (<em>iterable</em>) – Iterable of <a class="reference internal" href="#pyop2.types.map.Map" title="pyop2.types.map.Map"><code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code></a>s</p>
+</dd>
+</dl>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap.split">
+<span class="sig-name descname"><span class="pre">split</span></span><a class="headerlink" href="#pyop2.types.map.MixedMap.split" title="Link to this definition">¶</a></dt>
+<dd><p>The underlying tuple of <a class="reference internal" href="#pyop2.types.map.Map" title="pyop2.types.map.Map"><code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code></a>s.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap.iterset">
+<span class="sig-name descname"><span class="pre">iterset</span></span><a class="headerlink" href="#pyop2.types.map.MixedMap.iterset" title="Link to this definition">¶</a></dt>
+<dd><p><code class="xref py py-class docutils literal notranslate"><span class="pre">MixedSet</span></code> mapped from.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap.toset">
+<span class="sig-name descname"><span class="pre">toset</span></span><a class="headerlink" href="#pyop2.types.map.MixedMap.toset" title="Link to this definition">¶</a></dt>
+<dd><p><code class="xref py py-class docutils literal notranslate"><span class="pre">MixedSet</span></code> mapped to.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap.arity">
+<span class="sig-name descname"><span class="pre">arity</span></span><a class="headerlink" href="#pyop2.types.map.MixedMap.arity" title="Link to this definition">¶</a></dt>
+<dd><p>Arity of the mapping: total number of toset elements mapped to per
+iterset element.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap.arities">
+<span class="sig-name descname"><span class="pre">arities</span></span><a class="headerlink" href="#pyop2.types.map.MixedMap.arities" title="Link to this definition">¶</a></dt>
+<dd><p>Arity of the mapping: number of toset elements mapped to per
+iterset element.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Return type<span class="colon">:</span></dt>
+<dd class="field-odd"><p>tuple</p>
+</dd>
+</dl>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap.arange">
+<span class="sig-name descname"><span class="pre">arange</span></span><a class="headerlink" href="#pyop2.types.map.MixedMap.arange" title="Link to this definition">¶</a></dt>
+<dd><p>Tuple of arity offsets for each constituent <a class="reference internal" href="#pyop2.types.map.Map" title="pyop2.types.map.Map"><code class="xref py py-class docutils literal notranslate"><span class="pre">Map</span></code></a>.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap.values">
+<span class="sig-name descname"><span class="pre">values</span></span><a class="headerlink" href="#pyop2.types.map.MixedMap.values" title="Link to this definition">¶</a></dt>
+<dd><p>Mapping arrays excluding data for halos.</p>
+<p>This only returns the map values for local points, to see the
+halo points too, use <a class="reference internal" href="#pyop2.types.map.MixedMap.values_with_halo" title="pyop2.types.map.MixedMap.values_with_halo"><code class="xref py py-meth docutils literal notranslate"><span class="pre">values_with_halo()</span></code></a>.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap.values_with_halo">
+<span class="sig-name descname"><span class="pre">values_with_halo</span></span><a class="headerlink" href="#pyop2.types.map.MixedMap.values_with_halo" title="Link to this definition">¶</a></dt>
+<dd><p>Mapping arrays including data for halos.</p>
+<p>This returns all map values (including halo points), see
+<a class="reference internal" href="#pyop2.types.map.MixedMap.values" title="pyop2.types.map.MixedMap.values"><code class="xref py py-meth docutils literal notranslate"><span class="pre">values()</span></code></a> if you only need to look at the local
+points.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap.name">
+<span class="sig-name descname"><span class="pre">name</span></span><a class="headerlink" href="#pyop2.types.map.MixedMap.name" title="Link to this definition">¶</a></dt>
+<dd><p>User-defined labels</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap.offset">
+<span class="sig-name descname"><span class="pre">offset</span></span><a class="headerlink" href="#pyop2.types.map.MixedMap.offset" title="Link to this definition">¶</a></dt>
+<dd><p>Vertical offsets.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap.offset_quotient">
+<span class="sig-name descname"><span class="pre">offset_quotient</span></span><a class="headerlink" href="#pyop2.types.map.MixedMap.offset_quotient" title="Link to this definition">¶</a></dt>
+<dd><p>Offsets quotient.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.map.MixedMap.flattened_maps">
+<span class="sig-name descname"><span class="pre">flattened_maps</span></span><a class="headerlink" href="#pyop2.types.map.MixedMap.flattened_maps" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+</section>
+<section id="pyop2-types-mat-module">
+<h2>pyop2.types.mat module<a class="headerlink" href="#pyop2-types-mat-module" title="Link to this heading">¶</a></h2>
+</section>
+<section id="module-pyop2.types.set">
+<span id="pyop2-types-set-module"></span><h2>pyop2.types.set module<a class="headerlink" href="#module-pyop2.types.set" title="Link to this heading">¶</a></h2>
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.set.Set">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.set.</span></span><span class="sig-name descname"><span class="pre">Set</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">size</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">name</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">halo</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">comm</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.Set" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></p>
+<p>OP2 set.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>size</strong> (<em>integer</em><em> or </em><em>list</em><em> of </em><em>four integers.</em>) – The size of the set.</p></li>
+<li><p><strong>name</strong> (<em>string</em>) – The name of the set (optional).</p></li>
+<li><p><strong>halo</strong> – An exisiting halo to use (optional).</p></li>
+</ul>
+</dd>
+</dl>
+<p>When the set is employed as an iteration space in a
+<code class="xref py py-func docutils literal notranslate"><span class="pre">pyop2.op2.par_loop()</span></code>, the extent of any local iteration space within
+each set entry is indicated in brackets. See the example in
+<code class="xref py py-func docutils literal notranslate"><span class="pre">pyop2.op2.par_loop()</span></code> for more details.</p>
+<p>The size of the set can either be an integer, or a list of four
+integers.  The latter case is used for running in parallel where
+we distinguish between:</p>
+<blockquote>
+<div><ul class="simple">
+<li><p><cite>CORE</cite> (owned and not touching halo)</p></li>
+<li><p><cite>OWNED</cite> (owned, touching halo)</p></li>
+<li><p><cite>EXECUTE HALO</cite> (not owned, but executed over redundantly)</p></li>
+<li><p><cite>NON EXECUTE HALO</cite> (not owned, read when executing in the execute halo)</p></li>
+</ul>
+</div></blockquote>
+<p>If a single integer is passed, we assume that we’re running in
+serial and there is no distinction.</p>
+<p>The division of set elements is:</p>
+<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="p">[</span><span class="mi">0</span><span class="p">,</span> <span class="n">CORE</span><span class="p">)</span>
+<span class="p">[</span><span class="n">CORE</span><span class="p">,</span> <span class="n">OWNED</span><span class="p">)</span>
+<span class="p">[</span><span class="n">OWNED</span><span class="p">,</span> <span class="n">GHOST</span><span class="p">)</span>
+</pre></div>
+</div>
+<p>Halo send/receive data is stored on sets in a <code class="xref py py-class docutils literal notranslate"><span class="pre">Halo</span></code>.</p>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.core_size">
+<span class="sig-name descname"><span class="pre">core_size</span></span><a class="headerlink" href="#pyop2.types.set.Set.core_size" title="Link to this definition">¶</a></dt>
+<dd><p>Core set size.  Owned elements not touching halo elements.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.size">
+<span class="sig-name descname"><span class="pre">size</span></span><a class="headerlink" href="#pyop2.types.set.Set.size" title="Link to this definition">¶</a></dt>
+<dd><p>Set size, owned elements.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.total_size">
+<span class="sig-name descname"><span class="pre">total_size</span></span><a class="headerlink" href="#pyop2.types.set.Set.total_size" title="Link to this definition">¶</a></dt>
+<dd><p>Set size including ghost elements.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.sizes">
+<span class="sig-name descname"><span class="pre">sizes</span></span><a class="headerlink" href="#pyop2.types.set.Set.sizes" title="Link to this definition">¶</a></dt>
+<dd><p>Set sizes: core, owned, execute halo, total.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.core_part">
+<span class="sig-name descname"><span class="pre">core_part</span></span><a class="headerlink" href="#pyop2.types.set.Set.core_part" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.owned_part">
+<span class="sig-name descname"><span class="pre">owned_part</span></span><a class="headerlink" href="#pyop2.types.set.Set.owned_part" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.name">
+<span class="sig-name descname"><span class="pre">name</span></span><a class="headerlink" href="#pyop2.types.set.Set.name" title="Link to this definition">¶</a></dt>
+<dd><p>User-defined label</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.halo">
+<span class="sig-name descname"><span class="pre">halo</span></span><a class="headerlink" href="#pyop2.types.set.Set.halo" title="Link to this definition">¶</a></dt>
+<dd><p><code class="xref py py-class docutils literal notranslate"><span class="pre">Halo</span></code> associated with this Set</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.partition_size">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">partition_size</span></span><a class="headerlink" href="#pyop2.types.set.Set.partition_size" title="Link to this definition">¶</a></dt>
+<dd><p>Default partition size</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.layers">
+<span class="sig-name descname"><span class="pre">layers</span></span><a class="headerlink" href="#pyop2.types.set.Set.layers" title="Link to this definition">¶</a></dt>
+<dd><p>Return None (not an <a class="reference internal" href="#pyop2.types.set.ExtrudedSet" title="pyop2.types.set.ExtrudedSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">ExtrudedSet</span></code></a>).</p>
+</dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.intersection">
+<span class="sig-name descname"><span class="pre">intersection</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.Set.intersection" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.union">
+<span class="sig-name descname"><span class="pre">union</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.Set.union" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.difference">
+<span class="sig-name descname"><span class="pre">difference</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.Set.difference" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.set.Set.symmetric_difference">
+<span class="sig-name descname"><span class="pre">symmetric_difference</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.Set.symmetric_difference" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.set.GlobalSet">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.set.</span></span><span class="sig-name descname"><span class="pre">GlobalSet</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">comm</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.GlobalSet" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code></a></p>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.GlobalSet.core_size">
+<span class="sig-name descname"><span class="pre">core_size</span></span><a class="headerlink" href="#pyop2.types.set.GlobalSet.core_size" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.GlobalSet.size">
+<span class="sig-name descname"><span class="pre">size</span></span><a class="headerlink" href="#pyop2.types.set.GlobalSet.size" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.GlobalSet.total_size">
+<span class="sig-name descname"><span class="pre">total_size</span></span><a class="headerlink" href="#pyop2.types.set.GlobalSet.total_size" title="Link to this definition">¶</a></dt>
+<dd><p>Total set size, including halo elements.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.GlobalSet.sizes">
+<span class="sig-name descname"><span class="pre">sizes</span></span><a class="headerlink" href="#pyop2.types.set.GlobalSet.sizes" title="Link to this definition">¶</a></dt>
+<dd><p>Set sizes: core, owned, execute halo, total.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.GlobalSet.name">
+<span class="sig-name descname"><span class="pre">name</span></span><a class="headerlink" href="#pyop2.types.set.GlobalSet.name" title="Link to this definition">¶</a></dt>
+<dd><p>User-defined label</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.GlobalSet.halo">
+<span class="sig-name descname"><span class="pre">halo</span></span><a class="headerlink" href="#pyop2.types.set.GlobalSet.halo" title="Link to this definition">¶</a></dt>
+<dd><p><code class="xref py py-class docutils literal notranslate"><span class="pre">Halo</span></code> associated with this Set</p>
+</dd></dl>
+
+<dl class="py property">
+<dt class="sig sig-object py" id="pyop2.types.set.GlobalSet.partition_size">
+<em class="property"><span class="pre">property</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">partition_size</span></span><a class="headerlink" href="#pyop2.types.set.GlobalSet.partition_size" title="Link to this definition">¶</a></dt>
+<dd><p>Default partition size</p>
+</dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.set.ExtrudedSet">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.set.</span></span><span class="sig-name descname"><span class="pre">ExtrudedSet</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">parent</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">layers</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">extruded_periodic</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">False</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.ExtrudedSet" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code></a></p>
+<p>OP2 ExtrudedSet.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>parent</strong> (a <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code></a>.) – The parent <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code></a> to build this <a class="reference internal" href="#pyop2.types.set.ExtrudedSet" title="pyop2.types.set.ExtrudedSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">ExtrudedSet</span></code></a> on top of</p></li>
+<li><p><strong>layers</strong> (an integer, indicating the number of layers for every entity,
+or an array of shape (parent.total_size, 2) giving the start
+and one past the stop layer for every entity.  An entry
+<code class="docutils literal notranslate"><span class="pre">a,</span> <span class="pre">b</span> <span class="pre">=</span> <span class="pre">layers[e,</span> <span class="pre">...]</span></code> means that the layers for entity
+<code class="docutils literal notranslate"><span class="pre">e</span></code> run over <span class="math">[a, b)</span>.) – The number of layers in this <a class="reference internal" href="#pyop2.types.set.ExtrudedSet" title="pyop2.types.set.ExtrudedSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">ExtrudedSet</span></code></a>.</p></li>
+</ul>
+</dd>
+</dl>
+<p>The number of layers indicates the number of time the base set is
+extruded in the direction of the <a class="reference internal" href="#pyop2.types.set.ExtrudedSet" title="pyop2.types.set.ExtrudedSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">ExtrudedSet</span></code></a>.  As a
+result, there are <code class="docutils literal notranslate"><span class="pre">layers-1</span></code> extruded “cells” in an extruded set.</p>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.ExtrudedSet.parent">
+<span class="sig-name descname"><span class="pre">parent</span></span><a class="headerlink" href="#pyop2.types.set.ExtrudedSet.parent" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.ExtrudedSet.layers">
+<span class="sig-name descname"><span class="pre">layers</span></span><a class="headerlink" href="#pyop2.types.set.ExtrudedSet.layers" title="Link to this definition">¶</a></dt>
+<dd><p>The layers of this extruded set.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.ExtrudedSet.layers_array">
+<span class="sig-name descname"><span class="pre">layers_array</span></span><a class="headerlink" href="#pyop2.types.set.ExtrudedSet.layers_array" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.set.Subset">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.set.</span></span><span class="sig-name descname"><span class="pre">Subset</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">superset</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">indices</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.Subset" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.set.ExtrudedSet" title="pyop2.types.set.ExtrudedSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">ExtrudedSet</span></code></a></p>
+<p>OP2 subset.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><ul class="simple">
+<li><p><strong>superset</strong> (a <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code></a> or a <a class="reference internal" href="#pyop2.types.set.Subset" title="pyop2.types.set.Subset"><code class="xref py py-class docutils literal notranslate"><span class="pre">Subset</span></code></a>.) – The superset of the subset.</p></li>
+<li><p><strong>indices</strong> (<em>a list</em><em> of </em><em>integers</em><em>, or </em><em>a numpy array.</em>) – Elements of the superset that form the
+subset. Duplicate values are removed when constructing the subset.</p></li>
+</ul>
+</dd>
+</dl>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Subset.superset">
+<span class="sig-name descname"><span class="pre">superset</span></span><a class="headerlink" href="#pyop2.types.set.Subset.superset" title="Link to this definition">¶</a></dt>
+<dd><p>Returns the superset Set</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Subset.indices">
+<span class="sig-name descname"><span class="pre">indices</span></span><a class="headerlink" href="#pyop2.types.set.Subset.indices" title="Link to this definition">¶</a></dt>
+<dd><p>Returns the indices pointing in the superset.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Subset.owned_indices">
+<span class="sig-name descname"><span class="pre">owned_indices</span></span><a class="headerlink" href="#pyop2.types.set.Subset.owned_indices" title="Link to this definition">¶</a></dt>
+<dd><p>Return the indices that correspond to the owned entities of the
+superset.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.Subset.layers_array">
+<span class="sig-name descname"><span class="pre">layers_array</span></span><a class="headerlink" href="#pyop2.types.set.Subset.layers_array" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.set.Subset.intersection">
+<span class="sig-name descname"><span class="pre">intersection</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.Subset.intersection" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.set.Subset.union">
+<span class="sig-name descname"><span class="pre">union</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.Subset.union" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.set.Subset.difference">
+<span class="sig-name descname"><span class="pre">difference</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.Subset.difference" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+<dl class="py method">
+<dt class="sig sig-object py" id="pyop2.types.set.Subset.symmetric_difference">
+<span class="sig-name descname"><span class="pre">symmetric_difference</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">other</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.Subset.symmetric_difference" title="Link to this definition">¶</a></dt>
+<dd></dd></dl>
+
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.set.SetPartition">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.set.</span></span><span class="sig-name descname"><span class="pre">SetPartition</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">set</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">offset</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">size</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.SetPartition" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></p>
+</dd></dl>
+
+<dl class="py class">
+<dt class="sig sig-object py" id="pyop2.types.set.MixedSet">
+<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-prename descclassname"><span class="pre">pyop2.types.set.</span></span><span class="sig-name descname"><span class="pre">MixedSet</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="headerlink" href="#pyop2.types.set.MixedSet" title="Link to this definition">¶</a></dt>
+<dd><p>Bases: <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code></a>, <code class="xref py py-class docutils literal notranslate"><span class="pre">ObjectCached</span></code></p>
+<p>A container for a bag of <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code></a>s.</p>
+<dl class="field-list simple">
+<dt class="field-odd">Parameters<span class="colon">:</span></dt>
+<dd class="field-odd"><p><strong>sets</strong> (<em>iterable</em>) – Iterable of <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code></a>s or <a class="reference internal" href="#pyop2.types.set.ExtrudedSet" title="pyop2.types.set.ExtrudedSet"><code class="xref py py-class docutils literal notranslate"><span class="pre">ExtrudedSet</span></code></a>s</p>
+</dd>
+</dl>
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.MixedSet.split">
+<span class="sig-name descname"><span class="pre">split</span></span><a class="headerlink" href="#pyop2.types.set.MixedSet.split" title="Link to this definition">¶</a></dt>
+<dd><p>The underlying tuple of <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code></a>s.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.MixedSet.core_size">
+<span class="sig-name descname"><span class="pre">core_size</span></span><a class="headerlink" href="#pyop2.types.set.MixedSet.core_size" title="Link to this definition">¶</a></dt>
+<dd><p>Core set size. Owned elements not touching halo elements.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.MixedSet.size">
+<span class="sig-name descname"><span class="pre">size</span></span><a class="headerlink" href="#pyop2.types.set.MixedSet.size" title="Link to this definition">¶</a></dt>
+<dd><p>Set size, owned elements.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.MixedSet.total_size">
+<span class="sig-name descname"><span class="pre">total_size</span></span><a class="headerlink" href="#pyop2.types.set.MixedSet.total_size" title="Link to this definition">¶</a></dt>
+<dd><p>Total set size, including halo elements.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.MixedSet.sizes">
+<span class="sig-name descname"><span class="pre">sizes</span></span><a class="headerlink" href="#pyop2.types.set.MixedSet.sizes" title="Link to this definition">¶</a></dt>
+<dd><p>Set sizes: core, owned, execute halo, total.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.MixedSet.name">
+<span class="sig-name descname"><span class="pre">name</span></span><a class="headerlink" href="#pyop2.types.set.MixedSet.name" title="Link to this definition">¶</a></dt>
+<dd><p>User-defined labels.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.MixedSet.halo">
+<span class="sig-name descname"><span class="pre">halo</span></span><a class="headerlink" href="#pyop2.types.set.MixedSet.halo" title="Link to this definition">¶</a></dt>
+<dd><p><code class="xref py py-class docutils literal notranslate"><span class="pre">Halo</span></code>s associated with these <a class="reference internal" href="#pyop2.types.set.Set" title="pyop2.types.set.Set"><code class="xref py py-class docutils literal notranslate"><span class="pre">Set</span></code></a>s.</p>
+</dd></dl>
+
+<dl class="py attribute">
+<dt class="sig sig-object py" id="pyop2.types.set.MixedSet.layers">
+<span class="sig-name descname"><span class="pre">layers</span></span><a class="headerlink" href="#pyop2.types.set.MixedSet.layers" title="Link to this definition">¶</a></dt>
+<dd><p>Numbers of layers in the extruded mesh (or None if this MixedSet is not extruded).</p>
+</dd></dl>
+
+</dd></dl>
+
+</section>
+<section id="module-contents">
+<h2>Module contents<a class="headerlink" href="#module-contents" title="Link to this heading">¶</a></h2>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">pyop2.types package</a><ul>
+<li><a class="reference internal" href="#submodules">Submodules</a></li>
+<li><a class="reference internal" href="#module-pyop2.types.access">pyop2.types.access module</a><ul>
+<li><a class="reference internal" href="#pyop2.types.access.Access"><code class="docutils literal notranslate"><span class="pre">Access</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.access.Access.READ"><code class="docutils literal notranslate"><span class="pre">Access.READ</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.access.Access.WRITE"><code class="docutils literal notranslate"><span class="pre">Access.WRITE</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.access.Access.RW"><code class="docutils literal notranslate"><span class="pre">Access.RW</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.access.Access.INC"><code class="docutils literal notranslate"><span class="pre">Access.INC</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.access.Access.MIN"><code class="docutils literal notranslate"><span class="pre">Access.MIN</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.access.Access.MAX"><code class="docutils literal notranslate"><span class="pre">Access.MAX</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.access.READ"><code class="docutils literal notranslate"><span class="pre">READ</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.access.WRITE"><code class="docutils literal notranslate"><span class="pre">WRITE</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.access.RW"><code class="docutils literal notranslate"><span class="pre">RW</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.access.INC"><code class="docutils literal notranslate"><span class="pre">INC</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.access.MIN"><code class="docutils literal notranslate"><span class="pre">MIN</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.access.MAX"><code class="docutils literal notranslate"><span class="pre">MAX</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#module-pyop2.types.dat">pyop2.types.dat module</a><ul>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat"><code class="docutils literal notranslate"><span class="pre">AbstractDat</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.split"><code class="docutils literal notranslate"><span class="pre">AbstractDat.split</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.dataset"><code class="docutils literal notranslate"><span class="pre">AbstractDat.dataset</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.dim"><code class="docutils literal notranslate"><span class="pre">AbstractDat.dim</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.cdim"><code class="docutils literal notranslate"><span class="pre">AbstractDat.cdim</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.data"><code class="docutils literal notranslate"><span class="pre">AbstractDat.data</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.data_with_halos"><code class="docutils literal notranslate"><span class="pre">AbstractDat.data_with_halos</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.data_ro"><code class="docutils literal notranslate"><span class="pre">AbstractDat.data_ro</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.data_ro_with_halos"><code class="docutils literal notranslate"><span class="pre">AbstractDat.data_ro_with_halos</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.data_wo"><code class="docutils literal notranslate"><span class="pre">AbstractDat.data_wo</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.data_wo_with_halos"><code class="docutils literal notranslate"><span class="pre">AbstractDat.data_wo_with_halos</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.save"><code class="docutils literal notranslate"><span class="pre">AbstractDat.save()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.load"><code class="docutils literal notranslate"><span class="pre">AbstractDat.load()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.shape"><code class="docutils literal notranslate"><span class="pre">AbstractDat.shape</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.dtype"><code class="docutils literal notranslate"><span class="pre">AbstractDat.dtype</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.nbytes"><code class="docutils literal notranslate"><span class="pre">AbstractDat.nbytes</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.zero"><code class="docutils literal notranslate"><span class="pre">AbstractDat.zero()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.copy"><code class="docutils literal notranslate"><span class="pre">AbstractDat.copy()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.inner"><code class="docutils literal notranslate"><span class="pre">AbstractDat.inner()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.norm"><code class="docutils literal notranslate"><span class="pre">AbstractDat.norm</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.global_to_local_begin"><code class="docutils literal notranslate"><span class="pre">AbstractDat.global_to_local_begin()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.global_to_local_end"><code class="docutils literal notranslate"><span class="pre">AbstractDat.global_to_local_end()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.local_to_global_begin"><code class="docutils literal notranslate"><span class="pre">AbstractDat.local_to_global_begin()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.local_to_global_end"><code class="docutils literal notranslate"><span class="pre">AbstractDat.local_to_global_end()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.frozen_halo"><code class="docutils literal notranslate"><span class="pre">AbstractDat.frozen_halo()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.freeze_halo"><code class="docutils literal notranslate"><span class="pre">AbstractDat.freeze_halo()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.AbstractDat.unfreeze_halo"><code class="docutils literal notranslate"><span class="pre">AbstractDat.unfreeze_halo()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.dat.DatView"><code class="docutils literal notranslate"><span class="pre">DatView</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.dat.DatView.cdim"><code class="docutils literal notranslate"><span class="pre">DatView.cdim</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.DatView.dim"><code class="docutils literal notranslate"><span class="pre">DatView.dim</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.DatView.shape"><code class="docutils literal notranslate"><span class="pre">DatView.shape</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.DatView.halo_valid"><code class="docutils literal notranslate"><span class="pre">DatView.halo_valid</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.DatView.data"><code class="docutils literal notranslate"><span class="pre">DatView.data</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.DatView.data_ro"><code class="docutils literal notranslate"><span class="pre">DatView.data_ro</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.DatView.data_wo"><code class="docutils literal notranslate"><span class="pre">DatView.data_wo</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.DatView.data_with_halos"><code class="docutils literal notranslate"><span class="pre">DatView.data_with_halos</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.DatView.data_ro_with_halos"><code class="docutils literal notranslate"><span class="pre">DatView.data_ro_with_halos</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.DatView.data_wo_with_halos"><code class="docutils literal notranslate"><span class="pre">DatView.data_wo_with_halos</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.dat.Dat"><code class="docutils literal notranslate"><span class="pre">Dat</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.dat.Dat.vec_context"><code class="docutils literal notranslate"><span class="pre">Dat.vec_context()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat"><code class="docutils literal notranslate"><span class="pre">MixedDat</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.dat_version"><code class="docutils literal notranslate"><span class="pre">MixedDat.dat_version</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.increment_dat_version"><code class="docutils literal notranslate"><span class="pre">MixedDat.increment_dat_version()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.dtype"><code class="docutils literal notranslate"><span class="pre">MixedDat.dtype</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.split"><code class="docutils literal notranslate"><span class="pre">MixedDat.split</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.dataset"><code class="docutils literal notranslate"><span class="pre">MixedDat.dataset</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.data"><code class="docutils literal notranslate"><span class="pre">MixedDat.data</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.data_with_halos"><code class="docutils literal notranslate"><span class="pre">MixedDat.data_with_halos</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.data_ro"><code class="docutils literal notranslate"><span class="pre">MixedDat.data_ro</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.data_ro_with_halos"><code class="docutils literal notranslate"><span class="pre">MixedDat.data_ro_with_halos</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.data_wo"><code class="docutils literal notranslate"><span class="pre">MixedDat.data_wo</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.data_wo_with_halos"><code class="docutils literal notranslate"><span class="pre">MixedDat.data_wo_with_halos</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.halo_valid"><code class="docutils literal notranslate"><span class="pre">MixedDat.halo_valid</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.global_to_local_begin"><code class="docutils literal notranslate"><span class="pre">MixedDat.global_to_local_begin()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.global_to_local_end"><code class="docutils literal notranslate"><span class="pre">MixedDat.global_to_local_end()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.local_to_global_begin"><code class="docutils literal notranslate"><span class="pre">MixedDat.local_to_global_begin()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.local_to_global_end"><code class="docutils literal notranslate"><span class="pre">MixedDat.local_to_global_end()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.freeze_halo"><code class="docutils literal notranslate"><span class="pre">MixedDat.freeze_halo()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.unfreeze_halo"><code class="docutils literal notranslate"><span class="pre">MixedDat.unfreeze_halo()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.zero"><code class="docutils literal notranslate"><span class="pre">MixedDat.zero()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.nbytes"><code class="docutils literal notranslate"><span class="pre">MixedDat.nbytes</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.copy"><code class="docutils literal notranslate"><span class="pre">MixedDat.copy()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.inner"><code class="docutils literal notranslate"><span class="pre">MixedDat.inner()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dat.MixedDat.vec_context"><code class="docutils literal notranslate"><span class="pre">MixedDat.vec_context()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.dat.frozen_halo"><code class="docutils literal notranslate"><span class="pre">frozen_halo</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#module-pyop2.types.data_carrier">pyop2.types.data_carrier module</a><ul>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.DataCarrier"><code class="docutils literal notranslate"><span class="pre">DataCarrier</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.DataCarrier.dtype"><code class="docutils literal notranslate"><span class="pre">DataCarrier.dtype</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.DataCarrier.ctype"><code class="docutils literal notranslate"><span class="pre">DataCarrier.ctype</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.DataCarrier.name"><code class="docutils literal notranslate"><span class="pre">DataCarrier.name</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.DataCarrier.dim"><code class="docutils literal notranslate"><span class="pre">DataCarrier.dim</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.DataCarrier.cdim"><code class="docutils literal notranslate"><span class="pre">DataCarrier.cdim</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.DataCarrier.increment_dat_version"><code class="docutils literal notranslate"><span class="pre">DataCarrier.increment_dat_version()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.EmptyDataMixin"><code class="docutils literal notranslate"><span class="pre">EmptyDataMixin</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.VecAccessMixin"><code class="docutils literal notranslate"><span class="pre">VecAccessMixin</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.VecAccessMixin.dat_version"><code class="docutils literal notranslate"><span class="pre">VecAccessMixin.dat_version</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.VecAccessMixin.vec_context"><code class="docutils literal notranslate"><span class="pre">VecAccessMixin.vec_context()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.VecAccessMixin.vec"><code class="docutils literal notranslate"><span class="pre">VecAccessMixin.vec</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.VecAccessMixin.vec_wo"><code class="docutils literal notranslate"><span class="pre">VecAccessMixin.vec_wo</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.data_carrier.VecAccessMixin.vec_ro"><code class="docutils literal notranslate"><span class="pre">VecAccessMixin.vec_ro</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#module-pyop2.types.dataset">pyop2.types.dataset module</a><ul>
+<li><a class="reference internal" href="#pyop2.types.dataset.DataSet"><code class="docutils literal notranslate"><span class="pre">DataSet</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.dataset.DataSet.dim"><code class="docutils literal notranslate"><span class="pre">DataSet.dim</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.DataSet.cdim"><code class="docutils literal notranslate"><span class="pre">DataSet.cdim</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.DataSet.name"><code class="docutils literal notranslate"><span class="pre">DataSet.name</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.DataSet.set"><code class="docutils literal notranslate"><span class="pre">DataSet.set</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.DataSet.lgmap"><code class="docutils literal notranslate"><span class="pre">DataSet.lgmap</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.DataSet.scalar_lgmap"><code class="docutils literal notranslate"><span class="pre">DataSet.scalar_lgmap</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.DataSet.unblocked_lgmap"><code class="docutils literal notranslate"><span class="pre">DataSet.unblocked_lgmap</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.DataSet.field_ises"><code class="docutils literal notranslate"><span class="pre">DataSet.field_ises</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.DataSet.local_ises"><code class="docutils literal notranslate"><span class="pre">DataSet.local_ises</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.DataSet.layout_vec"><code class="docutils literal notranslate"><span class="pre">DataSet.layout_vec</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.DataSet.dm"><code class="docutils literal notranslate"><span class="pre">DataSet.dm</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.dataset.GlobalDataSet"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.dataset.GlobalDataSet.dim"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.dim</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.GlobalDataSet.cdim"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.cdim</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.GlobalDataSet.name"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.name</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.GlobalDataSet.set"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.set</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.GlobalDataSet.size"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.size</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.GlobalDataSet.lgmap"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.lgmap</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.GlobalDataSet.unblocked_lgmap"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.unblocked_lgmap</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.GlobalDataSet.local_ises"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.local_ises</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.GlobalDataSet.layout_vec"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.layout_vec</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.GlobalDataSet.dm"><code class="docutils literal notranslate"><span class="pre">GlobalDataSet.dm</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.dataset.MixedDataSet"><code class="docutils literal notranslate"><span class="pre">MixedDataSet</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.dataset.MixedDataSet.split"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.split</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.MixedDataSet.dim"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.dim</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.MixedDataSet.cdim"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.cdim</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.MixedDataSet.name"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.name</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.MixedDataSet.set"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.set</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.MixedDataSet.layout_vec"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.layout_vec</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.MixedDataSet.lgmap"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.lgmap</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.dataset.MixedDataSet.unblocked_lgmap"><code class="docutils literal notranslate"><span class="pre">MixedDataSet.unblocked_lgmap</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#module-pyop2.types.glob">pyop2.types.glob module</a><ul>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.shape"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.shape</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.dtype"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.dtype</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.data_ro"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.data_ro</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.data_wo"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.data_wo</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.data"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.data</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.data_with_halos"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.data_with_halos</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.data_ro_with_halos"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.data_ro_with_halos</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.data_wo_with_halos"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.data_wo_with_halos</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.halo_valid"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.halo_valid</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.copy"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.copy()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.split"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.split</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.nbytes"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.nbytes</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.SetFreeDataCarrier.inner"><code class="docutils literal notranslate"><span class="pre">SetFreeDataCarrier.inner()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.glob.Global"><code class="docutils literal notranslate"><span class="pre">Global</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.glob.Global.dataset"><code class="docutils literal notranslate"><span class="pre">Global.dataset</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.Global.duplicate"><code class="docutils literal notranslate"><span class="pre">Global.duplicate()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.Global.zero"><code class="docutils literal notranslate"><span class="pre">Global.zero()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.Global.global_to_local_begin"><code class="docutils literal notranslate"><span class="pre">Global.global_to_local_begin()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.Global.global_to_local_end"><code class="docutils literal notranslate"><span class="pre">Global.global_to_local_end()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.Global.local_to_global_begin"><code class="docutils literal notranslate"><span class="pre">Global.local_to_global_begin()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.Global.local_to_global_end"><code class="docutils literal notranslate"><span class="pre">Global.local_to_global_end()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.Global.frozen_halo"><code class="docutils literal notranslate"><span class="pre">Global.frozen_halo()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.Global.freeze_halo"><code class="docutils literal notranslate"><span class="pre">Global.freeze_halo()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.Global.unfreeze_halo"><code class="docutils literal notranslate"><span class="pre">Global.unfreeze_halo()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.glob.Global.vec_context"><code class="docutils literal notranslate"><span class="pre">Global.vec_context()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.glob.Constant"><code class="docutils literal notranslate"><span class="pre">Constant</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.glob.Constant.duplicate"><code class="docutils literal notranslate"><span class="pre">Constant.duplicate()</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#module-pyop2.types.halo">pyop2.types.halo module</a><ul>
+<li><a class="reference internal" href="#pyop2.types.halo.Halo"><code class="docutils literal notranslate"><span class="pre">Halo</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.halo.Halo.comm"><code class="docutils literal notranslate"><span class="pre">Halo.comm</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.halo.Halo.local_to_global_numbering"><code class="docutils literal notranslate"><span class="pre">Halo.local_to_global_numbering</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.halo.Halo.global_to_local_begin"><code class="docutils literal notranslate"><span class="pre">Halo.global_to_local_begin()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.halo.Halo.global_to_local_end"><code class="docutils literal notranslate"><span class="pre">Halo.global_to_local_end()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.halo.Halo.local_to_global_begin"><code class="docutils literal notranslate"><span class="pre">Halo.local_to_global_begin()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.halo.Halo.local_to_global_end"><code class="docutils literal notranslate"><span class="pre">Halo.local_to_global_end()</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#module-pyop2.types.map">pyop2.types.map module</a><ul>
+<li><a class="reference internal" href="#pyop2.types.map.Map"><code class="docutils literal notranslate"><span class="pre">Map</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.map.Map.dtype"><code class="docutils literal notranslate"><span class="pre">Map.dtype</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.Map.split"><code class="docutils literal notranslate"><span class="pre">Map.split</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.Map.iterset"><code class="docutils literal notranslate"><span class="pre">Map.iterset</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.Map.toset"><code class="docutils literal notranslate"><span class="pre">Map.toset</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.Map.arity"><code class="docutils literal notranslate"><span class="pre">Map.arity</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.Map.arities"><code class="docutils literal notranslate"><span class="pre">Map.arities</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.Map.arange"><code class="docutils literal notranslate"><span class="pre">Map.arange</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.Map.values"><code class="docutils literal notranslate"><span class="pre">Map.values</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.Map.values_with_halo"><code class="docutils literal notranslate"><span class="pre">Map.values_with_halo</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.Map.name"><code class="docutils literal notranslate"><span class="pre">Map.name</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.Map.offset"><code class="docutils literal notranslate"><span class="pre">Map.offset</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.Map.offset_quotient"><code class="docutils literal notranslate"><span class="pre">Map.offset_quotient</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.Map.flattened_maps"><code class="docutils literal notranslate"><span class="pre">Map.flattened_maps</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.map.PermutedMap"><code class="docutils literal notranslate"><span class="pre">PermutedMap</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.ComposedMap"><code class="docutils literal notranslate"><span class="pre">ComposedMap</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.map.ComposedMap.values"><code class="docutils literal notranslate"><span class="pre">ComposedMap.values</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.ComposedMap.values_with_halo"><code class="docutils literal notranslate"><span class="pre">ComposedMap.values_with_halo</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.ComposedMap.flattened_maps"><code class="docutils literal notranslate"><span class="pre">ComposedMap.flattened_maps</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap"><code class="docutils literal notranslate"><span class="pre">MixedMap</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap.split"><code class="docutils literal notranslate"><span class="pre">MixedMap.split</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap.iterset"><code class="docutils literal notranslate"><span class="pre">MixedMap.iterset</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap.toset"><code class="docutils literal notranslate"><span class="pre">MixedMap.toset</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap.arity"><code class="docutils literal notranslate"><span class="pre">MixedMap.arity</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap.arities"><code class="docutils literal notranslate"><span class="pre">MixedMap.arities</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap.arange"><code class="docutils literal notranslate"><span class="pre">MixedMap.arange</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap.values"><code class="docutils literal notranslate"><span class="pre">MixedMap.values</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap.values_with_halo"><code class="docutils literal notranslate"><span class="pre">MixedMap.values_with_halo</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap.name"><code class="docutils literal notranslate"><span class="pre">MixedMap.name</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap.offset"><code class="docutils literal notranslate"><span class="pre">MixedMap.offset</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap.offset_quotient"><code class="docutils literal notranslate"><span class="pre">MixedMap.offset_quotient</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.map.MixedMap.flattened_maps"><code class="docutils literal notranslate"><span class="pre">MixedMap.flattened_maps</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2-types-mat-module">pyop2.types.mat module</a></li>
+<li><a class="reference internal" href="#module-pyop2.types.set">pyop2.types.set module</a><ul>
+<li><a class="reference internal" href="#pyop2.types.set.Set"><code class="docutils literal notranslate"><span class="pre">Set</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.set.Set.core_size"><code class="docutils literal notranslate"><span class="pre">Set.core_size</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.size"><code class="docutils literal notranslate"><span class="pre">Set.size</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.total_size"><code class="docutils literal notranslate"><span class="pre">Set.total_size</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.sizes"><code class="docutils literal notranslate"><span class="pre">Set.sizes</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.core_part"><code class="docutils literal notranslate"><span class="pre">Set.core_part</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.owned_part"><code class="docutils literal notranslate"><span class="pre">Set.owned_part</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.name"><code class="docutils literal notranslate"><span class="pre">Set.name</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.halo"><code class="docutils literal notranslate"><span class="pre">Set.halo</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.partition_size"><code class="docutils literal notranslate"><span class="pre">Set.partition_size</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.layers"><code class="docutils literal notranslate"><span class="pre">Set.layers</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.intersection"><code class="docutils literal notranslate"><span class="pre">Set.intersection()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.union"><code class="docutils literal notranslate"><span class="pre">Set.union()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.difference"><code class="docutils literal notranslate"><span class="pre">Set.difference()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Set.symmetric_difference"><code class="docutils literal notranslate"><span class="pre">Set.symmetric_difference()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.set.GlobalSet"><code class="docutils literal notranslate"><span class="pre">GlobalSet</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.set.GlobalSet.core_size"><code class="docutils literal notranslate"><span class="pre">GlobalSet.core_size</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.GlobalSet.size"><code class="docutils literal notranslate"><span class="pre">GlobalSet.size</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.GlobalSet.total_size"><code class="docutils literal notranslate"><span class="pre">GlobalSet.total_size</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.GlobalSet.sizes"><code class="docutils literal notranslate"><span class="pre">GlobalSet.sizes</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.GlobalSet.name"><code class="docutils literal notranslate"><span class="pre">GlobalSet.name</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.GlobalSet.halo"><code class="docutils literal notranslate"><span class="pre">GlobalSet.halo</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.GlobalSet.partition_size"><code class="docutils literal notranslate"><span class="pre">GlobalSet.partition_size</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.set.ExtrudedSet"><code class="docutils literal notranslate"><span class="pre">ExtrudedSet</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.set.ExtrudedSet.parent"><code class="docutils literal notranslate"><span class="pre">ExtrudedSet.parent</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.ExtrudedSet.layers"><code class="docutils literal notranslate"><span class="pre">ExtrudedSet.layers</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.ExtrudedSet.layers_array"><code class="docutils literal notranslate"><span class="pre">ExtrudedSet.layers_array</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.set.Subset"><code class="docutils literal notranslate"><span class="pre">Subset</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.set.Subset.superset"><code class="docutils literal notranslate"><span class="pre">Subset.superset</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Subset.indices"><code class="docutils literal notranslate"><span class="pre">Subset.indices</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Subset.owned_indices"><code class="docutils literal notranslate"><span class="pre">Subset.owned_indices</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Subset.layers_array"><code class="docutils literal notranslate"><span class="pre">Subset.layers_array</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Subset.intersection"><code class="docutils literal notranslate"><span class="pre">Subset.intersection()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Subset.union"><code class="docutils literal notranslate"><span class="pre">Subset.union()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Subset.difference"><code class="docutils literal notranslate"><span class="pre">Subset.difference()</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.Subset.symmetric_difference"><code class="docutils literal notranslate"><span class="pre">Subset.symmetric_difference()</span></code></a></li>
+</ul>
+</li>
+<li><a class="reference internal" href="#pyop2.types.set.SetPartition"><code class="docutils literal notranslate"><span class="pre">SetPartition</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.MixedSet"><code class="docutils literal notranslate"><span class="pre">MixedSet</span></code></a><ul>
+<li><a class="reference internal" href="#pyop2.types.set.MixedSet.split"><code class="docutils literal notranslate"><span class="pre">MixedSet.split</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.MixedSet.core_size"><code class="docutils literal notranslate"><span class="pre">MixedSet.core_size</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.MixedSet.size"><code class="docutils literal notranslate"><span class="pre">MixedSet.size</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.MixedSet.total_size"><code class="docutils literal notranslate"><span class="pre">MixedSet.total_size</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.MixedSet.sizes"><code class="docutils literal notranslate"><span class="pre">MixedSet.sizes</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.MixedSet.name"><code class="docutils literal notranslate"><span class="pre">MixedSet.name</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.MixedSet.halo"><code class="docutils literal notranslate"><span class="pre">MixedSet.halo</span></code></a></li>
+<li><a class="reference internal" href="#pyop2.types.set.MixedSet.layers"><code class="docutils literal notranslate"><span class="pre">MixedSet.layers</span></code></a></li>
+</ul>
+</li>
+</ul>
+</li>
+<li><a class="reference internal" href="#module-contents">Module contents</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="pyop2.codegen.html"
+                          title="previous chapter">pyop2.codegen package</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/pyop2.types.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="pyop2.codegen.html" title="pyop2.codegen package"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+          <li class="nav-item nav-item-1"><a href="pyop2.html" >pyop2 package</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">pyop2.types package</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/search.html b/search.html
new file mode 100644
index 000000000..dbe5790c8
--- /dev/null
+++ b/search.html
@@ -0,0 +1,102 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
+    <title>Search &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <script src="_static/searchtools.js"></script>
+    <script src="_static/language_data.js"></script>
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="#" />
+  <script src="searchindex.js" defer></script>
+   
+
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Search</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <h1 id="search-documentation">Search</h1>
+  
+  <noscript>
+  <div class="admonition warning">
+  <p>
+    Please activate JavaScript to enable the search
+    functionality.
+  </p>
+  </div>
+  </noscript>
+  
+  
+  <p>
+    Searching for multiple words only shows matches that contain
+    all words.
+  </p>
+  
+  
+  <form action="" method="get">
+    <input type="text" name="q" aria-labelledby="search-documentation" value="" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+    <input type="submit" value="search" />
+    <span id="search-progress" style="padding-left: 10px"></span>
+  </form>
+  
+  
+  
+  <div id="search-results">
+  
+  </div>
+  
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">Search</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file
diff --git a/searchindex.js b/searchindex.js
new file mode 100644
index 000000000..ad134edf1
--- /dev/null
+++ b/searchindex.js
@@ -0,0 +1 @@
+Search.setIndex({"docnames": ["architecture", "backends", "caching", "concepts", "index", "installation", "ir", "kernels", "linear_algebra", "mixed", "mpi", "plan", "profiling", "pyop2", "pyop2.codegen", "pyop2.types", "user"], "filenames": ["architecture.rst", "backends.rst", "caching.rst", "concepts.rst", "index.rst", "installation.rst", "ir.rst", "kernels.rst", "linear_algebra.rst", "mixed.rst", "mpi.rst", "plan.rst", "profiling.rst", "pyop2.rst", "pyop2.codegen.rst", "pyop2.types.rst", "user.rst"], "titles": ["PyOP2 Architecture", "PyOP2 Backends", "Caching in PyOP2", "PyOP2 Concepts", "Welcome to PyOP2\u2019s documentation!", "Installing PyOP2", "The PyOP2 Intermediate Representation", "PyOP2 Kernels", "PyOP2 Linear Algebra Interface", "Mixed Types", "MPI", "Parallel Execution Plan", "Profiling", "pyop2 package", "pyop2.codegen package", "pyop2.types package", "pyop2 user documentation"], "terms": {"As": [0, 1, 2, 6, 7, 8, 15], "describ": [0, 1, 3, 6, 7, 8, 9, 10, 11, 15], "concept": [0, 4, 7, 8], "expos": [0, 6], "an": [0, 1, 2, 3, 6, 7, 8, 9, 10, 11, 12, 13, 15], "api": [0, 2, 4, 6, 13], "allow": [0, 3, 6, 7, 8, 9, 10, 15], "user": [0, 1, 2, 3, 4, 5, 6, 8, 10, 13, 15], "declar": [0, 3, 7, 8, 9], "topologi": [0, 3], "unstructur": [0, 3, 6], "mesh": [0, 3, 6, 10, 15], "form": [0, 2, 3, 8, 9, 15], "set": [0, 1, 2, 4, 6, 7, 8, 10, 11, 12, 13], "map": [0, 1, 2, 4, 6, 7, 8, 11, 13], "data": [0, 1, 2, 4, 6, 8, 9, 10, 11, 12, 13, 15], "dat": [0, 1, 4, 6, 7, 8, 10, 11, 12, 13], "mat": [0, 4, 8, 10, 13], "global": [0, 1, 7, 8, 9, 11, 13, 15], "const": [0, 1], "comput": [0, 1, 2, 3, 4, 6, 7, 8, 9, 11, 12, 15], "thi": [0, 1, 2, 3, 5, 6, 7, 8, 9, 10, 11, 12, 13, 15], "ar": [0, 1, 2, 3, 6, 7, 8, 9, 10, 11, 12, 13, 15], "kernel": [0, 1, 3, 4, 8, 9, 10, 12, 13, 15], "execut": [0, 1, 2, 3, 4, 6, 7, 10, 12, 13, 15], "parallel": [0, 1, 2, 4, 6, 7, 8, 10, 12, 15], "loop": [0, 1, 2, 4, 6, 7, 8, 11, 12, 15], "The": [0, 1, 2, 3, 4, 5, 7, 8, 9, 10, 11, 12, 13, 15], "i": [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 15], "frontend": 0, "runtim": [0, 1, 2, 12], "compil": [0, 1, 2, 4, 6], "which": [0, 1, 2, 3, 6, 7, 8, 9, 10, 11, 12, 13, 15], "gener": [0, 1, 2, 3, 6, 8, 9, 11, 12, 13, 15], "just": [0, 1, 13, 15], "time": [0, 1, 6, 7, 11, 12, 13, 15], "jit": [0, 1, 13], "low": 0, "level": [0, 7, 11, 13], "code": [0, 1, 2, 6, 7, 8, 10, 11, 12, 13], "rang": [0, 6, 8, 13], "effici": [0, 3, 6, 7, 10, 11], "schedul": [0, 1, 3], "A": [0, 1, 3, 6, 7, 8, 9, 10, 11, 12, 13, 15], "schemat": 0, "overview": [0, 1, 6], "given": [0, 1, 3, 6, 7, 8, 10, 12, 13, 15], "below": [0, 1, 3, 8, 10, 12], "from": [0, 1, 2, 3, 6, 8, 9, 10, 11, 13, 15], "outsid": 0, "perspect": 0, "convent": 0, "python": [0, 1, 2, 5, 7, 12, 13, 15], "librari": [0, 1, 8, 13], "perform": [0, 2, 4, 7, 8, 10, 11, 15], "critic": [0, 13], "function": [0, 1, 2, 3, 6, 7, 8, 12, 13, 15], "implement": [0, 1, 2, 3, 6, 7, 9, 10, 15], "cython": 0, "": [0, 1, 2, 6, 8, 9, 10, 15], "applic": [0, 3, 6, 11, 12], "make": [0, 1, 2, 3, 6, 7, 12, 15], "call": [0, 1, 2, 3, 6, 7, 8, 10, 12, 13, 15], "most": [0, 1, 3, 6, 9, 11, 12], "except": [0, 4, 8, 11], "par_loop": [0, 1, 2, 3, 7, 8, 9, 10, 11, 15], "encapsul": [0, 6], "core": [0, 1, 3, 6, 10, 15], "specif": [0, 1, 3, 4], "compris": [0, 8], "follow": [0, 1, 2, 3, 6, 7, 8, 9, 10, 11, 12], "step": [0, 6], "plan": [0, 1, 4, 12], "includ": [0, 8, 15], "inform": [0, 3, 11], "stage": [0, 1, 3, 4, 7, 8, 13, 15], "partit": [0, 1, 3, 4, 10, 15], "colour": [0, 1, 3, 4, 10], "iter": [0, 1, 2, 3, 4, 6, 8, 9, 11, 13, 15], "conflict": [0, 1, 15], "free": [0, 1, 6], "process": [0, 1, 2, 6, 8, 10, 11, 13, 15], "doe": [0, 1, 2, 3, 7, 8, 12, 15], "appli": [0, 1, 3, 6, 9], "sequenti": [0, 6, 8, 11], "argument": [0, 1, 2, 3, 6, 7, 8, 10, 11, 13, 15], "detail": [0, 1, 3, 8, 13, 15], "accord": [0, 6, 10, 13], "previou": [0, 1, 6], "pass": [0, 1, 2, 3, 6, 7, 8, 9, 11, 13, 15], "toolchain": 0, "produc": [0, 9, 12, 13], "share": [0, 1, 8, 9, 11, 13], "callabl": [0, 1, 2], "modul": [0, 2, 4], "dynam": [0, 9], "load": [0, 2, 6, 13, 15], "cach": [0, 1, 3, 4, 6, 8, 10, 11], "disk": [0, 1, 2], "save": [0, 8, 12, 13, 15], "recompil": 0, "when": [0, 1, 3, 6, 8, 9, 10, 12, 13, 15], "same": [0, 1, 2, 3, 6, 8, 9, 11, 13, 15], "again": [0, 2, 6, 8, 10, 11, 12], "build": [0, 1, 2, 3, 4, 6, 9, 12, 15], "list": [0, 1, 6, 7, 9, 13, 15], "mai": [0, 2, 3, 6, 7, 10], "initi": [0, 1, 6, 10, 15], "host": [0, 4, 8], "devic": [0, 3, 4, 11], "transfer": [0, 1, 3, 8], "cuda": [0, 7, 8], "opencl": [0, 7], "actual": [0, 1, 7, 10, 12, 13, 15], "For": [0, 2, 3, 6, 7, 8, 9, 10, 11, 15], "distribut": [0, 1, 4, 7, 8], "involv": [0, 1, 5, 6], "separ": [0, 1, 2, 8, 9, 10], "region": [0, 1, 10, 12, 13], "own": [0, 1, 8, 10, 12, 15], "current": [0, 1, 2, 6, 7, 8, 11], "processor": [0, 8, 10], "halo": [0, 1, 4, 12, 13], "mpi": [0, 1, 4, 8, 11, 15], "ani": [0, 1, 2, 3, 6, 7, 10, 12, 13, 15], "necessari": [0, 1], "reduct": [0, 10, 11, 12, 15], "matrix": [0, 1, 3, 4, 9, 10, 11, 13, 15], "assembli": [0, 3, 4, 6, 7, 15], "procedur": [0, 1], "select": [0, 4, 15], "keyword": [0, 7, 8], "init": [0, 2, 6], "If": [0, 1, 6, 7, 10, 11, 13, 15], "omit": [0, 3, 7, 8, 12, 15], "default": [0, 8, 12, 13, 15], "choic": [0, 8], "can": [0, 1, 2, 3, 4, 6, 7, 8, 9, 10, 11, 12, 15], "overridden": 0, "export": 0, "environ": [0, 1, 2, 12], "variabl": [0, 1, 2, 3, 6, 12, 13], "pyop2_backend": 0, "switch": 0, "without": [0, 3, 6, 10, 12, 15], "have": [0, 1, 2, 3, 6, 7, 8, 10, 12, 15], "touch": [0, 10, 11, 15], "onc": [0, 1, 2, 10, 13], "chosen": [0, 6, 8], "cannot": [0, 7, 15], "chang": [0, 1, 2, 13], "durat": 0, "run": [0, 1, 2, 6, 7, 15], "interpret": [0, 3], "session": 0, "provid": [0, 1, 3, 6, 8, 9, 12, 15], "singl": [0, 1, 3, 6, 7, 8, 11, 15], "regardless": 0, "all": [0, 1, 2, 3, 6, 7, 8, 9, 10, 11, 13, 15], "class": [0, 4, 13, 15], "public": 0, "defin": [0, 1, 2, 3, 7, 8, 9, 10, 13, 15], "op2": [0, 1, 2, 3, 4, 6, 7, 8, 9, 15], "interfac": [0, 1, 4, 6, 15], "whose": [0, 1, 15], "concret": 0, "initialis": [0, 1, 6, 8, 15], "metaclass": 0, "take": [0, 1, 2, 3, 6, 8, 15], "care": [0, 1, 3, 4, 15], "instanti": [0, 13], "version": [0, 1, 4, 5, 8, 12], "request": [0, 1, 6, 8, 10, 15], "correspond": [0, 1, 6, 7, 8, 15], "docstr": [0, 13], "entir": [0, 1, 6, 9, 10, 11, 12], "transpar": [0, 9], "complet": [0, 1, 6, 10], "orthogon": 0, "us": [0, 1, 2, 3, 4, 5, 7, 8, 9, 10, 11, 13, 15], "establish": 0, "practic": [0, 10], "object": [0, 1, 3, 4, 6, 13, 15], "orient": 0, "design": 0, "number": [1, 2, 3, 4, 6, 7, 8, 9, 11, 12, 13, 15], "differ": [1, 2, 3, 6, 10, 13, 15], "abl": [1, 10], "hardwar": 1, "architectur": [1, 4, 6, 7], "support": [1, 3, 4, 6, 7, 8, 10, 15], "cpu": [1, 4], "multipl": [1, 3, 4, 6, 8, 13, 15], "thread": [1, 6, 7, 8, 10, 11], "smp": 1, "omp_num_thread": 1, "offload": 1, "nvida": 1, "gpu": [1, 4, 6, 10], "requir": [1, 3, 5, 7, 8, 10, 11, 15], "pycuda": 1, "either": [1, 2, 15], "multi": 1, "pyopencl": 1, "datastructur": 1, "must": [1, 2, 3, 6, 7, 8, 9, 10, 15], "among": [1, 6, 7, 8, 10], "overlap": [1, 4], "so": [1, 2, 3, 6, 11, 15], "full": [1, 15], "onli": [1, 2, 3, 6, 7, 8, 9, 10, 11, 12, 13, 15], "hybrid": 1, "possibl": [1, 3, 6, 15], "where": [1, 2, 3, 7, 8, 11, 13, 15], "launch": [1, 7, 8, 10], "per": [1, 7, 8, 10, 11, 12, 15], "rank": [1, 15], "each": [1, 2, 3, 7, 8, 9, 10, 11, 13, 15], "individu": [1, 6, 15], "via": [1, 3, 7, 8, 9, 15], "ctype": [1, 13, 15], "also": [1, 5, 6, 9, 10, 12, 15], "cost": [1, 2, 10], "paid": 1, "everi": [1, 2, 15], "sinc": [1, 2, 3, 6, 7, 8, 10, 11, 15], "c": [1, 6, 7, 13, 15], "wrapper": [1, 8, 10], "respect": [1, 3, 7, 9], "out": [1, 2, 3, 4, 6, 7, 8, 10, 13], "access": [1, 6, 7, 9, 10, 11, 13], "descriptor": [1, 7, 15], "both": [1, 2, 6, 9, 15], "unit": 1, "inlin": 1, "incur": 1, "overhead": [1, 15], "recal": 1, "midpoint": [1, 3, 7], "cell": [1, 3, 7, 9, 15], "write": [1, 3, 6, 7, 8, 10, 12, 13, 15], "coordin": [1, 3, 7], "read": [1, 3, 4, 7, 9, 10, 11, 13, 15], "cell2vertex": [1, 7], "void": [1, 3, 6, 7, 8, 9], "doubl": [1, 3, 6, 7, 8, 9, 13], "p": [1, 7], "2": [1, 3, 6, 7, 8, 9, 12, 13, 15], "coord": [1, 3, 7], "0": [1, 3, 6, 7, 8, 9, 10, 12, 15], "1": [1, 2, 3, 6, 7, 8, 9, 10, 12, 13, 15], "3": [1, 3, 5, 6, 7, 8, 9, 12, 13, 15], "wrap_midpoint__": 1, "pyobject": 1, "_start": 1, "_end": 1, "_arg0_0": 1, "_arg1_0": 1, "_arg1_0_map0_0": 1, "int": [1, 6, 7, 8, 9, 13, 15], "start": [1, 8, 10, 15], "pyint_aslong": 1, "end": [1, 6, 8, 10, 15], "arg0_0": 1, "pyarrayobject": 1, "arg1_0": 1, "arg1_0_map0_0": 1, "arg1_0_vec": 1, "n": [1, 8, 9, 12, 15], "note": [1, 3, 7, 9, 12, 15], "directli": [1, 3, 6, 7, 8], "therefor": [1, 3, 5, 6, 8, 10, 12], "plain": [1, 7], "first": [1, 2, 3, 6, 7, 8, 9, 10], "need": [1, 3, 7, 8, 10, 15], "unwrap": 1, "indic": [1, 3, 8, 11, 13, 15], "over": [1, 2, 3, 7, 8, 9, 10, 11, 12, 15], "remain": [1, 2], "arrai": [1, 6, 7, 8, 11, 15], "consecut": 1, "avoid": [1, 10, 11, 15], "name": [1, 3, 6, 7, 8, 12, 13, 15], "clash": 1, "direct": [1, 3, 7, 15], "pointer": [1, 2, 7, 8], "straight": 1, "appropri": [1, 13, 15], "offset": [1, 3, 8, 11, 13, 15], "second": [1, 2, 6, 7, 9, 13], "indirect": [1, 7, 10, 11, 15], "henc": [1, 2], "pair": [1, 3, 8, 9, 11], "gather": [1, 7, 9], "ariti": [1, 2, 3, 7, 8, 13, 15], "alreadi": [1, 6, 8, 15], "two": [1, 2, 3, 6, 8, 10, 11, 15], "valu": [1, 3, 7, 8, 13, 15], "dataset": [1, 2, 3, 4, 7, 8, 13], "dimens": [1, 3, 6, 7, 8, 13, 15], "case": [1, 3, 6, 7, 8, 9, 10, 12, 15], "In": [1, 2, 3, 6, 7, 8, 9, 15], "contrast": [1, 3], "outermost": 1, "annot": [1, 12], "pragma": [1, 6], "To": [1, 2, 3, 6, 7, 10, 11, 12], "race": [1, 11], "condit": [1, 11], "safe": [1, 7, 10], "abov": [1, 2, 3, 7, 8, 10, 15], "_boffset": 1, "_nblock": 1, "_blkmap": 1, "_offset": 1, "_nelem": 1, "boffset": 1, "nblock": 1, "blkmap": 1, "nelem": [1, 8], "32": [1, 11], "ifdef": 1, "_openmp": 1, "nthread": 1, "omp_get_max_thread": 1, "els": [1, 8, 15], "endif": 1, "omp": 1, "tid": 1, "omp_get_thread_num": 1, "static": 1, "__b": 1, "bid": 1, "efirst": 1, "split": [1, 6, 11, 13, 15], "block": [1, 4, 6, 13, 15], "wrap": [1, 8, 13], "id": [1, 7], "index": [1, 3, 4, 7, 8, 13, 15], "part": [1, 2, 8, 9, 12, 15], "These": [1, 2, 8], "element": [1, 3, 6, 7, 8, 9, 11, 15], "its": [1, 3, 6, 7, 8, 9, 10, 11, 15], "scope": 1, "common": [1, 3, 6, 9, 13], "carrier": 1, "memori": [1, 2, 3, 4, 7, 8, 11, 13, 15], "flag": [1, 7, 13], "present": [1, 13], "state": 1, "device_unalloc": 1, "alloc": [1, 8, 11, 15], "host_unalloc": 1, "up": [1, 2, 3, 6, 8, 10, 11, 12, 15], "date": [1, 4, 10, 15], "valid": [1, 3, 8, 9, 13, 15], "invalid": [1, 13], "determin": [1, 8, 13], "prior": [1, 3], "target": [1, 3, 7], "locat": [1, 11], "trigger": [1, 6, 10], "lazili": 1, "e": [1, 3, 6, 7, 8, 12, 13, 15], "copi": [1, 13, 15], "occur": [1, 2, 9, 15], "particular": [1, 2, 3, 6, 7, 8], "automat": [1, 3, 6, 7, 8, 12], "back": [1, 7, 15], "unless": 1, "newli": [1, 11], "creat": [1, 3, 6, 7, 13, 15], "ha": [1, 2, 3, 6, 7, 9, 10, 11, 15], "associ": [1, 3, 9, 15], "diagram": [1, 9, 10], "show": [1, 6, 15], "action": 1, "transit": 1, "divid": [1, 8, 10], "three": [1, 2, 3, 7, 8, 15], "group": [1, 13], "explicit": [1, 6, 7], "red": 1, "black": 1, "blue": 1, "There": [1, 2, 3, 6, 7, 9, 10, 12, 15], "explicitli": [1, 3, 15], "tranfer": 1, "wa": 1, "befor": [1, 2, 3, 10, 12], "afterward": [1, 8], "written": [1, 3, 6, 7], "tabl": 1, "h2d": 1, "leav": [1, 6], "properti": [1, 13, 15], "data_ro": [1, 13, 15], "wai": [1, 3, 5, 6, 7, 9, 10, 11, 12], "never": 1, "modifi": [1, 6, 7, 10, 15], "extens": 1, "infrastructur": 1, "them": [1, 3, 15], "linear": [1, 3, 4, 6, 9, 15], "solver": [1, 8, 10, 12, 15], "spars": [1, 3, 4], "structur": [1, 3, 6, 8, 9, 10, 13, 15], "top": [1, 2, 6, 9, 15], "cusp": [1, 8], "greater": [1, 7], "algebra": [1, 4, 6, 15], "templat": 1, "base": [1, 2, 6, 8, 9, 13, 15], "approach": [1, 6], "__global__": [1, 8], "stub": 1, "routin": 1, "marshal": 1, "__device__": 1, "we": [1, 2, 3, 6, 7, 10, 15], "consid": [1, 3, 4, 6, 7, 8, 9], "exampl": [1, 2, 3, 6, 7, 8, 9, 15], "modif": [1, 7, 8], "qualifi": 1, "__midpoint_stub": 1, "paramet": [1, 3, 6, 8, 13, 15], "type": [1, 2, 3, 4, 7, 8, 13], "It": [1, 3, 4, 6, 7, 11, 15], "translat": [1, 3, 7], "set_siz": 1, "set_offset": 1, "arg0": [1, 8], "ind_arg1": 1, "ind_map": 1, "short": 1, "loc_map": 1, "ind_siz": 1, "ind_off": 1, "block_offset": 1, "nthrcol": 1, "thrcol": 1, "extern": 1, "__shared__": 1, "char": 1, "ind_arg1_map": 1, "ind_arg1_s": 1, "ind_arg1_shar": 1, "offset_b": 1, "offset_b_ab": 1, "ind_arg1_vec": 1, "blockidx": [1, 8], "x": [1, 5, 6, 8, 13], "y": [1, 6], "griddim": 1, "return": [1, 3, 7, 8, 13, 15], "threadidx": [1, 8], "blockid": 1, "nbyte": [1, 13, 15], "__syncthread": 1, "idx": [1, 8], "blockdim": [1, 8], "identifi": [1, 3], "insid": [1, 15], "within": [1, 6, 11, 15], "dimension": [1, 3, 6, 8], "grid": 1, "potenti": [1, 2], "prevent": [1, 13], "simultan": 1, "area": 1, "see": [1, 7, 9, 12, 13, 15], "line": [1, 4], "30": 1, "41": 1, "ensur": [1, 2, 9], "visibl": [1, 3], "after": [1, 3, 7, 10], "barrier": 1, "cooper": 1, "indirectli": [1, 3, 7, 8, 9, 11], "anoth": [1, 3, 6, 11, 13, 15], "synchronis": 1, "increment": [1, 3, 6, 13, 15], "size": [1, 2, 3, 6, 7, 8, 10, 11, 13, 15], "privat": 1, "built": [1, 2, 3, 6, 8, 13], "other": [1, 3, 6, 8, 9, 10, 12, 15], "suitabl": 1, "veri": [1, 3, 6, 7, 10, 12], "similar": [1, 3, 8, 10], "driver": 1, "oper": [1, 2, 3, 6, 7, 8, 15], "handl": [1, 3, 15], "petsc": [1, 8, 9, 10, 12, 13, 15], "signatur": [1, 6, 7], "storag": [1, 4], "string": [1, 6, 7, 13, 15], "enqueu": 1, "convers": 1, "round_up": 1, "byte": [1, 13, 15], "15": 1, "__global": 1, "__local": 1, "__kernel": 1, "__attribute__": 1, "reqd_work_group_s": 1, "668": 1, "p_ind_map": 1, "p_loc_map": 1, "p_ind_siz": 1, "p_ind_offset": 1, "p_blk_map": 1, "p_offset": 1, "p_nelem": 1, "p_nthrcol": 1, "p_thrcol": 1, "__privat": 1, "64": [1, 5, 11], "align": [1, 6, 13], "sizeof": 1, "long": [1, 2, 7], "active_threads_count": 1, "block_id": 1, "i_1": 1, "get_local_id": 1, "get_group_id": 1, "clk_local_mem_f": 1, "get_local_s": 1, "work": [1, 5, 6, 7, 10, 11, 12], "item": [1, 2, 7, 13], "organis": 1, "thei": [1, 2, 3, 9, 10, 15], "point": [1, 3, 7, 15], "local": [1, 3, 4, 6, 8, 9, 13, 15], "across": 1, "enforc": [1, 6], "bear": 1, "mind": 1, "almost": [1, 6], "ident": [1, 2], "wherea": 1, "hard": 1, "attribut": [1, 2, 6, 8, 9], "heavi": 2, "advers": 2, "affect": 2, "too": [2, 13, 15], "mani": [2, 3, 4, 6, 7, 9], "expens": [2, 3, 6, 8], "subsequ": [2, 8, 10, 15], "simul": 2, "pai": [2, 6], "been": [2, 3, 6, 7, 8, 10, 11], "result": [2, 3, 7, 8, 9, 13, 15], "lifetim": 2, "fast": 2, "some": [2, 3, 5, 6, 9, 15], "sparsiti": [2, 3, 4, 12, 15], "construct": [2, 3, 6, 8, 9, 11, 12, 15], "uniqu": [2, 3, 8, 11], "strategi": [2, 6], "axiom": 2, "equal": [2, 8, 11], "should": [2, 5, 6, 11, 13, 15], "depend": [2, 5, 6, 10], "metadata": [2, 3, 15], "impli": 2, "compar": [2, 10], "independ": [2, 3, 10], "absolut": 2, "kei": [2, 6, 8], "On": [2, 6, 7], "consequ": 2, "rule": [2, 9], "effect": 2, "distinguish": [2, 3, 6, 13, 15], "itself": [2, 3, 13], "live": [2, 3], "instanc": [2, 6, 9, 15], "cacheabl": 2, "inherit": 2, "evict": 2, "grow": [2, 10], "larg": [2, 3, 6, 7], "error": [2, 13, 15], "objectcach": [2, 15], "_cach": 2, "motiv": 2, "reli": 2, "being": [2, 3, 7, 13], "do": [2, 3, 10, 15], "worri": 2, "much": [2, 3, 6, 12], "about": [2, 10], "carri": 2, "around": [2, 8], "temporari": 2, "forev": 2, "hit": 2, "hierarchi": 2, "transient": 2, "immut": 2, "throw": 2, "awai": 2, "normal": [2, 15], "intern": [2, 4, 13], "howev": [2, 4, 9, 10, 15], "thu": [2, 4], "snippet": 2, "d": [2, 8, 9, 15], "ds2": 2, "10": 2, "assert": 2, "setup": 2, "ti": 2, "program": [2, 4, 6, 13], "hold": [2, 15], "refer": [2, 3, 11, 13], "one": [2, 3, 6, 7, 8, 9, 10, 13, 15], "soon": [2, 10], "lost": 2, "becom": 2, "candid": 2, "garbag": 2, "collect": [2, 8, 11, 15], "collector": 2, "onto": [2, 15], "persist": 2, "problem": 2, "instruct": [2, 13], "print": [2, 12, 13], "exit": [2, 12, 13, 15], "done": [2, 3, 8, 10, 11, 13], "pyop2_print_cache_s": [2, 13], "print_cache_s": [2, 13], "numer": [3, 6, 13], "algorithm": [3, 8, 11], "scientif": 3, "view": [3, 15], "everywher": 3, "often": [3, 9], "lend": 3, "natur": 3, "entiti": [3, 10, 15], "vertic": [3, 7, 11, 15], "edg": [3, 11], "connect": 3, "between": [3, 6, 7, 10, 15], "those": [3, 6, 11, 12], "domain": [3, 6], "languag": [3, 6], "dsl": [3, 6], "graph": 3, "repres": [3, 6, 8, 12, 15], "node": [3, 6, 8, 9, 13], "degre": [3, 10], "freedom": [3, 10], "field": 3, "while": [3, 11], "link": 3, "incid": 3, "coincid": 3, "necessarili": [3, 11], "g": [3, 6, 12, 13, 15], "constant": [3, 13, 15], "sourc": [3, 9, 12], "inject": [3, 12], "surject": 3, "restrict": [3, 7], "exclud": [3, 15], "certain": [3, 6, 12], "kind": [3, 6], "egd": 3, "regular": 3, "vertex": [3, 7, 11], "edges2vertic": 3, "4": [3, 7, 13, 15], "section": [3, 6, 10], "cardin": 3, "through": [3, 6, 7, 10, 15], "addit": [3, 7, 12], "specifi": [3, 6, 15], "how": [3, 4, 7, 11, 13], "store": [3, 6, 7, 8, 10, 15], "datatyp": [3, 4, 7], "shape": [3, 7, 13, 15], "One": [3, 6], "scalar": [3, 15], "higher": [3, 6, 7], "vector": [3, 6, 7, 8, 9, 10, 11, 15], "uniform": 3, "primit": 3, "numpi": [3, 7, 13, 15], "custom": 3, "insofar": 3, "serialis": 3, "deserialis": 3, "float": [3, 7, 8], "like": [3, 6, 12, 13, 15], "dvertic": 3, "dim": [3, 7, 13, 15], "dtype": [3, 7, 8, 13, 15], "2x2": [3, 9], "elast": 3, "tensor": [3, 6, 7, 8, 9], "would": [3, 6, 7], "ep": 3, "1e": 3, "14": 3, "context": [3, 13, 15], "word": [3, 8], "b": [3, 8, 15], "Of": [3, 6], "cours": [3, 6], "least": 3, "equival": [3, 9], "pattern": [3, 4, 9, 12, 13], "row": [3, 8, 9, 10, 11, 15], "column": [3, 8, 9, 15], "space": [3, 4, 6, 8, 9, 15], "more": [3, 6, 7, 8, 9, 12, 13, 15], "non": [3, 6, 8, 10, 15], "zero": [3, 6, 8, 13, 15], "pure": 3, "decoupl": 3, "reus": 3, "recomput": [3, 8], "fact": [3, 7], "behalf": 3, "previous": 3, "yield": [3, 8, 9], "instead": [3, 6, 10, 15], "span": 3, "hide": 3, "complex": [3, 7, 15], "chip": [3, 7], "order": [3, 7, 10, 15], "maximum": 3, "flexibl": 3, "than": [3, 6, 8, 9, 12, 13, 15], "underli": [3, 6, 15], "even": 3, "though": 3, "rw": [3, 7, 10, 13, 15], "give": [3, 5, 6, 8, 11, 15], "crucial": 3, "treat": [3, 9], "dure": [3, 7, 10, 13], "inc": [3, 7, 8, 9, 10, 13, 15], "min": [3, 13, 15], "minimum": 3, "max": [3, 13, 15], "Not": 3, "mode": [3, 8, 10, 13, 15], "ll": 3, "assum": [3, 6, 10, 15], "input": [3, 9], "output": [3, 12], "accumul": 3, "contribut": [3, 8, 9, 10, 15], "mean": [3, 6, 12, 15], "you": [3, 5, 6, 12, 13, 15], "stack": 3, "success": [3, 6], "add": [3, 8, 12], "tell": [3, 6, 12], "want": [3, 6, 15], "solv": [3, 4, 9], "primarili": [3, 6], "quantiti": [3, 9], "reduc": [3, 15], "summat": 3, "find": [3, 6], "l2": [3, 15], "norm": [3, 13, 15], "pressur": [3, 6, 9], "l2norm": 3, "constructor": [3, 7], "anonym": [3, 7], "prose": 4, "contain": [4, 5, 6, 8, 11, 15], "here": [4, 6], "significantli": 4, "inaccuraci": 4, "nevertheless": 4, "quit": 4, "resourc": [4, 7], "peopl": 4, "new": [4, 11, 13], "pleas": 4, "updat": [4, 13, 15], "regularli": [4, 12], "accur": 4, "content": 4, "instal": [4, 12], "layout": [4, 8, 15], "intermedi": [4, 15], "represent": [4, 13, 15], "achiev": 4, "portabl": 4, "ir": 4, "optim": 4, "backend": [4, 6, 8, 10, 11], "format": [4, 13, 15], "system": [4, 6, 9], "renumb": 4, "mix": [4, 13], "commun": [4, 13, 15], "exchang": [4, 12, 15], "debug": [4, 13], "leak": 4, "profil": 4, "timer": 4, "packag": 4, "subpackag": 4, "submodul": 4, "configur": [4, 8], "global_kernel": 4, "local_kernel": 4, "logger": 4, "parloop": [4, 6, 12], "util": 4, "search": [4, 8], "page": 4, "6": [5, 7, 15], "later": [5, 13], "main": [5, 6, 10], "test": [5, 6], "platform": [5, 6, 7], "ubuntu": 5, "18": 5, "04": 5, "bit": [5, 11], "successfulli": 5, "mac": 5, "o": [5, 12, 15], "somewhat": 5, "recommend": 5, "obtain": [5, 6, 7, 15], "firedrak": 5, "script": [5, 12], "venv": 5, "simpl": [6, 12], "guidelin": 6, "term": 6, "get": [6, 12, 15], "simplest": 6, "express": [6, 15], "semant": [6, 15], "abstract": [6, 15], "syntax": [6, 7], "tree": [6, 13], "manual": [6, 8], "thought": 6, "fed": 6, "layer": [6, 13, 15], "rather": [6, 7, 13, 15], "ast": 6, "parser": [6, 13], "advantag": 6, "enabl": [6, 12, 15], "inspect": 6, "transform": 6, "aim": 6, "better": 6, "purpos": 6, "exposit": 6, "let": 6, "u": 6, "member": [6, 15], "import": [6, 12], "edge_weight": 6, "basic": 6, "come": 6, "ast_bas": 6, "flatblock": 6, "flat": 6, "engin": 6, "possibli": 6, "fragment": 6, "interest": [6, 9, 12], "particularli": 6, "speed": 6, "develop": 6, "hand": [6, 8, 15], "demand": [6, 15], "properli": 6, "real": 6, "could": [6, 7, 13], "ast_bodi": 6, "go": 6, "c_for": 6, "assign": 6, "symbol": 6, "c_sym": 6, "fundecl": 6, "decl": 6, "bodi": 6, "sort": [6, 8, 11], "shortcut": 6, "extent": [6, 7, 15], "statement": 6, "fundament": 6, "final": [6, 9], "found": [6, 7, 12], "folder": [6, 12], "look": [6, 15], "test_matric": 6, "py": [6, 12], "test_iteration_space_dat": 6, "exactli": 6, "strive": 6, "best": 6, "machin": 6, "mainli": 6, "inher": 6, "avail": [6, 11, 13], "Then": 6, "maxim": 6, "outcom": 6, "simpli": 6, "That": 6, "prematur": 6, "might": [6, 15], "harm": 6, "minim": [6, 8], "had": 6, "embed": 6, "goal": 6, "decor": [6, 12, 13], "ad": [6, 8], "creation": [6, 7], "itspac": 6, "fulli": 6, "synchron": 6, "itvar1": 6, "itvar2": 6, "denot": 6, "along": 6, "simd": [6, 13], "suggest": [6, 8], "known": [6, 7], "inter": 6, "featur": [6, 10], "futur": 6, "releas": 6, "extract": [6, 15], "our": 6, "usual": [6, 8], "now": 6, "imagin": 6, "typic": 6, "becaus": [6, 10, 15], "small": [6, 10, 15], "fit": [6, 11], "l1": 6, "benefit": 6, "gain": 6, "distinct": [6, 11, 15], "acceler": 6, "model": 6, "huge": 6, "amount": [6, 7, 11], "deleg": 6, "chunk": [6, 7, 11], "off": [6, 8, 10, 13], "re": [6, 15], "exploit": [6, 8], "far": 6, "effort": 6, "spent": 6, "Being": 6, "method": [6, 8, 9, 15], "capabl": 6, "aggress": 6, "finit": [6, 7, 9], "categori": [6, 10], "autovector": 6, "dso": 6, "s1": [6, 9], "s2": [6, 9], "j": [6, 7, 8, 9], "outerproduct": 6, "k": [6, 7, 8], "incr": 6, "prod": 6, "conceptu": 6, "visit": 6, "ignor": [6, 12, 13], "lack": 6, "autotun": 6, "drive": 6, "autom": 6, "pad": 6, "issu": 6, "trip": 6, "count": [6, 13], "adjust": 6, "length": [6, 7, 8, 9, 13, 15], "invari": 6, "motion": 6, "hoist": [6, 7], "still": [6, 10], "signific": [6, 15], "proport": [6, 7], "regist": [6, 7], "tile": 6, "rectangular": 6, "outer": 6, "product": [6, 7, 15], "unrol": 6, "jam": 6, "improv": [6, 7], "mitig": 6, "analys": 6, "try": [6, 13, 15], "ffc": 6, "emblemat": 6, "plai": 6, "variou": [6, 8], "seri": 6, "opt": [6, 13], "licm": 6, "fals": [6, 12, 13, 15], "none": [6, 10, 13, 15], "ap": 6, "vect": 6, "my_kernel": 6, "dictionari": [6, 8], "option": [6, 7, 8, 13, 15], "No": [6, 15], "intra": 6, "true": [6, 7, 13], "know": 6, "8": [6, 13], "slice": 6, "8x8": 6, "smaller": 6, "By": [6, 10], "choos": [6, 11], "alwai": [6, 7, 15], "bound": [6, 13], "av": 6, "opportun": 6, "increas": [6, 7, 11], "chanc": 6, "ast_plan": 6, "autovect": 6, "ask": 6, "resort": 6, "techniqu": 6, "earli": 6, "experi": 6, "movement": 6, "well": [6, 13], "op": 6, "activ": 6, "v_op_uaj": 6, "uaj": 6, "stand": 6, "prove": 6, "combin": [6, 9], "incorpor": 6, "inner": [6, 13, 15], "factor": [6, 10], "larger": [6, 7, 10], "highli": 6, "characterist": 6, "match": [7, 8, 10], "invok": 7, "relationship": [7, 9], "phase": 7, "similarli": 7, "scatter": [7, 9, 15], "manipul": 7, "skip": [7, 15], "undefin": 7, "triangl": 7, "coveni": 7, "num_vertic": 7, "num_cel": 7, "subset": [7, 13, 15], "c99": 7, "third": 7, "fourth": 7, "agre": 7, "posit": [7, 8], "float64": [7, 8], "float32": 7, "int64": 7, "int32": [7, 15], "due": 7, "draw": 7, "attent": 7, "interchangibli": 7, "flatten": [7, 13, 15], "expect": [7, 13], "laid": 7, "compon": [7, 9, 15], "5": [7, 12, 15], "contigu": [7, 9, 10, 11, 15], "tupl": [7, 13, 15], "begin": [7, 15], "entri": [7, 8, 10, 15], "etc": 7, "limit": [7, 13], "usag": [7, 12, 15], "basi": 7, "consider": 7, "commonli": [7, 8], "serv": 7, "illustr": [7, 9, 10], "12x12": 7, "12": 7, "el": 7, "nele": 7, "manycor": 7, "sever": [7, 13], "lower": 7, "mass": 7, "doubli": 7, "nest": [7, 13, 15], "receiv": [7, 15], "told": 7, "iterationindex": [7, 8], "matric": [8, 10, 11, 13, 15], "thin": 8, "har": 8, "petsc4pi": 8, "vice": [8, 10], "versa": [8, 10], "squar": [8, 9], "popular": 8, "compress": 8, "csr": 8, "former": [8, 13], "integ": [8, 11, 15], "latter": [8, 15], "total": [8, 12, 15], "implicitli": [8, 15], "row_ptr": 8, "faster": 8, "lookup": 8, "binari": 8, "distribu": 8, "evenli": 8, "diagon": 8, "last": [8, 11], "assembl": [8, 9, 10, 11, 15], "iota_k": 8, "matsetvalu": 8, "At": [8, 11], "matassemblybegin": 8, "matassemblyend": 8, "finalis": [8, 10], "accss": 8, "elem_nod": 8, "num_nod": 8, "num_el": 8, "np": 8, "mat_kernel": 8, "right": [8, 9, 15], "side": [8, 15], "rhs_kernel": 8, "breviti": 8, "buffer": [8, 15], "addto_vector": 8, "wrap_mat_kernel__": 8, "buffer_arg0_0": 8, "arg0_0_0": 8, "objet": 8, "arg0_0_map0_0": 8, "arg0_0_map1_0": 8, "col": 8, "insert": [8, 10, 15], "whenev": 8, "exist": [8, 13, 15], "proce": [8, 11], "exclus": 8, "scan": 8, "concaten": [8, 15], "rowmap": 8, "colmap": 8, "from_siz": 8, "diag": 8, "minor": 8, "nrow": 8, "ncol": 8, "odiag": 8, "ksp": 8, "krylov": [8, 12], "conjug": [8, 15], "gradient": 8, "cg": 8, "residu": 8, "gmre": 8, "stabil": 8, "biconjug": 8, "bicgstab": 8, "complement": 8, "precondition": [8, 13], "pc": 8, "jacobi": [8, 12], "incomplet": 8, "choleski": 8, "lu": 8, "decomposit": 8, "multigrid": 8, "mechan": 8, "document": [8, 15], "pase": 8, "ksp_type": 8, "pc_type": 8, "solut": [8, 9], "ilu": 8, "soa": 8, "coalesc": 8, "manner": 8, "__mat_kernel_stub": 8, "arg0_offset": 8, "i0": 8, "i1": 8, "mass_cell_integral_0_otherwis": 8, "9": 8, "__lma_to_csr": 8, "lmadata": 8, "csrdata": 8, "rowptr": 8, "colidx": 8, "rowmapdim": 8, "colmapdim": 8, "nentries_per_el": 8, "po": 8, "__atomic_add": 8, "openmp": 8, "bridson": 8, "approxim": 8, "invers": [8, 11], "ainv": 8, "asymptot": 8, "amg": 8, "rais": [8, 13], "unsupport": 8, "equat": 9, "aris": 9, "fem": 9, "coupl": 9, "fluid": 9, "veloc": 9, "formul": 9, "navier": 9, "stoke": 9, "pyop2": [9, 10, 11], "mixedset": [9, 13, 15], "mixeddataset": [9, 13, 15], "mixedmap": [9, 13, 15], "mixeddat": [9, 13, 15], "under": [9, 12], "circumst": 9, "behav": 9, "uniformli": 9, "constitu": [9, 15], "conveni": 9, "themselv": 9, "m": [9, 12, 15], "md": 9, "mm": 9, "sr0": 9, "sr1": 9, "sc0": 9, "sc1": 9, "mr": 9, "mc": 9, "dsr": 9, "dsc": 9, "shown": 9, "matnest": [9, 13], "subblock": 9, "correct": [9, 15], "pack": 9, "togeth": 9, "mmap": 9, "3x3": 9, "v": 9, "left": [9, 15], "2x1": 9, "bottom": 9, "1x2": 9, "1x1": 9, "iota": 9, "boundari": 10, "neighbor": 10, "kept": 10, "consist": [10, 15], "entit": 10, "belong": 10, "four": [10, 15], "exec": 10, "redundantli": [10, 15], "highlight": 10, "correspondond": 10, "good": 10, "maximis": 10, "minimis": 10, "vast": 10, "major": 10, "immedi": 10, "latenc": 10, "bandwidth": 10, "rel": 10, "halo_exchange_begin": 10, "maybe_set_dat_dirti": 10, "mark": [10, 15], "compute_if_not_empti": 10, "itset": 10, "core_part": [10, 13, 15], "halo_exchange_end": 10, "wait": 10, "owned_part": [10, 13, 15], "reduction_begin": 10, "needs_exec_halo": 10, "exec_part": 10, "reduction_end": 10, "maybe_set_halo_update_need": 10, "concurr": [10, 11], "relat": [10, 15], "check": [10, 13], "whether": 10, "branch": 10, "keep": 10, "track": 10, "account": [10, 15], "disabl": [10, 15], "dof": [10, 13, 15], "price": 10, "maintain": 10, "redund": 10, "interior": 10, "volum": 10, "guid": 11, "mini": 11, "unrel": 11, "record": [11, 12], "referenc": 11, "mask": 11, "next": [11, 15], "suffici": 11, "reset": [11, 13], "made": 11, "until": [11, 15], "demo": 12, "cprofil": 12, "summari": 12, "stdout": 12, "help": 12, "intuit": 12, "excel": 12, "gprof2dot": 12, "pypi": 12, "sudo": 12, "pip": 12, "pdf": 12, "f": 12, "pstat": 12, "dot": 12, "tpdf": 12, "deal": 12, "gprof": 12, "everyth": 12, "less": 12, "aggreg": 12, "concat": 12, "file": [12, 15], "sy": 12, "glob": [12, 13], "stat": 12, "len": 12, "argv": 12, "__doc__": 12, "dump_stat": 12, "With": [12, 15], "basenam": 12, "your": [12, 15], "pyop2_print_summari": 12, "queri": [12, 13], "programat": 12, "helper": 12, "averag": 12, "timed_region": [12, 13], "timed_funct": [12, 13], "my": 12, "def": 12, "my_func": 12, "func": 12, "robert": 12, "kern": 12, "kernprof": 12, "l": 12, "line_profil": 12, "lprof": 12, "builtin": 12, "namespac": 12, "passthrough": 12, "noth": [12, 15], "__builtins__": 12, "remov": [12, 15], "lineprof": 12, "fabian": 12, "pedregosa": 12, "memory_profil": 12, "memprof": 12, "plot": 12, "codegen": 13, "builder": 13, "loopycompat": 13, "optimis": 13, "rep2loopi": 13, "abstractdat": [13, 15], "cdim": [13, 15], "data_with_halo": [13, 15], "data_ro_with_halo": [13, 15], "data_wo": [13, 15], "data_wo_with_halo": [13, 15], "global_to_local_begin": [13, 15], "global_to_local_end": [13, 15], "local_to_global_begin": [13, 15], "local_to_global_end": [13, 15], "frozen_halo": [13, 15], "freeze_halo": [13, 15], "unfreeze_halo": [13, 15], "datview": [13, 15], "halo_valid": [13, 15], "vec_context": [13, 15], "dat_vers": [13, 15], "increment_dat_vers": [13, 15], "data_carri": 13, "datacarri": [13, 15], "emptydatamixin": [13, 15], "vecaccessmixin": [13, 15], "vec": [13, 15], "vec_wo": [13, 15], "vec_ro": [13, 15], "lgmap": [13, 15], "scalar_lgmap": [13, 15], "unblocked_lgmap": [13, 15], "field_is": [13, 15], "local_is": [13, 15], "layout_vec": [13, 15], "dm": [13, 15], "globaldataset": [13, 15], "setfreedatacarri": [13, 15], "duplic": [13, 15], "comm": [13, 15], "local_to_global_numb": [13, 15], "iterset": [13, 15], "toset": [13, 15], "arang": [13, 15], "values_with_halo": [13, 15], "offset_quoti": [13, 15], "flattened_map": [13, 15], "permutedmap": [13, 15], "composedmap": [13, 15], "core_s": [13, 15], "total_s": [13, 15], "partition_s": [13, 15], "intersect": [13, 15], "union": [13, 15], "symmetric_differ": [13, 15], "globalset": [13, 15], "extrudedset": [13, 15], "parent": [13, 15], "layers_arrai": [13, 15], "superset": [13, 15], "owned_indic": [13, 15], "setpartit": [13, 15], "dict": 13, "cc": 13, "eg": 13, "gcc": 13, "path": [13, 15], "bin": 13, "cxx": 13, "ld": 13, "linker": 13, "cflag": 13, "extra": 13, "cxxflag": 13, "ldflag": 13, "simd_width": 13, "avx2": 13, "avx512": 13, "turn": 13, "type_check": 13, "ye": 13, "check_src_hash": 13, "allreduc": 13, "cache_dir": 13, "node_local_compil": 13, "filesystem": 13, "probabl": 13, "arrang": 13, "log_level": 13, "chatti": 13, "info": 13, "warn": 13, "block_spars": 13, "tmp": 13, "uid1001": 13, "pyop2_block_spars": 13, "bool": 13, "pyop2_cache_dir": 13, "str": 13, "pyop2_cc": 13, "pyop2_cflag": 13, "pyop2_check_src_hash": 13, "compute_kernel_flop": 13, "pyop2_compute_kernel_flop": 13, "pyop2_cxx": 13, "pyop2_cxxflag": 13, "pyop2_debug": 13, "pyop2_ld": 13, "pyop2_ldflag": 13, "pyop2_log_level": 13, "pyop2_matnest": 13, "no_fork_avail": 13, "pyop2_no_fork_avail": 13, "pyop2_node_local_compil": 13, "pyop2_simd_width": 13, "pyop2_type_check": 13, "reconfigur": 13, "kwarg": [13, 15], "unsafe_reconfigur": 13, "unsaf": 13, "replac": 13, "as_cstr": 13, "convert": 13, "as_ctyp": 13, "as_numpy_dtyp": 13, "dtype_limit": 13, "attempt": 13, "valueerror": 13, "datatypeerror": 13, "typeerror": 13, "dimtypeerror": 13, "aritytypeerror": 13, "indextypeerror": 13, "nametypeerror": 13, "settypeerror": 13, "sizetypeerror": 13, "subsetindexoutofbound": 13, "sparsitytypeerror": 13, "maptypeerror": 13, "datasettypeerror": 13, "mattypeerror": 13, "dattypeerror": 13, "kerneltypeerror": 13, "datavalueerror": 13, "illeg": 13, "indexvalueerror": 13, "modevalueerror": 13, "iteratevalueerror": 13, "setvalueerror": 13, "mapvalueerror": 13, "configurationerror": 13, "runtimeerror": 13, "compilationerror": 13, "sparsityformaterror": 13, "unabl": 13, "standard": [13, 15], "log": 13, "set_log_level": 13, "msg": 13, "arg": [13, 15], "messag": 13, "progress": 13, "manag": [13, 15], "indent": 13, "internal_comm": 13, "comm_world": 13, "pyop2_comm": 13, "is_pyop2_comm": 13, "incref": 13, "decref": 13, "decrement": 13, "temp_internal_comm": 13, "timed_stag": 13, "enter": 13, "event": 13, "cached_properti": 13, "fget": 13, "doc": 13, "evalu": 13, "leakag": 13, "as_tupl": 13, "allow_non": 13, "as_typ": 13, "obj": 13, "typ": 13, "otherwis": 13, "cast": 13, "tuplifi": 13, "validate_bas": 13, "formal": 13, "don": [13, 15], "t": [13, 15], "definit": 13, "silent": 13, "check_arg": 13, "validate_typ": 13, "fail": 13, "argtyp": 13, "validate_in": 13, "validate_rang": 13, "validate_dtyp": 13, "_": 13, "verify_reshap": 13, "verifi": 13, "reshap": 13, "16": 13, "descript": [13, 15], "argpars": 13, "argumentpars": 13, "parse_arg": 13, "pars": 13, "recognis": 13, "trim": 13, "pep": 13, "257": 13, "strip": 13, "get_petsc_dir": 13, "intenum": 15, "enumer": 15, "sum": 15, "respons": 15, "caus": 15, "invoc": 15, "abc": 15, "permiss": 15, "postpon": 15, "accomplish": 15, "notat": 15, "pointwis": 15, "divis": 15, "accessor": 15, "claim": 15, "logic": 15, "fewer": 15, "dirti": 15, "overwritten": 15, "unlik": 15, "filenam": 15, "_data": 15, "estim": 15, "payload": 15, "presum": 15, "destin": 15, "against": 15, "taken": 15, "act": 15, "access_mod": 15, "ghost": 15, "insert_mod": 15, "temporarili": 15, "repeatedli": 15, "bookkeep": 15, "freez": 15, "prefer": 15, "mdset_or_dat": 15, "bag": 15, "implcitli": 15, "upcast": 15, "mdat": 15, "mdset": 15, "dset1": 15, "dsetn": 15, "dat1": 15, "datn": 15, "revers": 15, "origin": 15, "multipli": 15, "compat": 15, "mixedmat": 15, "unfreez": 15, "frozen": 15, "whilst": 15, "label": 15, "mixin": 15, "petsc_count": 15, "ISes": 15, "proxi": 15, "mset": 15, "dim1": 15, "dimn": 15, "set1": 15, "setn": 15, "mixtur": 15, "termin": 15, "infinit": 15, "render": 15, "littl": 15, "statist": 15, "deep": 15, "self": 15, "dummi": 15, "desir": 15, "sent": 15, "finish": 15, "some_map": 15, "th": 15, "quotient": 15, "map_": 15, "permut": 15, "composit": 15, "maps_": 15, "compos": 15, "exisit": 15, "emploi": 15, "bracket": 15, "serial": 15, "send": 15, "extruded_period": 15, "past": 15, "stop": 15, "extrud": 15}, "objects": {"pyop2": [[13, 0, 0, "-", "configuration"], [13, 0, 0, "-", "datatypes"], [13, 0, 0, "-", "exceptions"], [13, 0, 0, "-", "logger"], [13, 0, 0, "-", "mpi"], [13, 0, 0, "-", "profiling"], [13, 0, 0, "-", "utils"]], "pyop2.configuration": [[13, 1, 1, "", "Configuration"]], "pyop2.configuration.Configuration": [[13, 2, 1, "", "DEFAULTS"], [13, 2, 1, "", "cache_dir"], [13, 3, 1, "", "reconfigure"], [13, 3, 1, "", "reset"], [13, 3, 1, "", "unsafe_reconfigure"]], "pyop2.datatypes": [[13, 4, 1, "", "as_cstr"], [13, 4, 1, "", "as_ctypes"], [13, 4, 1, "", "as_numpy_dtype"], [13, 4, 1, "", "dtype_limits"]], "pyop2.exceptions": [[13, 5, 1, "", "ArityTypeError"], [13, 5, 1, "", "CompilationError"], [13, 5, 1, "", "ConfigurationError"], [13, 5, 1, "", "DatTypeError"], [13, 5, 1, "", "DataSetTypeError"], [13, 5, 1, "", "DataTypeError"], [13, 5, 1, "", "DataValueError"], [13, 5, 1, "", "DimTypeError"], [13, 5, 1, "", "IndexTypeError"], [13, 5, 1, "", "IndexValueError"], [13, 5, 1, "", "IterateValueError"], [13, 5, 1, "", "KernelTypeError"], [13, 5, 1, "", "MapTypeError"], [13, 5, 1, "", "MapValueError"], [13, 5, 1, "", "MatTypeError"], [13, 5, 1, "", "ModeValueError"], [13, 5, 1, "", "NameTypeError"], [13, 5, 1, "", "SetTypeError"], [13, 5, 1, "", "SetValueError"], [13, 5, 1, "", "SizeTypeError"], [13, 5, 1, "", "SparsityFormatError"], [13, 5, 1, "", "SparsityTypeError"], [13, 5, 1, "", "SubsetIndexOutOfBounds"]], "pyop2.logger": [[13, 4, 1, "", "log"], [13, 4, 1, "", "progress"], [13, 4, 1, "", "set_log_level"]], "pyop2.mpi": [[13, 4, 1, "", "decref"], [13, 4, 1, "", "incref"], [13, 4, 1, "", "internal_comm"], [13, 4, 1, "", "is_pyop2_comm"], [13, 1, 1, "", "temp_internal_comm"]], "pyop2.profiling": [[13, 1, 1, "", "timed_function"], [13, 4, 1, "", "timed_region"], [13, 4, 1, "", "timed_stage"]], "pyop2.types": [[15, 0, 0, "-", "access"], [15, 0, 0, "-", "dat"], [15, 0, 0, "-", "data_carrier"], [15, 0, 0, "-", "dataset"], [15, 0, 0, "-", "glob"], [15, 0, 0, "-", "halo"], [15, 0, 0, "-", "map"], [15, 0, 0, "-", "set"]], "pyop2.types.access": [[15, 1, 1, "", "Access"], [15, 6, 1, "", "INC"], [15, 6, 1, "", "MAX"], [15, 6, 1, "", "MIN"], [15, 6, 1, "", "READ"], [15, 6, 1, "", "RW"], [15, 6, 1, "", "WRITE"]], "pyop2.types.access.Access": [[15, 2, 1, "", "INC"], [15, 2, 1, "", "MAX"], [15, 2, 1, "", "MIN"], [15, 2, 1, "", "READ"], [15, 2, 1, "", "RW"], [15, 2, 1, "", "WRITE"]], "pyop2.types.dat": [[15, 1, 1, "", "AbstractDat"], [15, 1, 1, "", "Dat"], [15, 1, 1, "", "DatView"], [15, 1, 1, "", "MixedDat"], [15, 1, 1, "", "frozen_halo"]], "pyop2.types.dat.AbstractDat": [[15, 2, 1, "", "cdim"], [15, 3, 1, "", "copy"], [15, 7, 1, "", "data"], [15, 7, 1, "", "data_ro"], [15, 7, 1, "", "data_ro_with_halos"], [15, 7, 1, "", "data_with_halos"], [15, 7, 1, "", "data_wo"], [15, 7, 1, "", "data_wo_with_halos"], [15, 2, 1, "", "dataset"], [15, 2, 1, "", "dim"], [15, 2, 1, "", "dtype"], [15, 3, 1, "", "freeze_halo"], [15, 3, 1, "", "frozen_halo"], [15, 3, 1, "", "global_to_local_begin"], [15, 3, 1, "", "global_to_local_end"], [15, 3, 1, "", "inner"], [15, 3, 1, "", "load"], [15, 3, 1, "", "local_to_global_begin"], [15, 3, 1, "", "local_to_global_end"], [15, 2, 1, "", "nbytes"], [15, 7, 1, "", "norm"], [15, 3, 1, "", "save"], [15, 2, 1, "", "shape"], [15, 2, 1, "", "split"], [15, 3, 1, "", "unfreeze_halo"], [15, 3, 1, "", "zero"]], "pyop2.types.dat.Dat": [[15, 3, 1, "", "vec_context"]], "pyop2.types.dat.DatView": [[15, 2, 1, "", "cdim"], [15, 7, 1, "", "data"], [15, 7, 1, "", "data_ro"], [15, 7, 1, "", "data_ro_with_halos"], [15, 7, 1, "", "data_with_halos"], [15, 7, 1, "", "data_wo"], [15, 7, 1, "", "data_wo_with_halos"], [15, 2, 1, "", "dim"], [15, 7, 1, "", "halo_valid"], [15, 2, 1, "", "shape"]], "pyop2.types.dat.MixedDat": [[15, 3, 1, "", "copy"], [15, 7, 1, "", "dat_version"], [15, 7, 1, "", "data"], [15, 7, 1, "", "data_ro"], [15, 7, 1, "", "data_ro_with_halos"], [15, 7, 1, "", "data_with_halos"], [15, 7, 1, "", "data_wo"], [15, 7, 1, "", "data_wo_with_halos"], [15, 2, 1, "", "dataset"], [15, 2, 1, "", "dtype"], [15, 3, 1, "", "freeze_halo"], [15, 3, 1, "", "global_to_local_begin"], [15, 3, 1, "", "global_to_local_end"], [15, 7, 1, "", "halo_valid"], [15, 3, 1, "", "increment_dat_version"], [15, 3, 1, "", "inner"], [15, 3, 1, "", "local_to_global_begin"], [15, 3, 1, "", "local_to_global_end"], [15, 2, 1, "", "nbytes"], [15, 2, 1, "", "split"], [15, 3, 1, "", "unfreeze_halo"], [15, 3, 1, "", "vec_context"], [15, 3, 1, "", "zero"]], "pyop2.types.data_carrier": [[15, 1, 1, "", "DataCarrier"], [15, 1, 1, "", "EmptyDataMixin"], [15, 1, 1, "", "VecAccessMixin"]], "pyop2.types.data_carrier.DataCarrier": [[15, 2, 1, "", "cdim"], [15, 2, 1, "", "ctype"], [15, 2, 1, "", "dim"], [15, 2, 1, "", "dtype"], [15, 3, 1, "", "increment_dat_version"], [15, 2, 1, "", "name"]], "pyop2.types.data_carrier.VecAccessMixin": [[15, 7, 1, "", "dat_version"], [15, 7, 1, "", "vec"], [15, 3, 1, "", "vec_context"], [15, 7, 1, "", "vec_ro"], [15, 7, 1, "", "vec_wo"]], "pyop2.types.dataset": [[15, 1, 1, "", "DataSet"], [15, 1, 1, "", "GlobalDataSet"], [15, 1, 1, "", "MixedDataSet"]], "pyop2.types.dataset.DataSet": [[15, 2, 1, "", "cdim"], [15, 2, 1, "", "dim"], [15, 2, 1, "", "dm"], [15, 2, 1, "", "field_ises"], [15, 2, 1, "", "layout_vec"], [15, 2, 1, "", "lgmap"], [15, 2, 1, "", "local_ises"], [15, 2, 1, "", "name"], [15, 2, 1, "", "scalar_lgmap"], [15, 2, 1, "", "set"], [15, 2, 1, "", "unblocked_lgmap"]], "pyop2.types.dataset.GlobalDataSet": [[15, 2, 1, "", "cdim"], [15, 2, 1, "", "dim"], [15, 2, 1, "", "dm"], [15, 2, 1, "", "layout_vec"], [15, 2, 1, "", "lgmap"], [15, 2, 1, "", "local_ises"], [15, 2, 1, "", "name"], [15, 2, 1, "", "set"], [15, 2, 1, "", "size"], [15, 2, 1, "", "unblocked_lgmap"]], "pyop2.types.dataset.MixedDataSet": [[15, 2, 1, "", "cdim"], [15, 2, 1, "", "dim"], [15, 2, 1, "", "layout_vec"], [15, 2, 1, "", "lgmap"], [15, 2, 1, "", "name"], [15, 2, 1, "", "set"], [15, 2, 1, "", "split"], [15, 2, 1, "", "unblocked_lgmap"]], "pyop2.types.glob": [[15, 1, 1, "", "Constant"], [15, 1, 1, "", "Global"], [15, 1, 1, "", "SetFreeDataCarrier"]], "pyop2.types.glob.Constant": [[15, 3, 1, "", "duplicate"]], "pyop2.types.glob.Global": [[15, 2, 1, "", "dataset"], [15, 3, 1, "", "duplicate"], [15, 3, 1, "", "freeze_halo"], [15, 3, 1, "", "frozen_halo"], [15, 3, 1, "", "global_to_local_begin"], [15, 3, 1, "", "global_to_local_end"], [15, 3, 1, "", "local_to_global_begin"], [15, 3, 1, "", "local_to_global_end"], [15, 3, 1, "", "unfreeze_halo"], [15, 3, 1, "", "vec_context"], [15, 3, 1, "", "zero"]], "pyop2.types.glob.SetFreeDataCarrier": [[15, 3, 1, "", "copy"], [15, 7, 1, "", "data"], [15, 7, 1, "", "data_ro"], [15, 7, 1, "", "data_ro_with_halos"], [15, 7, 1, "", "data_with_halos"], [15, 7, 1, "", "data_wo"], [15, 7, 1, "", "data_wo_with_halos"], [15, 7, 1, "", "dtype"], [15, 7, 1, "", "halo_valid"], [15, 3, 1, "", "inner"], [15, 7, 1, "", "nbytes"], [15, 7, 1, "", "shape"], [15, 7, 1, "", "split"]], "pyop2.types.halo": [[15, 1, 1, "", "Halo"]], "pyop2.types.halo.Halo": [[15, 7, 1, "", "comm"], [15, 3, 1, "", "global_to_local_begin"], [15, 3, 1, "", "global_to_local_end"], [15, 3, 1, "", "local_to_global_begin"], [15, 3, 1, "", "local_to_global_end"], [15, 7, 1, "", "local_to_global_numbering"]], "pyop2.types.map": [[15, 1, 1, "", "ComposedMap"], [15, 1, 1, "", "Map"], [15, 1, 1, "", "MixedMap"], [15, 1, 1, "", "PermutedMap"]], "pyop2.types.map.ComposedMap": [[15, 2, 1, "", "flattened_maps"], [15, 2, 1, "", "values"], [15, 2, 1, "", "values_with_halo"]], "pyop2.types.map.Map": [[15, 2, 1, "", "arange"], [15, 2, 1, "", "arities"], [15, 2, 1, "", "arity"], [15, 2, 1, "", "dtype"], [15, 2, 1, "", "flattened_maps"], [15, 2, 1, "", "iterset"], [15, 2, 1, "", "name"], [15, 2, 1, "", "offset"], [15, 2, 1, "", "offset_quotient"], [15, 2, 1, "", "split"], [15, 2, 1, "", "toset"], [15, 2, 1, "", "values"], [15, 2, 1, "", "values_with_halo"]], "pyop2.types.map.MixedMap": [[15, 2, 1, "", "arange"], [15, 2, 1, "", "arities"], [15, 2, 1, "", "arity"], [15, 2, 1, "", "flattened_maps"], [15, 2, 1, "", "iterset"], [15, 2, 1, "", "name"], [15, 2, 1, "", "offset"], [15, 2, 1, "", "offset_quotient"], [15, 2, 1, "", "split"], [15, 2, 1, "", "toset"], [15, 2, 1, "", "values"], [15, 2, 1, "", "values_with_halo"]], "pyop2.types.set": [[15, 1, 1, "", "ExtrudedSet"], [15, 1, 1, "", "GlobalSet"], [15, 1, 1, "", "MixedSet"], [15, 1, 1, "", "Set"], [15, 1, 1, "", "SetPartition"], [15, 1, 1, "", "Subset"]], "pyop2.types.set.ExtrudedSet": [[15, 2, 1, "", "layers"], [15, 2, 1, "", "layers_array"], [15, 2, 1, "", "parent"]], "pyop2.types.set.GlobalSet": [[15, 2, 1, "", "core_size"], [15, 2, 1, "", "halo"], [15, 2, 1, "", "name"], [15, 7, 1, "", "partition_size"], [15, 2, 1, "", "size"], [15, 2, 1, "", "sizes"], [15, 2, 1, "", "total_size"]], "pyop2.types.set.MixedSet": [[15, 2, 1, "", "core_size"], [15, 2, 1, "", "halo"], [15, 2, 1, "", "layers"], [15, 2, 1, "", "name"], [15, 2, 1, "", "size"], [15, 2, 1, "", "sizes"], [15, 2, 1, "", "split"], [15, 2, 1, "", "total_size"]], "pyop2.types.set.Set": [[15, 2, 1, "", "core_part"], [15, 2, 1, "", "core_size"], [15, 3, 1, "", "difference"], [15, 2, 1, "", "halo"], [15, 3, 1, "", "intersection"], [15, 2, 1, "", "layers"], [15, 2, 1, "", "name"], [15, 2, 1, "", "owned_part"], [15, 7, 1, "", "partition_size"], [15, 2, 1, "", "size"], [15, 2, 1, "", "sizes"], [15, 3, 1, "", "symmetric_difference"], [15, 2, 1, "", "total_size"], [15, 3, 1, "", "union"]], "pyop2.types.set.Subset": [[15, 3, 1, "", "difference"], [15, 2, 1, "", "indices"], [15, 3, 1, "", "intersection"], [15, 2, 1, "", "layers_array"], [15, 2, 1, "", "owned_indices"], [15, 2, 1, "", "superset"], [15, 3, 1, "", "symmetric_difference"], [15, 3, 1, "", "union"]], "pyop2.utils": [[13, 4, 1, "", "align"], [13, 4, 1, "", "as_tuple"], [13, 4, 1, "", "as_type"], [13, 1, 1, "", "cached_property"], [13, 4, 1, "", "flatten"], [13, 4, 1, "", "get_petsc_dir"], [13, 4, 1, "", "parse_args"], [13, 4, 1, "", "parser"], [13, 4, 1, "", "strip"], [13, 4, 1, "", "trim"], [13, 4, 1, "", "tuplify"], [13, 1, 1, "", "validate_base"], [13, 1, 1, "", "validate_dtype"], [13, 1, 1, "", "validate_in"], [13, 1, 1, "", "validate_range"], [13, 1, 1, "", "validate_type"], [13, 4, 1, "", "verify_reshape"]], "pyop2.utils.validate_base": [[13, 3, 1, "", "check_args"]], "pyop2.utils.validate_dtype": [[13, 3, 1, "", "check_arg"]], "pyop2.utils.validate_in": [[13, 3, 1, "", "check_arg"]], "pyop2.utils.validate_range": [[13, 3, 1, "", "check_arg"]], "pyop2.utils.validate_type": [[13, 3, 1, "", "check_arg"]]}, "objtypes": {"0": "py:module", "1": "py:class", "2": "py:attribute", "3": "py:method", "4": "py:function", "5": "py:exception", "6": "py:data", "7": "py:property"}, "objnames": {"0": ["py", "module", "Python module"], "1": ["py", "class", "Python class"], "2": ["py", "attribute", "Python attribute"], "3": ["py", "method", "Python method"], "4": ["py", "function", "Python function"], "5": ["py", "exception", "Python exception"], "6": ["py", "data", "Python data"], "7": ["py", "property", "Python property"]}, "titleterms": {"pyop2": [0, 1, 2, 3, 4, 5, 6, 7, 8, 12, 13, 14, 15, 16], "architectur": 0, "multipl": 0, "backend": [0, 1], "support": 0, "host": 1, "sequenti": 1, "openmp": 1, "devic": 1, "cuda": 1, "opencl": 1, "cach": [2, 13], "class": 2, "object": 2, "debug": 2, "leak": 2, "concept": 3, "set": [3, 9, 15], "map": [3, 9, 15], "data": [3, 7], "dat": [3, 9, 15], "global": 3, "const": 3, "mat": [3, 9, 15], "parallel": [3, 11], "loop": 3, "invoc": 3, "access": [3, 15], "descriptor": 3, "assembl": 3, "matric": 3, "reduct": 3, "welcom": 4, "": [4, 12], "document": [4, 16], "indic": 4, "tabl": 4, "content": [5, 13, 14, 15], "instal": 5, "The": 6, "intermedi": 6, "represent": [6, 14], "us": [6, 12], "achiev": 6, "perform": 6, "portabl": 6, "ir": 6, "optim": 6, "kernel": [6, 7], "cpu": 6, "how": 6, "select": 6, "specif": 6, "api": 7, "layout": 7, "local": [7, 10, 11], "iter": 7, "space": 7, "linear": 8, "algebra": 8, "interfac": 8, "spars": 8, "matrix": 8, "storag": 8, "format": 8, "assembli": [8, 9, 10], "build": 8, "sparsiti": [8, 9, 13], "pattern": 8, "solv": 8, "system": 8, "gpu": 8, "mix": 9, "type": [9, 15], "dataset": [9, 15], "block": 9, "mpi": [10, 13], "number": 10, "comput": 10, "commun": 10, "overlap": 10, "halo": [10, 15], "exchang": 10, "distribut": 10, "execut": 11, "plan": 11, "partit": 11, "renumb": 11, "stage": 11, "colour": 11, "profil": [12, 13], "program": 12, "creat": 12, "graph": 12, "consolid": 12, "from": 12, "differ": 12, "run": 12, "intern": 12, "timer": 12, "line": 12, "memori": 12, "packag": [13, 14, 15, 16], "subpackag": 13, "submodul": [13, 14, 15], "modul": [13, 14, 15], "compil": 13, "configur": 13, "datatyp": 13, "except": 13, "global_kernel": 13, "local_kernel": 13, "logger": 13, "op2": 13, "parloop": 13, "util": 13, "version": 13, "codegen": 14, "builder": 14, "loopycompat": 14, "node": 14, "optimis": 14, "rep2loopi": 14, "data_carri": 15, "glob": 15, "user": 16}, "envversion": {"sphinx.domains.c": 3, "sphinx.domains.changeset": 1, "sphinx.domains.citation": 1, "sphinx.domains.cpp": 9, "sphinx.domains.index": 1, "sphinx.domains.javascript": 3, "sphinx.domains.math": 2, "sphinx.domains.python": 4, "sphinx.domains.rst": 2, "sphinx.domains.std": 2, "sphinx.ext.todo": 2, "sphinx": 60}, "alltitles": {"PyOP2 Architecture": [[0, "pyop2-architecture"]], "Multiple Backend Support": [[0, "multiple-backend-support"]], "PyOP2 Backends": [[1, "pyop2-backends"]], "Host backends": [[1, "host-backends"]], "Sequential backend": [[1, "sequential-backend"]], "OpenMP backend": [[1, "openmp-backend"]], "Device backends": [[1, "device-backends"]], "CUDA backend": [[1, "cuda-backend"]], "OpenCL backend": [[1, "opencl-backend"]], "Caching in PyOP2": [[2, "caching-in-pyop2"]], "Class caches": [[2, "class-caches"]], "Object caches": [[2, "object-caches"]], "Debugging cache leaks": [[2, "debugging-cache-leaks"]], "PyOP2 Concepts": [[3, "pyop2-concepts"]], "Sets and mappings": [[3, "sets-and-mappings"]], "Data": [[3, "data"]], "Dat": [[3, "dat"]], "Global": [[3, "global"]], "Const": [[3, "const"]], "Mat": [[3, "mat"]], "Parallel loops": [[3, "parallel-loops"]], "Loop invocations": [[3, "loop-invocations"]], "Access descriptors": [[3, "access-descriptors"]], "Loops assembling matrices": [[3, "loops-assembling-matrices"]], "Loops with global reductions": [[3, "loops-with-global-reductions"]], "Welcome to PyOP2\u2019s documentation!": [[4, "welcome-to-pyop2-s-documentation"]], "Indices and tables": [[4, "indices-and-tables"]], "Contents": [[5, "contents"]], "Installing PyOP2": [[5, "installing-pyop2"]], "The PyOP2 Intermediate Representation": [[6, "the-pyop2-intermediate-representation"]], "Using the Intermediate Representation": [[6, "using-the-intermediate-representation"]], "Achieving Performance Portability with the IR": [[6, "achieving-performance-portability-with-the-ir"]], "Optimizing kernels on CPUs": [[6, "optimizing-kernels-on-cpus"]], "How to select specific kernel optimizations": [[6, "how-to-select-specific-kernel-optimizations"]], "PyOP2 Kernels": [[7, "pyop2-kernels"]], "Kernel API": [[7, "kernel-api"]], "Data layout": [[7, "data-layout"]], "Local iteration spaces": [[7, "local-iteration-spaces"]], "PyOP2 Linear Algebra Interface": [[8, "pyop2-linear-algebra-interface"]], "Sparse Matrix Storage Formats": [[8, "sparse-matrix-storage-formats"]], "Matrix assembly": [[8, "matrix-assembly"]], "Building a sparsity pattern": [[8, "building-a-sparsity-pattern"]], "Solving a linear system": [[8, "solving-a-linear-system"]], "GPU matrix assembly": [[8, "gpu-matrix-assembly"]], "GPU linear algebra": [[8, "gpu-linear-algebra"]], "Mixed Types": [[9, "mixed-types"]], "Mixed Set, DataSet, Map and Dat": [[9, "mixed-set-dataset-map-and-dat"]], "Block Sparsity and Mat": [[9, "block-sparsity-and-mat"]], "Mixed Assembly": [[9, "mixed-assembly"]], "MPI": [[10, "mpi"]], "Local Numbering": [[10, "local-numbering"]], "Computation-communication Overlap": [[10, "computation-communication-overlap"]], "Halo exchange": [[10, "halo-exchange"]], "Distributed Assembly": [[10, "distributed-assembly"]], "Parallel Execution Plan": [[11, "parallel-execution-plan"]], "Partitioning": [[11, "partitioning"]], "Local Renumbering and Staging": [[11, "local-renumbering-and-staging"]], "Colouring": [[11, "colouring"]], "Profiling": [[12, "profiling"]], "Profiling PyOP2 programs": [[12, "profiling-pyop2-programs"]], "Creating a graph": [[12, "creating-a-graph"]], "Consolidating profiles from different runs": [[12, "consolidating-profiles-from-different-runs"]], "Using PyOP2\u2019s internal timers": [[12, "using-pyop2-s-internal-timers"]], "Line-by-line profiling": [[12, "line-by-line-profiling"]], "Memory profiling": [[12, "memory-profiling"]], "pyop2 package": [[13, "pyop2-package"]], "Subpackages": [[13, "subpackages"]], "Submodules": [[13, "submodules"], [14, "submodules"], [15, "submodules"]], "pyop2.caching module": [[13, "pyop2-caching-module"]], "pyop2.compilation module": [[13, "pyop2-compilation-module"]], "pyop2.configuration module": [[13, "module-pyop2.configuration"]], "pyop2.datatypes module": [[13, "module-pyop2.datatypes"]], "pyop2.exceptions module": [[13, "module-pyop2.exceptions"]], "pyop2.global_kernel module": [[13, "pyop2-global-kernel-module"]], "pyop2.local_kernel module": [[13, "pyop2-local-kernel-module"]], "pyop2.logger module": [[13, "module-pyop2.logger"]], "pyop2.mpi module": [[13, "module-pyop2.mpi"]], "pyop2.op2 module": [[13, "pyop2-op2-module"]], "pyop2.parloop module": [[13, "pyop2-parloop-module"]], "pyop2.profiling module": [[13, "module-pyop2.profiling"]], "pyop2.sparsity module": [[13, "pyop2-sparsity-module"]], "pyop2.utils module": [[13, "module-pyop2.utils"]], "pyop2.version module": [[13, "pyop2-version-module"]], "Module contents": [[13, "module-contents"], [14, "module-contents"], [15, "module-contents"]], "pyop2.codegen package": [[14, "pyop2-codegen-package"]], "pyop2.codegen.builder module": [[14, "pyop2-codegen-builder-module"]], "pyop2.codegen.loopycompat module": [[14, "pyop2-codegen-loopycompat-module"]], "pyop2.codegen.node module": [[14, "pyop2-codegen-node-module"]], "pyop2.codegen.optimise module": [[14, "pyop2-codegen-optimise-module"]], "pyop2.codegen.rep2loopy module": [[14, "pyop2-codegen-rep2loopy-module"]], "pyop2.codegen.representation module": [[14, "pyop2-codegen-representation-module"]], "pyop2.types package": [[15, "pyop2-types-package"]], "pyop2.types.access module": [[15, "module-pyop2.types.access"]], "pyop2.types.dat module": [[15, "module-pyop2.types.dat"]], "pyop2.types.data_carrier module": [[15, "module-pyop2.types.data_carrier"]], "pyop2.types.dataset module": [[15, "module-pyop2.types.dataset"]], "pyop2.types.glob module": [[15, "module-pyop2.types.glob"]], "pyop2.types.halo module": [[15, "module-pyop2.types.halo"]], "pyop2.types.map module": [[15, "module-pyop2.types.map"]], "pyop2.types.mat module": [[15, "pyop2-types-mat-module"]], "pyop2.types.set module": [[15, "module-pyop2.types.set"]], "pyop2 user documentation": [[16, "pyop2-user-documentation"]], "pyop2 Package": [[16, "pyop2-package"]]}, "indexentries": {"aritytypeerror": [[13, "pyop2.exceptions.ArityTypeError"]], "compilationerror": [[13, "pyop2.exceptions.CompilationError"]], "configuration (class in pyop2.configuration)": [[13, "pyop2.configuration.Configuration"]], "configurationerror": [[13, "pyop2.exceptions.ConfigurationError"]], "defaults (pyop2.configuration.configuration attribute)": [[13, "pyop2.configuration.Configuration.DEFAULTS"]], "dattypeerror": [[13, "pyop2.exceptions.DatTypeError"]], "datasettypeerror": [[13, "pyop2.exceptions.DataSetTypeError"]], "datatypeerror": [[13, "pyop2.exceptions.DataTypeError"]], "datavalueerror": [[13, "pyop2.exceptions.DataValueError"]], "dimtypeerror": [[13, "pyop2.exceptions.DimTypeError"]], "indextypeerror": [[13, "pyop2.exceptions.IndexTypeError"]], "indexvalueerror": [[13, "pyop2.exceptions.IndexValueError"]], "iteratevalueerror": [[13, "pyop2.exceptions.IterateValueError"]], "kerneltypeerror": [[13, "pyop2.exceptions.KernelTypeError"]], "maptypeerror": [[13, "pyop2.exceptions.MapTypeError"]], "mapvalueerror": [[13, "pyop2.exceptions.MapValueError"]], "mattypeerror": [[13, "pyop2.exceptions.MatTypeError"]], "modevalueerror": [[13, "pyop2.exceptions.ModeValueError"]], "nametypeerror": [[13, "pyop2.exceptions.NameTypeError"]], "settypeerror": [[13, "pyop2.exceptions.SetTypeError"]], "setvalueerror": [[13, "pyop2.exceptions.SetValueError"]], "sizetypeerror": [[13, "pyop2.exceptions.SizeTypeError"]], "sparsityformaterror": [[13, "pyop2.exceptions.SparsityFormatError"]], "sparsitytypeerror": [[13, "pyop2.exceptions.SparsityTypeError"]], "subsetindexoutofbounds": [[13, "pyop2.exceptions.SubsetIndexOutOfBounds"]], "align() (in module pyop2.utils)": [[13, "pyop2.utils.align"]], "as_cstr() (in module pyop2.datatypes)": [[13, "pyop2.datatypes.as_cstr"]], "as_ctypes() (in module pyop2.datatypes)": [[13, "pyop2.datatypes.as_ctypes"]], "as_numpy_dtype() (in module pyop2.datatypes)": [[13, "pyop2.datatypes.as_numpy_dtype"]], "as_tuple() (in module pyop2.utils)": [[13, "pyop2.utils.as_tuple"]], "as_type() (in module pyop2.utils)": [[13, "pyop2.utils.as_type"]], "cache_dir (pyop2.configuration.configuration attribute)": [[13, "pyop2.configuration.Configuration.cache_dir"]], "cached_property (class in pyop2.utils)": [[13, "pyop2.utils.cached_property"]], "check_arg() (pyop2.utils.validate_dtype method)": [[13, "pyop2.utils.validate_dtype.check_arg"]], "check_arg() (pyop2.utils.validate_in method)": [[13, "pyop2.utils.validate_in.check_arg"]], "check_arg() (pyop2.utils.validate_range method)": [[13, "pyop2.utils.validate_range.check_arg"]], "check_arg() (pyop2.utils.validate_type method)": [[13, "pyop2.utils.validate_type.check_arg"]], "check_args() (pyop2.utils.validate_base method)": [[13, "pyop2.utils.validate_base.check_args"]], "decref() (in module pyop2.mpi)": [[13, "pyop2.mpi.decref"]], "dtype_limits() (in module pyop2.datatypes)": [[13, "pyop2.datatypes.dtype_limits"]], "flatten() (in module pyop2.utils)": [[13, "pyop2.utils.flatten"]], "get_petsc_dir() (in module pyop2.utils)": [[13, "pyop2.utils.get_petsc_dir"]], "incref() (in module pyop2.mpi)": [[13, "pyop2.mpi.incref"]], "internal_comm() (in module pyop2.mpi)": [[13, "pyop2.mpi.internal_comm"]], "is_pyop2_comm() (in module pyop2.mpi)": [[13, "pyop2.mpi.is_pyop2_comm"]], "log() (in module pyop2.logger)": [[13, "pyop2.logger.log"]], "module": [[13, "module-pyop2.configuration"], [13, "module-pyop2.datatypes"], [13, "module-pyop2.exceptions"], [13, "module-pyop2.logger"], [13, "module-pyop2.mpi"], [13, "module-pyop2.profiling"], [13, "module-pyop2.utils"], [15, "module-pyop2.types.access"], [15, "module-pyop2.types.dat"], [15, "module-pyop2.types.data_carrier"], [15, "module-pyop2.types.dataset"], [15, "module-pyop2.types.glob"], [15, "module-pyop2.types.halo"], [15, "module-pyop2.types.map"], [15, "module-pyop2.types.set"]], "parse_args() (in module pyop2.utils)": [[13, "pyop2.utils.parse_args"]], "parser() (in module pyop2.utils)": [[13, "pyop2.utils.parser"]], "progress() (in module pyop2.logger)": [[13, "pyop2.logger.progress"]], "pyop2.configuration": [[13, "module-pyop2.configuration"]], "pyop2.datatypes": [[13, "module-pyop2.datatypes"]], "pyop2.exceptions": [[13, "module-pyop2.exceptions"]], "pyop2.logger": [[13, "module-pyop2.logger"]], "pyop2.mpi": [[13, "module-pyop2.mpi"]], "pyop2.profiling": [[13, "module-pyop2.profiling"]], "pyop2.utils": [[13, "module-pyop2.utils"]], "reconfigure() (pyop2.configuration.configuration method)": [[13, "pyop2.configuration.Configuration.reconfigure"]], "reset() (pyop2.configuration.configuration method)": [[13, "pyop2.configuration.Configuration.reset"]], "set_log_level() (in module pyop2.logger)": [[13, "pyop2.logger.set_log_level"]], "strip() (in module pyop2.utils)": [[13, "pyop2.utils.strip"]], "temp_internal_comm (class in pyop2.mpi)": [[13, "pyop2.mpi.temp_internal_comm"]], "timed_function (class in pyop2.profiling)": [[13, "pyop2.profiling.timed_function"]], "timed_region() (in module pyop2.profiling)": [[13, "pyop2.profiling.timed_region"]], "timed_stage() (in module pyop2.profiling)": [[13, "pyop2.profiling.timed_stage"]], "trim() (in module pyop2.utils)": [[13, "pyop2.utils.trim"]], "tuplify() (in module pyop2.utils)": [[13, "pyop2.utils.tuplify"]], "unsafe_reconfigure() (pyop2.configuration.configuration method)": [[13, "pyop2.configuration.Configuration.unsafe_reconfigure"]], "validate_base (class in pyop2.utils)": [[13, "pyop2.utils.validate_base"]], "validate_dtype (class in pyop2.utils)": [[13, "pyop2.utils.validate_dtype"]], "validate_in (class in pyop2.utils)": [[13, "pyop2.utils.validate_in"]], "validate_range (class in pyop2.utils)": [[13, "pyop2.utils.validate_range"]], "validate_type (class in pyop2.utils)": [[13, "pyop2.utils.validate_type"]], "verify_reshape() (in module pyop2.utils)": [[13, "pyop2.utils.verify_reshape"]], "abstractdat (class in pyop2.types.dat)": [[15, "pyop2.types.dat.AbstractDat"]], "access (class in pyop2.types.access)": [[15, "pyop2.types.access.Access"]], "composedmap (class in pyop2.types.map)": [[15, "pyop2.types.map.ComposedMap"]], "constant (class in pyop2.types.glob)": [[15, "pyop2.types.glob.Constant"]], "dat (class in pyop2.types.dat)": [[15, "pyop2.types.dat.Dat"]], "datview (class in pyop2.types.dat)": [[15, "pyop2.types.dat.DatView"]], "datacarrier (class in pyop2.types.data_carrier)": [[15, "pyop2.types.data_carrier.DataCarrier"]], "dataset (class in pyop2.types.dataset)": [[15, "pyop2.types.dataset.DataSet"]], "emptydatamixin (class in pyop2.types.data_carrier)": [[15, "pyop2.types.data_carrier.EmptyDataMixin"]], "extrudedset (class in pyop2.types.set)": [[15, "pyop2.types.set.ExtrudedSet"]], "global (class in pyop2.types.glob)": [[15, "pyop2.types.glob.Global"]], "globaldataset (class in pyop2.types.dataset)": [[15, "pyop2.types.dataset.GlobalDataSet"]], "globalset (class in pyop2.types.set)": [[15, "pyop2.types.set.GlobalSet"]], "halo (class in pyop2.types.halo)": [[15, "pyop2.types.halo.Halo"]], "inc (in module pyop2.types.access)": [[15, "pyop2.types.access.INC"]], "inc (pyop2.types.access.access attribute)": [[15, "pyop2.types.access.Access.INC"]], "max (in module pyop2.types.access)": [[15, "pyop2.types.access.MAX"]], "max (pyop2.types.access.access attribute)": [[15, "pyop2.types.access.Access.MAX"]], "min (in module pyop2.types.access)": [[15, "pyop2.types.access.MIN"]], "min (pyop2.types.access.access attribute)": [[15, "pyop2.types.access.Access.MIN"]], "map (class in pyop2.types.map)": [[15, "pyop2.types.map.Map"]], "mixeddat (class in pyop2.types.dat)": [[15, "pyop2.types.dat.MixedDat"]], "mixeddataset (class in pyop2.types.dataset)": [[15, "pyop2.types.dataset.MixedDataSet"]], "mixedmap (class in pyop2.types.map)": [[15, "pyop2.types.map.MixedMap"]], "mixedset (class in pyop2.types.set)": [[15, "pyop2.types.set.MixedSet"]], "permutedmap (class in pyop2.types.map)": [[15, "pyop2.types.map.PermutedMap"]], "read (in module pyop2.types.access)": [[15, "pyop2.types.access.READ"]], "read (pyop2.types.access.access attribute)": [[15, "pyop2.types.access.Access.READ"]], "rw (in module pyop2.types.access)": [[15, "pyop2.types.access.RW"]], "rw (pyop2.types.access.access attribute)": [[15, "pyop2.types.access.Access.RW"]], "set (class in pyop2.types.set)": [[15, "pyop2.types.set.Set"]], "setfreedatacarrier (class in pyop2.types.glob)": [[15, "pyop2.types.glob.SetFreeDataCarrier"]], "setpartition (class in pyop2.types.set)": [[15, "pyop2.types.set.SetPartition"]], "subset (class in pyop2.types.set)": [[15, "pyop2.types.set.Subset"]], "vecaccessmixin (class in pyop2.types.data_carrier)": [[15, "pyop2.types.data_carrier.VecAccessMixin"]], "write (in module pyop2.types.access)": [[15, "pyop2.types.access.WRITE"]], "write (pyop2.types.access.access attribute)": [[15, "pyop2.types.access.Access.WRITE"]], "arange (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.arange"]], "arange (pyop2.types.map.mixedmap attribute)": [[15, "pyop2.types.map.MixedMap.arange"]], "arities (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.arities"]], "arities (pyop2.types.map.mixedmap attribute)": [[15, "pyop2.types.map.MixedMap.arities"]], "arity (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.arity"]], "arity (pyop2.types.map.mixedmap attribute)": [[15, "pyop2.types.map.MixedMap.arity"]], "cdim (pyop2.types.dat.abstractdat attribute)": [[15, "pyop2.types.dat.AbstractDat.cdim"]], "cdim (pyop2.types.dat.datview attribute)": [[15, "pyop2.types.dat.DatView.cdim"]], "cdim (pyop2.types.data_carrier.datacarrier attribute)": [[15, "pyop2.types.data_carrier.DataCarrier.cdim"]], "cdim (pyop2.types.dataset.dataset attribute)": [[15, "pyop2.types.dataset.DataSet.cdim"]], "cdim (pyop2.types.dataset.globaldataset attribute)": [[15, "pyop2.types.dataset.GlobalDataSet.cdim"]], "cdim (pyop2.types.dataset.mixeddataset attribute)": [[15, "pyop2.types.dataset.MixedDataSet.cdim"]], "comm (pyop2.types.halo.halo property)": [[15, "pyop2.types.halo.Halo.comm"]], "copy() (pyop2.types.dat.abstractdat method)": [[15, "pyop2.types.dat.AbstractDat.copy"]], "copy() (pyop2.types.dat.mixeddat method)": [[15, "pyop2.types.dat.MixedDat.copy"]], "copy() (pyop2.types.glob.setfreedatacarrier method)": [[15, "pyop2.types.glob.SetFreeDataCarrier.copy"]], "core_part (pyop2.types.set.set attribute)": [[15, "pyop2.types.set.Set.core_part"]], "core_size (pyop2.types.set.globalset attribute)": [[15, "pyop2.types.set.GlobalSet.core_size"]], "core_size (pyop2.types.set.mixedset attribute)": [[15, "pyop2.types.set.MixedSet.core_size"]], "core_size (pyop2.types.set.set attribute)": [[15, "pyop2.types.set.Set.core_size"]], "ctype (pyop2.types.data_carrier.datacarrier attribute)": [[15, "pyop2.types.data_carrier.DataCarrier.ctype"]], "dat_version (pyop2.types.dat.mixeddat property)": [[15, "pyop2.types.dat.MixedDat.dat_version"]], "dat_version (pyop2.types.data_carrier.vecaccessmixin property)": [[15, "pyop2.types.data_carrier.VecAccessMixin.dat_version"]], "data (pyop2.types.dat.abstractdat property)": [[15, "pyop2.types.dat.AbstractDat.data"]], "data (pyop2.types.dat.datview property)": [[15, "pyop2.types.dat.DatView.data"]], "data (pyop2.types.dat.mixeddat property)": [[15, "pyop2.types.dat.MixedDat.data"]], "data (pyop2.types.glob.setfreedatacarrier property)": [[15, "pyop2.types.glob.SetFreeDataCarrier.data"]], "data_ro (pyop2.types.dat.abstractdat property)": [[15, "pyop2.types.dat.AbstractDat.data_ro"]], "data_ro (pyop2.types.dat.datview property)": [[15, "pyop2.types.dat.DatView.data_ro"]], "data_ro (pyop2.types.dat.mixeddat property)": [[15, "pyop2.types.dat.MixedDat.data_ro"]], "data_ro (pyop2.types.glob.setfreedatacarrier property)": [[15, "pyop2.types.glob.SetFreeDataCarrier.data_ro"]], "data_ro_with_halos (pyop2.types.dat.abstractdat property)": [[15, "pyop2.types.dat.AbstractDat.data_ro_with_halos"]], "data_ro_with_halos (pyop2.types.dat.datview property)": [[15, "pyop2.types.dat.DatView.data_ro_with_halos"]], "data_ro_with_halos (pyop2.types.dat.mixeddat property)": [[15, "pyop2.types.dat.MixedDat.data_ro_with_halos"]], "data_ro_with_halos (pyop2.types.glob.setfreedatacarrier property)": [[15, "pyop2.types.glob.SetFreeDataCarrier.data_ro_with_halos"]], "data_with_halos (pyop2.types.dat.abstractdat property)": [[15, "pyop2.types.dat.AbstractDat.data_with_halos"]], "data_with_halos (pyop2.types.dat.datview property)": [[15, "pyop2.types.dat.DatView.data_with_halos"]], "data_with_halos (pyop2.types.dat.mixeddat property)": [[15, "pyop2.types.dat.MixedDat.data_with_halos"]], "data_with_halos (pyop2.types.glob.setfreedatacarrier property)": [[15, "pyop2.types.glob.SetFreeDataCarrier.data_with_halos"]], "data_wo (pyop2.types.dat.abstractdat property)": [[15, "pyop2.types.dat.AbstractDat.data_wo"]], "data_wo (pyop2.types.dat.datview property)": [[15, "pyop2.types.dat.DatView.data_wo"]], "data_wo (pyop2.types.dat.mixeddat property)": [[15, "pyop2.types.dat.MixedDat.data_wo"]], "data_wo (pyop2.types.glob.setfreedatacarrier property)": [[15, "pyop2.types.glob.SetFreeDataCarrier.data_wo"]], "data_wo_with_halos (pyop2.types.dat.abstractdat property)": [[15, "pyop2.types.dat.AbstractDat.data_wo_with_halos"]], "data_wo_with_halos (pyop2.types.dat.datview property)": [[15, "pyop2.types.dat.DatView.data_wo_with_halos"]], "data_wo_with_halos (pyop2.types.dat.mixeddat property)": [[15, "pyop2.types.dat.MixedDat.data_wo_with_halos"]], "data_wo_with_halos (pyop2.types.glob.setfreedatacarrier property)": [[15, "pyop2.types.glob.SetFreeDataCarrier.data_wo_with_halos"]], "dataset (pyop2.types.dat.abstractdat attribute)": [[15, "pyop2.types.dat.AbstractDat.dataset"]], "dataset (pyop2.types.dat.mixeddat attribute)": [[15, "pyop2.types.dat.MixedDat.dataset"]], "dataset (pyop2.types.glob.global attribute)": [[15, "pyop2.types.glob.Global.dataset"]], "difference() (pyop2.types.set.set method)": [[15, "pyop2.types.set.Set.difference"]], "difference() (pyop2.types.set.subset method)": [[15, "pyop2.types.set.Subset.difference"]], "dim (pyop2.types.dat.abstractdat attribute)": [[15, "pyop2.types.dat.AbstractDat.dim"]], "dim (pyop2.types.dat.datview attribute)": [[15, "pyop2.types.dat.DatView.dim"]], "dim (pyop2.types.data_carrier.datacarrier attribute)": [[15, "pyop2.types.data_carrier.DataCarrier.dim"]], "dim (pyop2.types.dataset.dataset attribute)": [[15, "pyop2.types.dataset.DataSet.dim"]], "dim (pyop2.types.dataset.globaldataset attribute)": [[15, "pyop2.types.dataset.GlobalDataSet.dim"]], "dim (pyop2.types.dataset.mixeddataset attribute)": [[15, "pyop2.types.dataset.MixedDataSet.dim"]], "dm (pyop2.types.dataset.dataset attribute)": [[15, "pyop2.types.dataset.DataSet.dm"]], "dm (pyop2.types.dataset.globaldataset attribute)": [[15, "pyop2.types.dataset.GlobalDataSet.dm"]], "dtype (pyop2.types.dat.abstractdat attribute)": [[15, "pyop2.types.dat.AbstractDat.dtype"]], "dtype (pyop2.types.dat.mixeddat attribute)": [[15, "pyop2.types.dat.MixedDat.dtype"]], "dtype (pyop2.types.data_carrier.datacarrier attribute)": [[15, "pyop2.types.data_carrier.DataCarrier.dtype"]], "dtype (pyop2.types.glob.setfreedatacarrier property)": [[15, "pyop2.types.glob.SetFreeDataCarrier.dtype"]], "dtype (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.dtype"]], "duplicate() (pyop2.types.glob.constant method)": [[15, "pyop2.types.glob.Constant.duplicate"]], "duplicate() (pyop2.types.glob.global method)": [[15, "pyop2.types.glob.Global.duplicate"]], "field_ises (pyop2.types.dataset.dataset attribute)": [[15, "pyop2.types.dataset.DataSet.field_ises"]], "flattened_maps (pyop2.types.map.composedmap attribute)": [[15, "pyop2.types.map.ComposedMap.flattened_maps"]], "flattened_maps (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.flattened_maps"]], "flattened_maps (pyop2.types.map.mixedmap attribute)": [[15, "pyop2.types.map.MixedMap.flattened_maps"]], "freeze_halo() (pyop2.types.dat.abstractdat method)": [[15, "pyop2.types.dat.AbstractDat.freeze_halo"]], "freeze_halo() (pyop2.types.dat.mixeddat method)": [[15, "pyop2.types.dat.MixedDat.freeze_halo"]], "freeze_halo() (pyop2.types.glob.global method)": [[15, "pyop2.types.glob.Global.freeze_halo"]], "frozen_halo (class in pyop2.types.dat)": [[15, "pyop2.types.dat.frozen_halo"]], "frozen_halo() (pyop2.types.dat.abstractdat method)": [[15, "pyop2.types.dat.AbstractDat.frozen_halo"]], "frozen_halo() (pyop2.types.glob.global method)": [[15, "pyop2.types.glob.Global.frozen_halo"]], "global_to_local_begin() (pyop2.types.dat.abstractdat method)": [[15, "pyop2.types.dat.AbstractDat.global_to_local_begin"]], "global_to_local_begin() (pyop2.types.dat.mixeddat method)": [[15, "pyop2.types.dat.MixedDat.global_to_local_begin"]], "global_to_local_begin() (pyop2.types.glob.global method)": [[15, "pyop2.types.glob.Global.global_to_local_begin"]], "global_to_local_begin() (pyop2.types.halo.halo method)": [[15, "pyop2.types.halo.Halo.global_to_local_begin"]], "global_to_local_end() (pyop2.types.dat.abstractdat method)": [[15, "pyop2.types.dat.AbstractDat.global_to_local_end"]], "global_to_local_end() (pyop2.types.dat.mixeddat method)": [[15, "pyop2.types.dat.MixedDat.global_to_local_end"]], "global_to_local_end() (pyop2.types.glob.global method)": [[15, "pyop2.types.glob.Global.global_to_local_end"]], "global_to_local_end() (pyop2.types.halo.halo method)": [[15, "pyop2.types.halo.Halo.global_to_local_end"]], "halo (pyop2.types.set.globalset attribute)": [[15, "pyop2.types.set.GlobalSet.halo"]], "halo (pyop2.types.set.mixedset attribute)": [[15, "pyop2.types.set.MixedSet.halo"]], "halo (pyop2.types.set.set attribute)": [[15, "pyop2.types.set.Set.halo"]], "halo_valid (pyop2.types.dat.datview property)": [[15, "pyop2.types.dat.DatView.halo_valid"]], "halo_valid (pyop2.types.dat.mixeddat property)": [[15, "pyop2.types.dat.MixedDat.halo_valid"]], "halo_valid (pyop2.types.glob.setfreedatacarrier property)": [[15, "pyop2.types.glob.SetFreeDataCarrier.halo_valid"]], "increment_dat_version() (pyop2.types.dat.mixeddat method)": [[15, "pyop2.types.dat.MixedDat.increment_dat_version"]], "increment_dat_version() (pyop2.types.data_carrier.datacarrier method)": [[15, "pyop2.types.data_carrier.DataCarrier.increment_dat_version"]], "indices (pyop2.types.set.subset attribute)": [[15, "pyop2.types.set.Subset.indices"]], "inner() (pyop2.types.dat.abstractdat method)": [[15, "pyop2.types.dat.AbstractDat.inner"]], "inner() (pyop2.types.dat.mixeddat method)": [[15, "pyop2.types.dat.MixedDat.inner"]], "inner() (pyop2.types.glob.setfreedatacarrier method)": [[15, "pyop2.types.glob.SetFreeDataCarrier.inner"]], "intersection() (pyop2.types.set.set method)": [[15, "pyop2.types.set.Set.intersection"]], "intersection() (pyop2.types.set.subset method)": [[15, "pyop2.types.set.Subset.intersection"]], "iterset (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.iterset"]], "iterset (pyop2.types.map.mixedmap attribute)": [[15, "pyop2.types.map.MixedMap.iterset"]], "layers (pyop2.types.set.extrudedset attribute)": [[15, "pyop2.types.set.ExtrudedSet.layers"]], "layers (pyop2.types.set.mixedset attribute)": [[15, "pyop2.types.set.MixedSet.layers"]], "layers (pyop2.types.set.set attribute)": [[15, "pyop2.types.set.Set.layers"]], "layers_array (pyop2.types.set.extrudedset attribute)": [[15, "pyop2.types.set.ExtrudedSet.layers_array"]], "layers_array (pyop2.types.set.subset attribute)": [[15, "pyop2.types.set.Subset.layers_array"]], "layout_vec (pyop2.types.dataset.dataset attribute)": [[15, "pyop2.types.dataset.DataSet.layout_vec"]], "layout_vec (pyop2.types.dataset.globaldataset attribute)": [[15, "pyop2.types.dataset.GlobalDataSet.layout_vec"]], "layout_vec (pyop2.types.dataset.mixeddataset attribute)": [[15, "pyop2.types.dataset.MixedDataSet.layout_vec"]], "lgmap (pyop2.types.dataset.dataset attribute)": [[15, "pyop2.types.dataset.DataSet.lgmap"]], "lgmap (pyop2.types.dataset.globaldataset attribute)": [[15, "pyop2.types.dataset.GlobalDataSet.lgmap"]], "lgmap (pyop2.types.dataset.mixeddataset attribute)": [[15, "pyop2.types.dataset.MixedDataSet.lgmap"]], "load() (pyop2.types.dat.abstractdat method)": [[15, "pyop2.types.dat.AbstractDat.load"]], "local_ises (pyop2.types.dataset.dataset attribute)": [[15, "pyop2.types.dataset.DataSet.local_ises"]], "local_ises (pyop2.types.dataset.globaldataset attribute)": [[15, "pyop2.types.dataset.GlobalDataSet.local_ises"]], "local_to_global_begin() (pyop2.types.dat.abstractdat method)": [[15, "pyop2.types.dat.AbstractDat.local_to_global_begin"]], "local_to_global_begin() (pyop2.types.dat.mixeddat method)": [[15, "pyop2.types.dat.MixedDat.local_to_global_begin"]], "local_to_global_begin() (pyop2.types.glob.global method)": [[15, "pyop2.types.glob.Global.local_to_global_begin"]], "local_to_global_begin() (pyop2.types.halo.halo method)": [[15, "pyop2.types.halo.Halo.local_to_global_begin"]], "local_to_global_end() (pyop2.types.dat.abstractdat method)": [[15, "pyop2.types.dat.AbstractDat.local_to_global_end"]], "local_to_global_end() (pyop2.types.dat.mixeddat method)": [[15, "pyop2.types.dat.MixedDat.local_to_global_end"]], "local_to_global_end() (pyop2.types.glob.global method)": [[15, "pyop2.types.glob.Global.local_to_global_end"]], "local_to_global_end() (pyop2.types.halo.halo method)": [[15, "pyop2.types.halo.Halo.local_to_global_end"]], "local_to_global_numbering (pyop2.types.halo.halo property)": [[15, "pyop2.types.halo.Halo.local_to_global_numbering"]], "name (pyop2.types.data_carrier.datacarrier attribute)": [[15, "pyop2.types.data_carrier.DataCarrier.name"]], "name (pyop2.types.dataset.dataset attribute)": [[15, "pyop2.types.dataset.DataSet.name"]], "name (pyop2.types.dataset.globaldataset attribute)": [[15, "pyop2.types.dataset.GlobalDataSet.name"]], "name (pyop2.types.dataset.mixeddataset attribute)": [[15, "pyop2.types.dataset.MixedDataSet.name"]], "name (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.name"]], "name (pyop2.types.map.mixedmap attribute)": [[15, "pyop2.types.map.MixedMap.name"]], "name (pyop2.types.set.globalset attribute)": [[15, "pyop2.types.set.GlobalSet.name"]], "name (pyop2.types.set.mixedset attribute)": [[15, "pyop2.types.set.MixedSet.name"]], "name (pyop2.types.set.set attribute)": [[15, "pyop2.types.set.Set.name"]], "nbytes (pyop2.types.dat.abstractdat attribute)": [[15, "pyop2.types.dat.AbstractDat.nbytes"]], "nbytes (pyop2.types.dat.mixeddat attribute)": [[15, "pyop2.types.dat.MixedDat.nbytes"]], "nbytes (pyop2.types.glob.setfreedatacarrier property)": [[15, "pyop2.types.glob.SetFreeDataCarrier.nbytes"]], "norm (pyop2.types.dat.abstractdat property)": [[15, "pyop2.types.dat.AbstractDat.norm"]], "offset (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.offset"]], "offset (pyop2.types.map.mixedmap attribute)": [[15, "pyop2.types.map.MixedMap.offset"]], "offset_quotient (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.offset_quotient"]], "offset_quotient (pyop2.types.map.mixedmap attribute)": [[15, "pyop2.types.map.MixedMap.offset_quotient"]], "owned_indices (pyop2.types.set.subset attribute)": [[15, "pyop2.types.set.Subset.owned_indices"]], "owned_part (pyop2.types.set.set attribute)": [[15, "pyop2.types.set.Set.owned_part"]], "parent (pyop2.types.set.extrudedset attribute)": [[15, "pyop2.types.set.ExtrudedSet.parent"]], "partition_size (pyop2.types.set.globalset property)": [[15, "pyop2.types.set.GlobalSet.partition_size"]], "partition_size (pyop2.types.set.set property)": [[15, "pyop2.types.set.Set.partition_size"]], "pyop2.types.access": [[15, "module-pyop2.types.access"]], "pyop2.types.dat": [[15, "module-pyop2.types.dat"]], "pyop2.types.data_carrier": [[15, "module-pyop2.types.data_carrier"]], "pyop2.types.dataset": [[15, "module-pyop2.types.dataset"]], "pyop2.types.glob": [[15, "module-pyop2.types.glob"]], "pyop2.types.halo": [[15, "module-pyop2.types.halo"]], "pyop2.types.map": [[15, "module-pyop2.types.map"]], "pyop2.types.set": [[15, "module-pyop2.types.set"]], "save() (pyop2.types.dat.abstractdat method)": [[15, "pyop2.types.dat.AbstractDat.save"]], "scalar_lgmap (pyop2.types.dataset.dataset attribute)": [[15, "pyop2.types.dataset.DataSet.scalar_lgmap"]], "set (pyop2.types.dataset.dataset attribute)": [[15, "pyop2.types.dataset.DataSet.set"]], "set (pyop2.types.dataset.globaldataset attribute)": [[15, "pyop2.types.dataset.GlobalDataSet.set"]], "set (pyop2.types.dataset.mixeddataset attribute)": [[15, "pyop2.types.dataset.MixedDataSet.set"]], "shape (pyop2.types.dat.abstractdat attribute)": [[15, "pyop2.types.dat.AbstractDat.shape"]], "shape (pyop2.types.dat.datview attribute)": [[15, "pyop2.types.dat.DatView.shape"]], "shape (pyop2.types.glob.setfreedatacarrier property)": [[15, "pyop2.types.glob.SetFreeDataCarrier.shape"]], "size (pyop2.types.dataset.globaldataset attribute)": [[15, "pyop2.types.dataset.GlobalDataSet.size"]], "size (pyop2.types.set.globalset attribute)": [[15, "pyop2.types.set.GlobalSet.size"]], "size (pyop2.types.set.mixedset attribute)": [[15, "pyop2.types.set.MixedSet.size"]], "size (pyop2.types.set.set attribute)": [[15, "pyop2.types.set.Set.size"]], "sizes (pyop2.types.set.globalset attribute)": [[15, "pyop2.types.set.GlobalSet.sizes"]], "sizes (pyop2.types.set.mixedset attribute)": [[15, "pyop2.types.set.MixedSet.sizes"]], "sizes (pyop2.types.set.set attribute)": [[15, "pyop2.types.set.Set.sizes"]], "split (pyop2.types.dat.abstractdat attribute)": [[15, "pyop2.types.dat.AbstractDat.split"]], "split (pyop2.types.dat.mixeddat attribute)": [[15, "pyop2.types.dat.MixedDat.split"]], "split (pyop2.types.dataset.mixeddataset attribute)": [[15, "pyop2.types.dataset.MixedDataSet.split"]], "split (pyop2.types.glob.setfreedatacarrier property)": [[15, "pyop2.types.glob.SetFreeDataCarrier.split"]], "split (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.split"]], "split (pyop2.types.map.mixedmap attribute)": [[15, "pyop2.types.map.MixedMap.split"]], "split (pyop2.types.set.mixedset attribute)": [[15, "pyop2.types.set.MixedSet.split"]], "superset (pyop2.types.set.subset attribute)": [[15, "pyop2.types.set.Subset.superset"]], "symmetric_difference() (pyop2.types.set.set method)": [[15, "pyop2.types.set.Set.symmetric_difference"]], "symmetric_difference() (pyop2.types.set.subset method)": [[15, "pyop2.types.set.Subset.symmetric_difference"]], "toset (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.toset"]], "toset (pyop2.types.map.mixedmap attribute)": [[15, "pyop2.types.map.MixedMap.toset"]], "total_size (pyop2.types.set.globalset attribute)": [[15, "pyop2.types.set.GlobalSet.total_size"]], "total_size (pyop2.types.set.mixedset attribute)": [[15, "pyop2.types.set.MixedSet.total_size"]], "total_size (pyop2.types.set.set attribute)": [[15, "pyop2.types.set.Set.total_size"]], "unblocked_lgmap (pyop2.types.dataset.dataset attribute)": [[15, "pyop2.types.dataset.DataSet.unblocked_lgmap"]], "unblocked_lgmap (pyop2.types.dataset.globaldataset attribute)": [[15, "pyop2.types.dataset.GlobalDataSet.unblocked_lgmap"]], "unblocked_lgmap (pyop2.types.dataset.mixeddataset attribute)": [[15, "pyop2.types.dataset.MixedDataSet.unblocked_lgmap"]], "unfreeze_halo() (pyop2.types.dat.abstractdat method)": [[15, "pyop2.types.dat.AbstractDat.unfreeze_halo"]], "unfreeze_halo() (pyop2.types.dat.mixeddat method)": [[15, "pyop2.types.dat.MixedDat.unfreeze_halo"]], "unfreeze_halo() (pyop2.types.glob.global method)": [[15, "pyop2.types.glob.Global.unfreeze_halo"]], "union() (pyop2.types.set.set method)": [[15, "pyop2.types.set.Set.union"]], "union() (pyop2.types.set.subset method)": [[15, "pyop2.types.set.Subset.union"]], "values (pyop2.types.map.composedmap attribute)": [[15, "pyop2.types.map.ComposedMap.values"]], "values (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.values"]], "values (pyop2.types.map.mixedmap attribute)": [[15, "pyop2.types.map.MixedMap.values"]], "values_with_halo (pyop2.types.map.composedmap attribute)": [[15, "pyop2.types.map.ComposedMap.values_with_halo"]], "values_with_halo (pyop2.types.map.map attribute)": [[15, "pyop2.types.map.Map.values_with_halo"]], "values_with_halo (pyop2.types.map.mixedmap attribute)": [[15, "pyop2.types.map.MixedMap.values_with_halo"]], "vec (pyop2.types.data_carrier.vecaccessmixin property)": [[15, "pyop2.types.data_carrier.VecAccessMixin.vec"]], "vec_context() (pyop2.types.dat.dat method)": [[15, "pyop2.types.dat.Dat.vec_context"]], "vec_context() (pyop2.types.dat.mixeddat method)": [[15, "pyop2.types.dat.MixedDat.vec_context"]], "vec_context() (pyop2.types.data_carrier.vecaccessmixin method)": [[15, "pyop2.types.data_carrier.VecAccessMixin.vec_context"]], "vec_context() (pyop2.types.glob.global method)": [[15, "pyop2.types.glob.Global.vec_context"]], "vec_ro (pyop2.types.data_carrier.vecaccessmixin property)": [[15, "pyop2.types.data_carrier.VecAccessMixin.vec_ro"]], "vec_wo (pyop2.types.data_carrier.vecaccessmixin property)": [[15, "pyop2.types.data_carrier.VecAccessMixin.vec_wo"]], "zero() (pyop2.types.dat.abstractdat method)": [[15, "pyop2.types.dat.AbstractDat.zero"]], "zero() (pyop2.types.dat.mixeddat method)": [[15, "pyop2.types.dat.MixedDat.zero"]], "zero() (pyop2.types.glob.global method)": [[15, "pyop2.types.glob.Global.zero"]]}})
\ No newline at end of file
diff --git a/user.html b/user.html
new file mode 100644
index 000000000..d6e2dc835
--- /dev/null
+++ b/user.html
@@ -0,0 +1,125 @@
+<!DOCTYPE html>
+
+<html lang="en" data-content_root="./">
+  <head>
+    <meta charset="utf-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
+
+    <title>pyop2 user documentation &#8212; PyOP2 2020.0 documentation</title>
+    <link rel="stylesheet" type="text/css" href="_static/pygments.css?v=fa44fd50" />
+    <link rel="stylesheet" type="text/css" href="_static/classic.css?v=514cf933" />
+    
+    <script src="_static/documentation_options.js?v=63d4e452"></script>
+    <script src="_static/doctools.js?v=888ff710"></script>
+    <script src="_static/sphinx_highlight.js?v=dc90522c"></script>
+    
+    <link rel="index" title="Index" href="genindex.html" />
+    <link rel="search" title="Search" href="search.html" />
+    <link rel="next" title="pyop2 package" href="pyop2.html" />
+    <link rel="prev" title="Profiling" href="profiling.html" /> 
+  </head><body>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             accesskey="I">index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="pyop2.html" title="pyop2 package"
+             accesskey="N">next</a> |</li>
+        <li class="right" >
+          <a href="profiling.html" title="Profiling"
+             accesskey="P">previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">pyop2 user documentation</a></li> 
+      </ul>
+    </div>  
+
+    <div class="document">
+      <div class="documentwrapper">
+        <div class="bodywrapper">
+          <div class="body" role="main">
+            
+  <section id="pyop2-user-documentation">
+<h1>pyop2 user documentation<a class="headerlink" href="#pyop2-user-documentation" title="Link to this heading">¶</a></h1>
+<section id="pyop2-package">
+<h2><code class="xref py py-mod docutils literal notranslate"><span class="pre">pyop2</span></code> Package<a class="headerlink" href="#pyop2-package" title="Link to this heading">¶</a></h2>
+</section>
+</section>
+
+
+            <div class="clearer"></div>
+          </div>
+        </div>
+      </div>
+      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
+        <div class="sphinxsidebarwrapper">
+  <div>
+    <h3><a href="index.html">Table of Contents</a></h3>
+    <ul>
+<li><a class="reference internal" href="#">pyop2 user documentation</a><ul>
+<li><a class="reference internal" href="#pyop2-package"><code class="xref py py-mod docutils literal notranslate"><span class="pre">pyop2</span></code> Package</a></li>
+</ul>
+</li>
+</ul>
+
+  </div>
+  <div>
+    <h4>Previous topic</h4>
+    <p class="topless"><a href="profiling.html"
+                          title="previous chapter">Profiling</a></p>
+  </div>
+  <div>
+    <h4>Next topic</h4>
+    <p class="topless"><a href="pyop2.html"
+                          title="next chapter">pyop2 package</a></p>
+  </div>
+  <div role="note" aria-label="source link">
+    <h3>This Page</h3>
+    <ul class="this-page-menu">
+      <li><a href="_sources/user.rst.txt"
+            rel="nofollow">Show Source</a></li>
+    </ul>
+   </div>
+<div id="searchbox" style="display: none" role="search">
+  <h3 id="searchlabel">Quick search</h3>
+    <div class="searchformwrapper">
+    <form class="search" action="search.html" method="get">
+      <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
+      <input type="submit" value="Go" />
+    </form>
+    </div>
+</div>
+<script>document.getElementById('searchbox').style.display = "block"</script>
+        </div>
+      </div>
+      <div class="clearer"></div>
+    </div>
+    <div class="related" role="navigation" aria-label="related navigation">
+      <h3>Navigation</h3>
+      <ul>
+        <li class="right" style="margin-right: 10px">
+          <a href="genindex.html" title="General Index"
+             >index</a></li>
+        <li class="right" >
+          <a href="py-modindex.html" title="Python Module Index"
+             >modules</a> |</li>
+        <li class="right" >
+          <a href="pyop2.html" title="pyop2 package"
+             >next</a> |</li>
+        <li class="right" >
+          <a href="profiling.html" title="Profiling"
+             >previous</a> |</li>
+        <li class="nav-item nav-item-0"><a href="index.html">PyOP2 2020.0 documentation</a> &#187;</li>
+        <li class="nav-item nav-item-this"><a href="">pyop2 user documentation</a></li> 
+      </ul>
+    </div>
+    <div class="footer" role="contentinfo">
+    &#169; Copyright 2012-2013, Imperial College et al.
+      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
+    </div>
+  </body>
+</html>
\ No newline at end of file