From dcad809eb06e4a8921220f4162d0816d9fb25630 Mon Sep 17 00:00:00 2001
From: imcovangent <I.vanGent@tudelft.nl>
Date: Wed, 5 Sep 2018 14:29:02 +0200
Subject: [PATCH] Finished KADMOS/VISTOMS interface server version and tested
 locally.

Former-commit-id: b871e42fd444cc5ddda8477ddd7c7dd15e859b13
---
 kadmos/graph/mixin_vistoms.py                 |    31 +-
 kadmos/vistoms/clean_server_database.py       |    24 +
 .../downloads/sellar_problem_fpg_mda.xml      |   397 +
 .../downloads/sellar_problem_fpg_mdo.xml      |   431 +
 .../vistoms/downloads/sellar_problem_idf.xml  |   953 +
 .../downloads/sellar_problem_mdfgs.xml        |   810 +
 .../vistoms/downloads/sellar_problem_mdfj.xml |   858 +
 .../vistoms/downloads/sellar_problem_rcg.xml  |   434 +
 kadmos/vistoms/downloads/ssbj_co.xml          |  3989 +++
 kadmos/vistoms/downloads/ssbj_doegs.xml       |  2334 ++
 kadmos/vistoms/downloads/ssbj_fpg_mda.xml     |  1270 +
 kadmos/vistoms/downloads/ssbj_fpg_mdo.xml     |  1401 +
 kadmos/vistoms/downloads/ssbj_mdags.xml       |  1783 +
 kadmos/vistoms/downloads/ssbj_mdfgs.xml       |  2470 ++
 kadmos/vistoms/downloads/ssbj_mdfj.xml        |  2606 ++
 kadmos/vistoms/downloads/ssbj_rcg.xml         |  1195 +
 kadmos/vistoms/examples/SellarARCG_01.kdms    |   Bin 5175 -> 0 bytes
 kadmos/vistoms/examples/SellarBFPGIDF_02.kdms |   Bin 5506 -> 0 bytes
 .../vistoms/examples/SellarCMDAOIDF_03.kdms   |   Bin 10747 -> 0 bytes
 .../examples/SellarCMDAOIDF_03_mpg.kdms       |   Bin 4412 -> 0 bytes
 .../vistoms/examples/SellarDFPGMDFGS_04.kdms  |   Bin 5452 -> 0 bytes
 .../vistoms/examples/SellarEMDAOMDFGS_05.kdms |   Bin 9438 -> 0 bytes
 .../examples/SellarEMDAOMDFGS_05_mpg.kdms     |   Bin 4251 -> 0 bytes
 kadmos/vistoms/examples/SsbjARCG_06.kdms      |   Bin 16612 -> 0 bytes
 kadmos/vistoms/examples/SsbjBFPG_07.kdms      |   Bin 18581 -> 0 bytes
 kadmos/vistoms/examples/SsbjCBLISS_08.kdms    |   Bin 77715 -> 0 bytes
 .../vistoms/examples/SsbjCBLISS_08_mpg.kdms   |   Bin 29370 -> 0 bytes
 kadmos/vistoms/examples/SsbjDCO_09.kdms       |   Bin 51690 -> 0 bytes
 kadmos/vistoms/examples/SsbjDCO_09_mpg.kdms   |   Bin 17112 -> 0 bytes
 .../vistoms/examples/scriptfornamechange.py   |    22 -
 kadmos/vistoms/interface_start.py             |     6 +-
 kadmos/vistoms/interface_vistoms.py           |  2064 --
 .../vistoms/templates/VISTOMS_sessions.html   | 28573 ----------------
 .../vistoms/templates/acknowledgements.html   |     6 +-
 kadmos/vistoms/templates/index.html           |    70 +-
 kadmos/vistoms/templates/info.html            |    14 +-
 kadmos/vistoms/vistoms.py                     |    88 +-
 37 files changed, 21137 insertions(+), 30692 deletions(-)
 create mode 100644 kadmos/vistoms/clean_server_database.py
 create mode 100644 kadmos/vistoms/downloads/sellar_problem_fpg_mda.xml
 create mode 100644 kadmos/vistoms/downloads/sellar_problem_fpg_mdo.xml
 create mode 100644 kadmos/vistoms/downloads/sellar_problem_idf.xml
 create mode 100644 kadmos/vistoms/downloads/sellar_problem_mdfgs.xml
 create mode 100644 kadmos/vistoms/downloads/sellar_problem_mdfj.xml
 create mode 100644 kadmos/vistoms/downloads/sellar_problem_rcg.xml
 create mode 100644 kadmos/vistoms/downloads/ssbj_co.xml
 create mode 100644 kadmos/vistoms/downloads/ssbj_doegs.xml
 create mode 100644 kadmos/vistoms/downloads/ssbj_fpg_mda.xml
 create mode 100644 kadmos/vistoms/downloads/ssbj_fpg_mdo.xml
 create mode 100644 kadmos/vistoms/downloads/ssbj_mdags.xml
 create mode 100644 kadmos/vistoms/downloads/ssbj_mdfgs.xml
 create mode 100644 kadmos/vistoms/downloads/ssbj_mdfj.xml
 create mode 100644 kadmos/vistoms/downloads/ssbj_rcg.xml
 delete mode 100644 kadmos/vistoms/examples/SellarARCG_01.kdms
 delete mode 100644 kadmos/vistoms/examples/SellarBFPGIDF_02.kdms
 delete mode 100644 kadmos/vistoms/examples/SellarCMDAOIDF_03.kdms
 delete mode 100644 kadmos/vistoms/examples/SellarCMDAOIDF_03_mpg.kdms
 delete mode 100644 kadmos/vistoms/examples/SellarDFPGMDFGS_04.kdms
 delete mode 100644 kadmos/vistoms/examples/SellarEMDAOMDFGS_05.kdms
 delete mode 100644 kadmos/vistoms/examples/SellarEMDAOMDFGS_05_mpg.kdms
 delete mode 100644 kadmos/vistoms/examples/SsbjARCG_06.kdms
 delete mode 100644 kadmos/vistoms/examples/SsbjBFPG_07.kdms
 delete mode 100644 kadmos/vistoms/examples/SsbjCBLISS_08.kdms
 delete mode 100644 kadmos/vistoms/examples/SsbjCBLISS_08_mpg.kdms
 delete mode 100644 kadmos/vistoms/examples/SsbjDCO_09.kdms
 delete mode 100644 kadmos/vistoms/examples/SsbjDCO_09_mpg.kdms
 delete mode 100644 kadmos/vistoms/examples/scriptfornamechange.py
 delete mode 100644 kadmos/vistoms/interface_vistoms.py
 delete mode 100644 kadmos/vistoms/templates/VISTOMS_sessions.html

diff --git a/kadmos/graph/mixin_vistoms.py b/kadmos/graph/mixin_vistoms.py
index 577a9f3b9..ae90583b5 100644
--- a/kadmos/graph/mixin_vistoms.py
+++ b/kadmos/graph/mixin_vistoms.py
@@ -6,6 +6,7 @@ import shutil
 import linecache
 import logging
 import tempfile
+from datetime import datetime
 
 import progressbar
 from kadmos.cmdows import CMDOWS
@@ -1257,8 +1258,18 @@ def _get_the_data(vistoms_file):
     return data, thedata_linenumber
 
 
-def retrieve_session_folder(sessions_catalog_folder, session_id):
-    # TODO: Add docstring
+def retrieve_session_folder(sessions_catalog_folder, session_id, add_usage_stamp=False):
+    """Function to retrieve the session folder path from a session specification file in the catalog.
+
+    :param sessions_catalog_folder: Folder with session specification files
+    :type sessions_catalog_folder: str
+    :param session_id: identifier of the session
+    :type session_id: str
+    :param add_usage_stamp: setting on whether a refresh stamp should be added
+    :type add_usage_stamp: bool
+    :return: folder path with the session files
+    :rtype: str
+    """
 
     # Check if the sessions catalog folder exists
     if not os.path.exists(sessions_catalog_folder):
@@ -1267,25 +1278,31 @@ def retrieve_session_folder(sessions_catalog_folder, session_id):
     # If the folder exists, then check if the session_id file exists
     session_file_name = session_id + '.json'
     session_file_path = os.path.join(sessions_catalog_folder, session_file_name)
-    if not os.path.isfile(session_file_path):
+    if not os.path.isfile(session_file_path):  # Create new session file if it does not exist
         raise AssertionError('Could not find session file {} in sessions catalog folder {}.'
                              .format(session_file_name, sessions_catalog_folder))
 
     # If folder and file exist, then read the file
     try:
         with open(session_file_path) as f:
-            session_data = json.load(f)
+            session_details = json.load(f)
     except Exception as e:
         raise SystemError('Could not read the session file {} because of {}.'.format(session_file_name, e))
 
     # Check if folder if provided in session data
-    if 'folder' not in session_data:
+    if 'folder' not in session_details:
         raise AssertionError('Could not read folder from session file {}.'.format(session_file_name))
     else:
-        session_folder = session_data['folder']
+        session_folder = session_details['folder']
+
+    # Optionally add usage stamp to session catalog file
+    if add_usage_stamp:
+        session_details['last_refresh'] = str(datetime.now())
+        with open(session_file_path, 'w') as outfile:
+            json.dump(session_details, outfile)
 
     # Make sure the session folder exists or else create it
     if not os.path.exists(session_folder):
-        os.mkdir(session_folder)
+        os.makedirs(session_folder)
 
     return session_folder
diff --git a/kadmos/vistoms/clean_server_database.py b/kadmos/vistoms/clean_server_database.py
new file mode 100644
index 000000000..2df06c98c
--- /dev/null
+++ b/kadmos/vistoms/clean_server_database.py
@@ -0,0 +1,24 @@
+import json
+import os
+import shutil
+
+session_catalog_folder = '/Users/imcovangent/Desktop/VISTOMS_interface_ses'
+
+for file in os.listdir(session_catalog_folder):
+    if os.path.splitext(file)[1] == '.json':
+        # Read the file
+        session_file_path = os.path.join(session_catalog_folder, file)
+        try:
+            with open(session_file_path) as f:
+                session_details = json.load(f)
+        except Exception as e:
+            raise SystemError('Could not read the session file {} because of {}.'.format(file, e))
+        if 'last_refresh' not in session_details:
+            session_folder = session_details['folder']
+            try:
+                shutil.rmtree(session_folder)
+            except Exception as e:
+                print("WARNING: Could not remove session folder {}.".format(session_folder))
+            os.remove(session_file_path)
+            print("Removed session file and session folder for session {}.".format(os.path.basename(file)))
+print("Finished cleaning database.")
diff --git a/kadmos/vistoms/downloads/sellar_problem_fpg_mda.xml b/kadmos/vistoms/downloads/sellar_problem_fpg_mda.xml
new file mode 100644
index 000000000..37128eafb
--- /dev/null
+++ b/kadmos/vistoms/downloads/sellar_problem_fpg_mda.xml
@@ -0,0 +1,397 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>FPG CMDOWS file of the well-known Sellar problem</description>
+    <timestamp>2018-07-31T15:33:25.889517</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a fundamental problem graph (FPG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-07-31T15:33:25.889517</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="ivangent">
+          <name>Imco van Gent</name>
+          <email>i.vangent@tudelft.nl</email>
+          <company>TU Delft</company>
+        </contact>
+        <contact uID="lmuller">
+          <name>Lukas Muller</name>
+          <email>l.muller@student.tudelft.nl</email>
+          <company>TU Delft</company>
+        </contact>
+      </contacts>
+      <organigram>
+        <integrators>
+          <integrator>
+            <contactUID>ivangent</contactUID>
+          </integrator>
+        </integrators>
+        <architects>
+          <architect>
+            <contactUID>lmuller</contactUID>
+          </architect>
+          <architect>
+            <contactUID>ivangent</contactUID>
+          </architect>
+        </architects>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="A">
+        <label>A</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/settings/a</parameterUID>
+            <equationLabel>a</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/settings/c</parameterUID>
+            <equations uID="A_equation">
+              <equation language="Python">a</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="F1">
+        <label>F1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <equationLabel>x1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/f</parameterUID>
+            <equations uID="F1_equation">
+              <equation language="Python">x1**2+z2+y1+exp(-y2)</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="G2">
+        <label>G2</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/g2</parameterUID>
+            <equations uID="G2_equation">
+              <equation language="Python">1-y2/24.0</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="G1">
+        <label>G1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/g1</parameterUID>
+            <equations uID="G1_equation">
+              <equation language="Python">y1/3.16-1</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="D2">
+        <label>D2</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <equationLabel>z1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/settings/c</parameterUID>
+            <equationLabel>c</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equations uID="D2_equation">
+              <equation language="Python">abs(y1)**.5 + z1 + z2</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="D1">
+        <label>D1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <equationLabel>x1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <equationLabel>z1</equationLabel>
+            <validRanges>
+              <limitRange>
+                <minimum>-5</minimum>
+                <maximum>5.0</maximum>
+              </limitRange>
+              <listRange>
+                <listRangeItem>7.5</listRangeItem>
+                <listRangeItem>8</listRangeItem>
+              </listRange>
+            </validRanges>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/settings/c</parameterUID>
+            <equationLabel>c</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equations uID="D1_equation">
+              <equation language="Python">z1**2. + x1 + z2 - .2*y2</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/analyses/y1">
+      <label>y1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/settings/c">
+      <label>c</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/y2">
+      <label>y2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/settings/a">
+      <label>a</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/z2">
+      <label>z2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/z1">
+      <label>z1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/x1">
+      <label>x1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/g1">
+      <label>g1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/g2">
+      <label>g2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/f">
+      <label>f</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <problemDefinition uID="converged-MDAGauss-Seidel">
+    <problemFormulation>
+      <mdaoArchitecture>converged-MDA</mdaoArchitecture>
+      <convergerType>Gauss-Seidel</convergerType>
+      <executableBlocksOrder>
+        <executableBlock position="1">A</executableBlock>
+        <executableBlock position="2">D2</executableBlock>
+        <executableBlock position="3">D1</executableBlock>
+        <executableBlock position="4">G1</executableBlock>
+        <executableBlock position="5">G2</executableBlock>
+        <executableBlock position="6">F1</executableBlock>
+      </executableBlocksOrder>
+      <allowUnconvergedCouplings>false</allowUnconvergedCouplings>
+    </problemFormulation>
+    <problemRoles>
+      <parameters>
+        <stateVariables>
+          <stateVariable uID="__statVar__/dataSchema/analyses/y1">
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/analyses/y2">
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/analyses/g1">
+            <parameterUID>/dataSchema/analyses/g1</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/analyses/g2">
+            <parameterUID>/dataSchema/analyses/g2</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/analyses/f">
+            <parameterUID>/dataSchema/analyses/f</parameterUID>
+          </stateVariable>
+        </stateVariables>
+      </parameters>
+      <executableBlocks>
+        <preCouplingBlocks>
+          <preCouplingBlock>A</preCouplingBlock>
+        </preCouplingBlocks>
+        <coupledBlocks>
+          <coupledBlock>D2</coupledBlock>
+          <coupledBlock>D1</coupledBlock>
+        </coupledBlocks>
+        <postCouplingBlocks>
+          <postCouplingBlock>G1</postCouplingBlock>
+          <postCouplingBlock>G2</postCouplingBlock>
+          <postCouplingBlock>F1</postCouplingBlock>
+        </postCouplingBlocks>
+      </executableBlocks>
+    </problemRoles>
+  </problemDefinition>
+  <workflow>
+    <dataGraph>
+      <name>FPG - converged-MDA-GS</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>A</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/settings/c</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/f</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/g2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/g1</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>G1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/settings/a</fromParameterUID>
+          <toExecutableBlockUID>A</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/settings/c</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/settings/c</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>G2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/y1</toParameterUID>
+        </edge>
+      </edges>
+    </dataGraph>
+  </workflow>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/sellar_problem_fpg_mdo.xml b/kadmos/vistoms/downloads/sellar_problem_fpg_mdo.xml
new file mode 100644
index 000000000..7e0a6a4d5
--- /dev/null
+++ b/kadmos/vistoms/downloads/sellar_problem_fpg_mdo.xml
@@ -0,0 +1,431 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>FPG CMDOWS file of the well-known Sellar problem</description>
+    <timestamp>2018-07-31T15:59:27.917199</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a fundamental problem graph (FPG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-07-31T15:59:27.917199</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="ivangent">
+          <name>Imco van Gent</name>
+          <email>i.vangent@tudelft.nl</email>
+          <company>TU Delft</company>
+        </contact>
+        <contact uID="lmuller">
+          <name>Lukas Muller</name>
+          <email>l.muller@student.tudelft.nl</email>
+          <company>TU Delft</company>
+        </contact>
+      </contacts>
+      <organigram>
+        <integrators>
+          <integrator>
+            <contactUID>ivangent</contactUID>
+          </integrator>
+        </integrators>
+        <architects>
+          <architect>
+            <contactUID>lmuller</contactUID>
+          </architect>
+          <architect>
+            <contactUID>ivangent</contactUID>
+          </architect>
+        </architects>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="A">
+        <label>A</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/settings/a</parameterUID>
+            <equationLabel>a</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/settings/c</parameterUID>
+            <equations uID="A_equation">
+              <equation language="Python">a</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="F1">
+        <label>F1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <equationLabel>x1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/f</parameterUID>
+            <equations uID="F1_equation">
+              <equation language="Python">x1**2+z2+y1+exp(-y2)</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="G2">
+        <label>G2</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/g2</parameterUID>
+            <equations uID="G2_equation">
+              <equation language="Python">1-y2/24.0</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="G1">
+        <label>G1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/g1</parameterUID>
+            <equations uID="G1_equation">
+              <equation language="Python">y1/3.16-1</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="D2">
+        <label>D2</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <equationLabel>z1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/settings/c</parameterUID>
+            <equationLabel>c</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equations uID="D2_equation">
+              <equation language="Python">abs(y1)**.5 + z1 + z2</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="D1">
+        <label>D1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <equationLabel>x1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <equationLabel>z1</equationLabel>
+            <validRanges>
+              <limitRange>
+                <minimum>-5</minimum>
+                <maximum>5.0</maximum>
+              </limitRange>
+              <listRange>
+                <listRangeItem>7.5</listRangeItem>
+                <listRangeItem>8</listRangeItem>
+              </listRange>
+            </validRanges>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/settings/c</parameterUID>
+            <equationLabel>c</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equations uID="D1_equation">
+              <equation language="Python">z1**2. + x1 + z2 - .2*y2</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/analyses/y1">
+      <label>y1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/settings/c">
+      <label>c</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/y2">
+      <label>y2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/settings/a">
+      <label>a</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/z2">
+      <label>z2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/z1">
+      <label>z1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/x1">
+      <label>x1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/g1">
+      <label>g1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/g2">
+      <label>g2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/f">
+      <label>f</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <problemDefinition uID="MDFGauss-Seidel">
+    <problemFormulation>
+      <mdaoArchitecture>MDF</mdaoArchitecture>
+      <convergerType>Gauss-Seidel</convergerType>
+      <executableBlocksOrder>
+        <executableBlock position="1">A</executableBlock>
+        <executableBlock position="2">D2</executableBlock>
+        <executableBlock position="3">D1</executableBlock>
+        <executableBlock position="4">G1</executableBlock>
+        <executableBlock position="5">G2</executableBlock>
+        <executableBlock position="6">F1</executableBlock>
+      </executableBlocksOrder>
+      <allowUnconvergedCouplings>false</allowUnconvergedCouplings>
+    </problemFormulation>
+    <problemRoles>
+      <parameters>
+        <designVariables>
+          <designVariable uID="__desVar__/dataSchema/geometry/z2">
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.0</minimum>
+                <maximum>10</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/geometry/z1">
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>-10</minimum>
+                <maximum>10</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/geometry/x1">
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.0</minimum>
+                <maximum>10</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+        </designVariables>
+        <objectiveVariables>
+          <objectiveVariable uID="__objVar__/dataSchema/analyses/f">
+            <parameterUID>/dataSchema/analyses/f</parameterUID>
+          </objectiveVariable>
+        </objectiveVariables>
+        <constraintVariables>
+          <constraintVariable uID="__conVar__/dataSchema/analyses/g1">
+            <parameterUID>/dataSchema/analyses/g1</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/analyses/g2">
+            <parameterUID>/dataSchema/analyses/g2</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+        </constraintVariables>
+      </parameters>
+      <executableBlocks>
+        <preCouplingBlocks>
+          <preCouplingBlock>A</preCouplingBlock>
+        </preCouplingBlocks>
+        <coupledBlocks>
+          <coupledBlock>D2</coupledBlock>
+          <coupledBlock>D1</coupledBlock>
+        </coupledBlocks>
+        <postCouplingBlocks>
+          <postCouplingBlock>G1</postCouplingBlock>
+          <postCouplingBlock>G2</postCouplingBlock>
+          <postCouplingBlock>F1</postCouplingBlock>
+        </postCouplingBlocks>
+      </executableBlocks>
+    </problemRoles>
+  </problemDefinition>
+  <workflow>
+    <dataGraph>
+      <name>FPG - MDF-GS</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>A</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/settings/c</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/f</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/g2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/g1</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>G1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/settings/a</fromParameterUID>
+          <toExecutableBlockUID>A</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/settings/c</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/settings/c</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>G2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/y1</toParameterUID>
+        </edge>
+      </edges>
+    </dataGraph>
+  </workflow>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/sellar_problem_idf.xml b/kadmos/vistoms/downloads/sellar_problem_idf.xml
new file mode 100644
index 000000000..f0e394e83
--- /dev/null
+++ b/kadmos/vistoms/downloads/sellar_problem_idf.xml
@@ -0,0 +1,953 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>Mdao CMDOWS file of the well-known Sellar problem</description>
+    <timestamp>2018-08-20T15:36:22.849944</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a mdao data graph (MDG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-08-20T15:36:22.849944</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="ivangent">
+          <name>Imco van Gent</name>
+          <email>i.vangent@tudelft.nl</email>
+          <company>TU Delft</company>
+        </contact>
+        <contact uID="lmuller">
+          <name>Lukas Muller</name>
+          <email>l.muller@student.tudelft.nl</email>
+          <company>TU Delft</company>
+        </contact>
+      </contacts>
+      <organigram>
+        <integrators>
+          <integrator>
+            <contactUID>ivangent</contactUID>
+          </integrator>
+        </integrators>
+        <architects>
+          <architect>
+            <contactUID>lmuller</contactUID>
+          </architect>
+          <architect>
+            <contactUID>ivangent</contactUID>
+          </architect>
+        </architects>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="F1">
+        <label>F1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <equationLabel>x1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/f</parameterUID>
+            <equations uID="F1_equation">
+              <equation language="Python">x1**2+z2+y1+exp(-y2)</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/analyses/f</parameterUID>
+            <equationsUID>F1_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="G2">
+        <label>G2</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/g2</parameterUID>
+            <equations uID="G2_equation">
+              <equation language="Python">1-y2/24.0</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g2</parameterUID>
+            <equationsUID>G2_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="G1">
+        <label>G1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g1</parameterUID>
+            <equations uID="G1_equation">
+              <equation language="Python">y1/3.16-1</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/analyses/g1</parameterUID>
+            <equationsUID>G1_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="Gc">
+        <label>Gc</label>
+        <functionType>consistency</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1</parameterUID>
+            <equationLabel>y1c</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y2</parameterUID>
+            <equationLabel>y2c</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y1</parameterUID>
+            <equations uID="Gc_equation">
+              <equation language="Python">y1-y1c</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y2</parameterUID>
+            <equations uID="Gc_equation_1">
+              <equation language="Python">y2-y2c</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="D2">
+        <label>D2</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <equationLabel>z1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equations uID="D2_equation">
+              <equation language="Python">abs(y1)**.5 + z1 + z2</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y2</parameterUID>
+            <equationsUID>D2_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="D1">
+        <label>D1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <equationLabel>x1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <equationLabel>z1</equationLabel>
+            <validRanges>
+              <limitRange>
+                <minimum>-5</minimum>
+                <maximum>5.0</maximum>
+              </limitRange>
+              <listRange>
+                <listRangeItem>7.5</listRangeItem>
+                <listRangeItem>8</listRangeItem>
+              </listRange>
+            </validRanges>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y1</parameterUID>
+            <equations uID="D1_equation">
+              <equation language="Python">z1**2. + x1 + z2 - .2*y2</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationsUID>D1_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/analyses/g1">
+      <label>g1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/g2">
+      <label>g2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/f">
+      <label>f</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/z1">
+      <label>z1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/z2">
+      <label>z2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/y2">
+      <label>y2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/y1">
+      <label>y1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/x1">
+      <label>x1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <problemDefinition uID="IDFNone">
+    <problemFormulation>
+      <mdaoArchitecture>IDF</mdaoArchitecture>
+      <executableBlocksOrder>
+        <executableBlock position="1">D2</executableBlock>
+        <executableBlock position="2">D1</executableBlock>
+        <executableBlock position="3">G1</executableBlock>
+        <executableBlock position="4">G2</executableBlock>
+        <executableBlock position="5">F1</executableBlock>
+      </executableBlocksOrder>
+      <allowUnconvergedCouplings>false</allowUnconvergedCouplings>
+    </problemFormulation>
+    <problemRoles>
+      <parameters>
+        <designVariables>
+          <designVariable uID="__desVar__/dataSchema/geometry/z1">
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>-10</minimum>
+                <maximum>10</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/geometry/z2">
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.0</minimum>
+                <maximum>10</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/analyses/y2">
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>-10.0</minimum>
+                <maximum>10.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/analyses/y1">
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>-10.0</minimum>
+                <maximum>10.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/geometry/x1">
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.0</minimum>
+                <maximum>10</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+        </designVariables>
+        <objectiveVariables>
+          <objectiveVariable uID="__objVar__/dataSchema/analyses/f">
+            <parameterUID>/dataSchema/analyses/f</parameterUID>
+          </objectiveVariable>
+        </objectiveVariables>
+        <constraintVariables>
+          <constraintVariable uID="__conVar__/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y1">
+            <parameterUID>/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y1</parameterUID>
+            <constraintType>equality</constraintType>
+            <constraintOperator>==</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y2">
+            <parameterUID>/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y2</parameterUID>
+            <constraintType>equality</constraintType>
+            <constraintOperator>==</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/analyses/g1">
+            <parameterUID>/dataSchema/analyses/g1</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/analyses/g2">
+            <parameterUID>/dataSchema/analyses/g2</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+        </constraintVariables>
+      </parameters>
+      <executableBlocks>
+        <coupledBlocks>
+          <coupledBlock>D2</coupledBlock>
+          <coupledBlock>D1</coupledBlock>
+        </coupledBlocks>
+        <postCouplingBlocks>
+          <postCouplingBlock>G1</postCouplingBlock>
+          <postCouplingBlock>G2</postCouplingBlock>
+          <postCouplingBlock>F1</postCouplingBlock>
+          <postCouplingBlock>Gc</postCouplingBlock>
+        </postCouplingBlocks>
+      </executableBlocks>
+    </problemRoles>
+  </problemDefinition>
+  <workflow>
+    <problemDefinitionUID>IDFNone</problemDefinitionUID>
+    <dataGraph>
+      <name>XDSM - IDF</name>
+      <edges>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y1</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y2</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g1</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>Gc</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>Gc</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/geometry/x1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/geometry/z1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/geometry/z2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/x1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/g2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/g1</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/g1</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/g2</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Gc</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Gc</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/f</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/f</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/f</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/f</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/x1</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>Gc</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>G2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>Gc</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>G1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/y1</toParameterUID>
+        </edge>
+      </edges>
+    </dataGraph>
+    <processGraph>
+      <name>mpg Sellar problem</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>F1</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G2</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G1</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>1</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Gc</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toExecutableBlockUID>Gc</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toExecutableBlockUID>G2</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toExecutableBlockUID>Gc</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toExecutableBlockUID>G1</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+      </edges>
+      <nodes>
+        <node>
+          <referenceUID>F1</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>6</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Optimizer</referenceUID>
+          <processStepNumber>1</processStepNumber>
+          <convergerStepNumber>4</convergerStepNumber>
+          <diagonalPosition>1</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>G2</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>5</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>G1</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>4</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Coordinator</referenceUID>
+          <processStepNumber>0</processStepNumber>
+          <convergerStepNumber>5</convergerStepNumber>
+          <diagonalPosition>0</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Gc</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>7</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>D2</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <diagonalPosition>2</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>D1</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <diagonalPosition>3</diagonalPosition>
+        </node>
+      </nodes>
+      <metadata>
+        <loopNesting>
+          <loopElements>
+            <loopElement relatedUID="Coordinator">
+              <loopElements>
+                <loopElement relatedUID="Optimizer">
+                  <functionElements>
+                    <functionElement>D1</functionElement>
+                    <functionElement>D2</functionElement>
+                    <functionElement>F1</functionElement>
+                    <functionElement>G1</functionElement>
+                    <functionElement>Gc</functionElement>
+                    <functionElement>G2</functionElement>
+                  </functionElements>
+                </loopElement>
+              </loopElements>
+            </loopElement>
+          </loopElements>
+        </loopNesting>
+      </metadata>
+    </processGraph>
+  </workflow>
+  <architectureElements>
+    <parameters>
+      <initialGuessCouplingVariables>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y1">
+          <relatedParameterUID>/dataSchema/analyses/y1</relatedParameterUID>
+          <label>y1^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y2">
+          <relatedParameterUID>/dataSchema/analyses/y2</relatedParameterUID>
+          <label>y2^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+      </initialGuessCouplingVariables>
+      <finalCouplingVariables>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y2">
+          <relatedParameterUID>/dataSchema/analyses/y2</relatedParameterUID>
+          <label>y2^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y1">
+          <relatedParameterUID>/dataSchema/analyses/y1</relatedParameterUID>
+          <label>y1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+      </finalCouplingVariables>
+      <couplingCopyVariables>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1">
+          <relatedParameterUID>/dataSchema/analyses/y1</relatedParameterUID>
+          <label>y1^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y2">
+          <relatedParameterUID>/dataSchema/analyses/y2</relatedParameterUID>
+          <label>y2^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+      </couplingCopyVariables>
+      <initialGuessDesignVariables>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z2">
+          <relatedParameterUID>/dataSchema/geometry/z2</relatedParameterUID>
+          <label>z2^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/x1">
+          <relatedParameterUID>/dataSchema/geometry/x1</relatedParameterUID>
+          <label>x1^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z1">
+          <relatedParameterUID>/dataSchema/geometry/z1</relatedParameterUID>
+          <label>z1^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+      </initialGuessDesignVariables>
+      <finalDesignVariables>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/x1">
+          <relatedParameterUID>/dataSchema/geometry/x1</relatedParameterUID>
+          <label>x1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z1">
+          <relatedParameterUID>/dataSchema/geometry/z1</relatedParameterUID>
+          <label>z1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z2">
+          <relatedParameterUID>/dataSchema/geometry/z2</relatedParameterUID>
+          <label>z2^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+      </finalDesignVariables>
+      <finalOutputVariables>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g1">
+          <relatedParameterUID>/dataSchema/analyses/g1</relatedParameterUID>
+          <label>g1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/f">
+          <relatedParameterUID>/dataSchema/analyses/f</relatedParameterUID>
+          <label>f^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g2">
+          <relatedParameterUID>/dataSchema/analyses/g2</relatedParameterUID>
+          <label>g2^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+      </finalOutputVariables>
+      <consistencyConstraintVariables>
+        <consistencyConstraintVariable uID="/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y1">
+          <relatedParameterUID>/dataSchema/analyses/y1</relatedParameterUID>
+          <label>gc_y1</label>
+          <instanceID>1</instanceID>
+        </consistencyConstraintVariable>
+        <consistencyConstraintVariable uID="/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y2">
+          <relatedParameterUID>/dataSchema/analyses/y2</relatedParameterUID>
+          <label>gc_y2</label>
+          <instanceID>1</instanceID>
+        </consistencyConstraintVariable>
+      </consistencyConstraintVariables>
+    </parameters>
+    <executableBlocks>
+      <coordinators>
+        <coordinator uID="Coordinator">
+          <label>COOR</label>
+        </coordinator>
+      </coordinators>
+      <optimizers>
+        <optimizer uID="Optimizer">
+          <label>OPT</label>
+          <settings>
+            <package>SciPy</package>
+            <algorithm>SLSQP</algorithm>
+            <maximumIterations>1000</maximumIterations>
+            <maximumFunctionEvaluations>1000</maximumFunctionEvaluations>
+            <convergenceTolerance>1e-06</convergenceTolerance>
+            <constraintTolerance>1e-06</constraintTolerance>
+            <applyScaling>true</applyScaling>
+          </settings>
+          <designVariables>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/analyses/y2</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/geometry/x1</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/analyses/y1</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/geometry/z1</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/geometry/z2</designVariableUID>
+            </designVariable>
+          </designVariables>
+          <objectiveVariables>
+            <objectiveVariable>
+              <objectiveVariableUID>__objVar__/dataSchema/analyses/f</objectiveVariableUID>
+            </objectiveVariable>
+          </objectiveVariables>
+          <constraintVariables>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/analyses/g1</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/analyses/g2</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y1</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/architectureNodes/consistencyConstraintVariables/dataSchemaCopy/analyses/gc_y2</constraintVariableUID>
+            </constraintVariable>
+          </constraintVariables>
+        </optimizer>
+      </optimizers>
+      <postCouplingAnalyses>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>G2</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>G1</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>Gc</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>F1</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>D2</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>D1</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+      </postCouplingAnalyses>
+    </executableBlocks>
+  </architectureElements>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/sellar_problem_mdfgs.xml b/kadmos/vistoms/downloads/sellar_problem_mdfgs.xml
new file mode 100644
index 000000000..dac56321b
--- /dev/null
+++ b/kadmos/vistoms/downloads/sellar_problem_mdfgs.xml
@@ -0,0 +1,810 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>Mdao CMDOWS file of the well-known Sellar problem</description>
+    <timestamp>2018-08-20T15:17:11.787860</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a mdao data graph (MDG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-08-20T15:17:11.787860</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="ivangent">
+          <name>Imco van Gent</name>
+          <email>i.vangent@tudelft.nl</email>
+          <company>TU Delft</company>
+        </contact>
+        <contact uID="lmuller">
+          <name>Lukas Muller</name>
+          <email>l.muller@student.tudelft.nl</email>
+          <company>TU Delft</company>
+        </contact>
+      </contacts>
+      <organigram>
+        <integrators>
+          <integrator>
+            <contactUID>ivangent</contactUID>
+          </integrator>
+        </integrators>
+        <architects>
+          <architect>
+            <contactUID>lmuller</contactUID>
+          </architect>
+          <architect>
+            <contactUID>ivangent</contactUID>
+          </architect>
+        </architects>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="F1">
+        <label>F1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <equationLabel>x1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/f</parameterUID>
+            <equations uID="F1_equation">
+              <equation language="Python">x1**2+z2+y1+exp(-y2)</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/analyses/f</parameterUID>
+            <equationsUID>F1_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="D2">
+        <label>D2</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <equationLabel>z1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equations uID="D2_equation">
+              <equation language="Python">abs(y1)**.5 + z1 + z2</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="G2">
+        <label>G2</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/g2</parameterUID>
+            <equations uID="G2_equation">
+              <equation language="Python">1-y2/24.0</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g2</parameterUID>
+            <equationsUID>G2_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="G1">
+        <label>G1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g1</parameterUID>
+            <equations uID="G1_equation">
+              <equation language="Python">y1/3.16-1</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/analyses/g1</parameterUID>
+            <equationsUID>G1_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="D1">
+        <label>D1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <equationLabel>z1</equationLabel>
+            <validRanges>
+              <limitRange>
+                <minimum>-5</minimum>
+                <maximum>5.0</maximum>
+              </limitRange>
+              <listRange>
+                <listRangeItem>7.5</listRangeItem>
+                <listRangeItem>8</listRangeItem>
+              </listRange>
+            </validRanges>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <equationLabel>x1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y1</parameterUID>
+            <equations uID="D1_equation">
+              <equation language="Python">z1**2. + x1 + z2 - .2*y2</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationsUID>D1_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/analyses/g1">
+      <label>g1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/g2">
+      <label>g2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/f">
+      <label>f</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/z1">
+      <label>z1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/z2">
+      <label>z2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/y2">
+      <label>y2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/y1">
+      <label>y1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/x1">
+      <label>x1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <problemDefinition uID="MDFGauss-Seidel">
+    <problemFormulation>
+      <mdaoArchitecture>MDF</mdaoArchitecture>
+      <convergerType>Gauss-Seidel</convergerType>
+      <executableBlocksOrder>
+        <executableBlock position="1">D2</executableBlock>
+        <executableBlock position="2">D1</executableBlock>
+        <executableBlock position="3">G1</executableBlock>
+        <executableBlock position="4">G2</executableBlock>
+        <executableBlock position="5">F1</executableBlock>
+      </executableBlocksOrder>
+      <allowUnconvergedCouplings>false</allowUnconvergedCouplings>
+    </problemFormulation>
+    <problemRoles>
+      <parameters>
+        <designVariables>
+          <designVariable uID="__desVar__/dataSchema/geometry/z1">
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>-10</minimum>
+                <maximum>10</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/geometry/z2">
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.0</minimum>
+                <maximum>10</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/geometry/x1">
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.0</minimum>
+                <maximum>10</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+        </designVariables>
+        <objectiveVariables>
+          <objectiveVariable uID="__objVar__/dataSchema/analyses/f">
+            <parameterUID>/dataSchema/analyses/f</parameterUID>
+          </objectiveVariable>
+        </objectiveVariables>
+        <constraintVariables>
+          <constraintVariable uID="__conVar__/dataSchema/analyses/g1">
+            <parameterUID>/dataSchema/analyses/g1</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/analyses/g2">
+            <parameterUID>/dataSchema/analyses/g2</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+        </constraintVariables>
+      </parameters>
+      <executableBlocks>
+        <coupledBlocks>
+          <coupledBlock>D2</coupledBlock>
+          <coupledBlock>D1</coupledBlock>
+        </coupledBlocks>
+        <postCouplingBlocks>
+          <postCouplingBlock>G1</postCouplingBlock>
+          <postCouplingBlock>G2</postCouplingBlock>
+          <postCouplingBlock>F1</postCouplingBlock>
+        </postCouplingBlocks>
+      </executableBlocks>
+    </problemRoles>
+  </problemDefinition>
+  <workflow>
+    <problemDefinitionUID>MDFGauss-Seidel</problemDefinitionUID>
+    <dataGraph>
+      <name>XDSM - MDF-GS</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g1</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/geometry/x1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/geometry/z1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/geometry/z2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/x1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/g2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/g1</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/g1</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/g2</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/f</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/f</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/f</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/f</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/x1</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>G2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>G1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/y1</toParameterUID>
+        </edge>
+      </edges>
+    </dataGraph>
+    <processGraph>
+      <name>mpg Sellar problem</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>F1</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+          <processStepNumber>8</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G2</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G1</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>G2</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>G1</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>1</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+      </edges>
+      <nodes>
+        <node>
+          <referenceUID>F1</referenceUID>
+          <processStepNumber>6</processStepNumber>
+          <diagonalPosition>7</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Optimizer</referenceUID>
+          <processStepNumber>1</processStepNumber>
+          <convergerStepNumber>7</convergerStepNumber>
+          <diagonalPosition>1</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>G2</referenceUID>
+          <processStepNumber>6</processStepNumber>
+          <diagonalPosition>6</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>G1</referenceUID>
+          <processStepNumber>6</processStepNumber>
+          <diagonalPosition>5</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Converger</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <convergerStepNumber>5</convergerStepNumber>
+          <diagonalPosition>2</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Coordinator</referenceUID>
+          <processStepNumber>0</processStepNumber>
+          <convergerStepNumber>8</convergerStepNumber>
+          <diagonalPosition>0</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>D2</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>3</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>D1</referenceUID>
+          <processStepNumber>4</processStepNumber>
+          <diagonalPosition>4</diagonalPosition>
+        </node>
+      </nodes>
+      <metadata>
+        <loopNesting>
+          <loopElements>
+            <loopElement relatedUID="Coordinator">
+              <loopElements>
+                <loopElement relatedUID="Optimizer">
+                  <loopElements>
+                    <loopElement relatedUID="Converger">
+                      <functionElements>
+                        <functionElement>D2</functionElement>
+                        <functionElement>D1</functionElement>
+                      </functionElements>
+                    </loopElement>
+                  </loopElements>
+                  <functionElements>
+                    <functionElement>F1</functionElement>
+                    <functionElement>G1</functionElement>
+                    <functionElement>G2</functionElement>
+                  </functionElements>
+                </loopElement>
+              </loopElements>
+            </loopElement>
+          </loopElements>
+        </loopNesting>
+      </metadata>
+    </processGraph>
+  </workflow>
+  <architectureElements>
+    <parameters>
+      <initialGuessCouplingVariables>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y1">
+          <relatedParameterUID>/dataSchema/analyses/y1</relatedParameterUID>
+          <label>y1^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+      </initialGuessCouplingVariables>
+      <finalCouplingVariables>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y1">
+          <relatedParameterUID>/dataSchema/analyses/y1</relatedParameterUID>
+          <label>y1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+      </finalCouplingVariables>
+      <couplingCopyVariables>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1">
+          <relatedParameterUID>/dataSchema/analyses/y1</relatedParameterUID>
+          <label>y1^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+      </couplingCopyVariables>
+      <initialGuessDesignVariables>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z2">
+          <relatedParameterUID>/dataSchema/geometry/z2</relatedParameterUID>
+          <label>z2^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z1">
+          <relatedParameterUID>/dataSchema/geometry/z1</relatedParameterUID>
+          <label>z1^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/x1">
+          <relatedParameterUID>/dataSchema/geometry/x1</relatedParameterUID>
+          <label>x1^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+      </initialGuessDesignVariables>
+      <finalDesignVariables>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/x1">
+          <relatedParameterUID>/dataSchema/geometry/x1</relatedParameterUID>
+          <label>x1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z1">
+          <relatedParameterUID>/dataSchema/geometry/z1</relatedParameterUID>
+          <label>z1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z2">
+          <relatedParameterUID>/dataSchema/geometry/z2</relatedParameterUID>
+          <label>z2^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+      </finalDesignVariables>
+      <finalOutputVariables>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g1">
+          <relatedParameterUID>/dataSchema/analyses/g1</relatedParameterUID>
+          <label>g1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/f">
+          <relatedParameterUID>/dataSchema/analyses/f</relatedParameterUID>
+          <label>f^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g2">
+          <relatedParameterUID>/dataSchema/analyses/g2</relatedParameterUID>
+          <label>g2^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+      </finalOutputVariables>
+    </parameters>
+    <executableBlocks>
+      <coordinators>
+        <coordinator uID="Coordinator">
+          <label>COOR</label>
+        </coordinator>
+      </coordinators>
+      <optimizers>
+        <optimizer uID="Optimizer">
+          <label>OPT</label>
+          <settings>
+            <package>SciPy</package>
+            <algorithm>SLSQP</algorithm>
+            <maximumIterations>1000</maximumIterations>
+            <maximumFunctionEvaluations>1000</maximumFunctionEvaluations>
+            <convergenceTolerance>1e-06</convergenceTolerance>
+            <constraintTolerance>1e-06</constraintTolerance>
+            <applyScaling>true</applyScaling>
+          </settings>
+          <designVariables>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/geometry/x1</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/geometry/z1</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/geometry/z2</designVariableUID>
+            </designVariable>
+          </designVariables>
+          <objectiveVariables>
+            <objectiveVariable>
+              <objectiveVariableUID>__objVar__/dataSchema/analyses/f</objectiveVariableUID>
+            </objectiveVariable>
+          </objectiveVariables>
+          <constraintVariables>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/analyses/g1</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/analyses/g2</constraintVariableUID>
+            </constraintVariable>
+          </constraintVariables>
+        </optimizer>
+      </optimizers>
+      <convergers>
+        <converger uID="Converger">
+          <label>CONV</label>
+          <settings>
+            <linearSolver>
+              <method>Gauss-Seidel</method>
+              <lastIterationsToConsider>1</lastIterationsToConsider>
+              <maximumIterations>100</maximumIterations>
+              <convergenceToleranceRelative>1e-06</convergenceToleranceRelative>
+              <convergenceToleranceAbsolute>1e-06</convergenceToleranceAbsolute>
+            </linearSolver>
+            <nonlinearSolver>
+              <method>Gauss-Seidel</method>
+              <lastIterationsToConsider>1</lastIterationsToConsider>
+              <maximumIterations>100</maximumIterations>
+              <convergenceToleranceRelative>1e-06</convergenceToleranceRelative>
+              <convergenceToleranceAbsolute>1e-06</convergenceToleranceAbsolute>
+            </nonlinearSolver>
+          </settings>
+        </converger>
+      </convergers>
+      <coupledAnalyses>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>D2</relatedExecutableBlockUID>
+        </coupledAnalysis>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>D1</relatedExecutableBlockUID>
+        </coupledAnalysis>
+      </coupledAnalyses>
+      <postCouplingAnalyses>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>G2</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>G1</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>F1</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+      </postCouplingAnalyses>
+    </executableBlocks>
+  </architectureElements>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/sellar_problem_mdfj.xml b/kadmos/vistoms/downloads/sellar_problem_mdfj.xml
new file mode 100644
index 000000000..41c871ca7
--- /dev/null
+++ b/kadmos/vistoms/downloads/sellar_problem_mdfj.xml
@@ -0,0 +1,858 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>Mdao CMDOWS file of the well-known Sellar problem</description>
+    <timestamp>2018-08-20T15:17:11.787860</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a mdao data graph (MDG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-08-20T15:17:11.787860</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="ivangent">
+          <name>Imco van Gent</name>
+          <email>i.vangent@tudelft.nl</email>
+          <company>TU Delft</company>
+        </contact>
+        <contact uID="lmuller">
+          <name>Lukas Muller</name>
+          <email>l.muller@student.tudelft.nl</email>
+          <company>TU Delft</company>
+        </contact>
+      </contacts>
+      <organigram>
+        <integrators>
+          <integrator>
+            <contactUID>ivangent</contactUID>
+          </integrator>
+        </integrators>
+        <architects>
+          <architect>
+            <contactUID>lmuller</contactUID>
+          </architect>
+          <architect>
+            <contactUID>ivangent</contactUID>
+          </architect>
+        </architects>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="F1">
+        <label>F1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <equationLabel>x1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/f</parameterUID>
+            <equations uID="F1_equation">
+              <equation language="Python">x1**2+z2+y1+exp(-y2)</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/analyses/f</parameterUID>
+            <equationsUID>F1_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="D2">
+        <label>D2</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <equationLabel>z1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equations uID="D2_equation">
+              <equation language="Python">abs(y1)**.5 + z1 + z2</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y2</parameterUID>
+            <equationsUID>D2_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="G2">
+        <label>G2</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/g2</parameterUID>
+            <equations uID="G2_equation">
+              <equation language="Python">1-y2/24.0</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g2</parameterUID>
+            <equationsUID>G2_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="G1">
+        <label>G1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g1</parameterUID>
+            <equations uID="G1_equation">
+              <equation language="Python">y1/3.16-1</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/analyses/g1</parameterUID>
+            <equationsUID>G1_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="D1">
+        <label>D1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <equationLabel>x1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <equationLabel>z1</equationLabel>
+            <validRanges>
+              <limitRange>
+                <minimum>-5</minimum>
+                <maximum>5.0</maximum>
+              </limitRange>
+              <listRange>
+                <listRangeItem>7.5</listRangeItem>
+                <listRangeItem>8</listRangeItem>
+              </listRange>
+            </validRanges>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y1</parameterUID>
+            <equations uID="D1_equation">
+              <equation language="Python">z1**2. + x1 + z2 - .2*y2</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationsUID>D1_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/analyses/g1">
+      <label>g1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/g2">
+      <label>g2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/f">
+      <label>f</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/z1">
+      <label>z1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/z2">
+      <label>z2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/y2">
+      <label>y2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/y1">
+      <label>y1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/x1">
+      <label>x1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <problemDefinition uID="MDFJacobi">
+    <problemFormulation>
+      <mdaoArchitecture>MDF</mdaoArchitecture>
+      <convergerType>Jacobi</convergerType>
+      <executableBlocksOrder>
+        <executableBlock position="1">D2</executableBlock>
+        <executableBlock position="2">D1</executableBlock>
+        <executableBlock position="3">G1</executableBlock>
+        <executableBlock position="4">G2</executableBlock>
+        <executableBlock position="5">F1</executableBlock>
+      </executableBlocksOrder>
+      <allowUnconvergedCouplings>false</allowUnconvergedCouplings>
+    </problemFormulation>
+    <problemRoles>
+      <parameters>
+        <designVariables>
+          <designVariable uID="__desVar__/dataSchema/geometry/z1">
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>-10</minimum>
+                <maximum>10</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/geometry/z2">
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.0</minimum>
+                <maximum>10</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/geometry/x1">
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <nominalValue>0.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.0</minimum>
+                <maximum>10</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+        </designVariables>
+        <objectiveVariables>
+          <objectiveVariable uID="__objVar__/dataSchema/analyses/f">
+            <parameterUID>/dataSchema/analyses/f</parameterUID>
+          </objectiveVariable>
+        </objectiveVariables>
+        <constraintVariables>
+          <constraintVariable uID="__conVar__/dataSchema/analyses/g1">
+            <parameterUID>/dataSchema/analyses/g1</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/analyses/g2">
+            <parameterUID>/dataSchema/analyses/g2</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+        </constraintVariables>
+      </parameters>
+      <executableBlocks>
+        <coupledBlocks>
+          <coupledBlock>D2</coupledBlock>
+          <coupledBlock>D1</coupledBlock>
+        </coupledBlocks>
+        <postCouplingBlocks>
+          <postCouplingBlock>G1</postCouplingBlock>
+          <postCouplingBlock>G2</postCouplingBlock>
+          <postCouplingBlock>F1</postCouplingBlock>
+        </postCouplingBlocks>
+      </executableBlocks>
+    </problemRoles>
+  </problemDefinition>
+  <workflow>
+    <problemDefinitionUID>MDFJacobi</problemDefinitionUID>
+    <dataGraph>
+      <name>XDSM - MDF-J</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g1</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/geometry/x1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/geometry/z1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/geometry/z2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/x1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/g2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/g1</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/g1</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/g2</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/f</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/f</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/f</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/f</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/x1</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>G2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>G1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/y1</toParameterUID>
+        </edge>
+      </edges>
+    </dataGraph>
+    <processGraph>
+      <name>mpg Sellar problem</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>F1</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G2</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G1</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>G2</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>G1</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>1</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+      </edges>
+      <nodes>
+        <node>
+          <referenceUID>F1</referenceUID>
+          <processStepNumber>5</processStepNumber>
+          <diagonalPosition>7</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Optimizer</referenceUID>
+          <processStepNumber>1</processStepNumber>
+          <convergerStepNumber>6</convergerStepNumber>
+          <diagonalPosition>1</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>G2</referenceUID>
+          <processStepNumber>5</processStepNumber>
+          <diagonalPosition>6</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>G1</referenceUID>
+          <processStepNumber>5</processStepNumber>
+          <diagonalPosition>5</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Converger</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <convergerStepNumber>4</convergerStepNumber>
+          <diagonalPosition>2</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Coordinator</referenceUID>
+          <processStepNumber>0</processStepNumber>
+          <convergerStepNumber>7</convergerStepNumber>
+          <diagonalPosition>0</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>D2</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>3</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>D1</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>4</diagonalPosition>
+        </node>
+      </nodes>
+      <metadata>
+        <loopNesting>
+          <loopElements>
+            <loopElement relatedUID="Coordinator">
+              <loopElements>
+                <loopElement relatedUID="Optimizer">
+                  <loopElements>
+                    <loopElement relatedUID="Converger">
+                      <functionElements>
+                        <functionElement>D1</functionElement>
+                        <functionElement>D2</functionElement>
+                      </functionElements>
+                    </loopElement>
+                  </loopElements>
+                  <functionElements>
+                    <functionElement>F1</functionElement>
+                    <functionElement>G1</functionElement>
+                    <functionElement>G2</functionElement>
+                  </functionElements>
+                </loopElement>
+              </loopElements>
+            </loopElement>
+          </loopElements>
+        </loopNesting>
+      </metadata>
+    </processGraph>
+  </workflow>
+  <architectureElements>
+    <parameters>
+      <initialGuessCouplingVariables>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y1">
+          <relatedParameterUID>/dataSchema/analyses/y1</relatedParameterUID>
+          <label>y1^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/analyses/y2">
+          <relatedParameterUID>/dataSchema/analyses/y2</relatedParameterUID>
+          <label>y2^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+      </initialGuessCouplingVariables>
+      <finalCouplingVariables>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y2">
+          <relatedParameterUID>/dataSchema/analyses/y2</relatedParameterUID>
+          <label>y2^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/analyses/y1">
+          <relatedParameterUID>/dataSchema/analyses/y1</relatedParameterUID>
+          <label>y1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+      </finalCouplingVariables>
+      <couplingCopyVariables>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y1">
+          <relatedParameterUID>/dataSchema/analyses/y1</relatedParameterUID>
+          <label>y1^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/analyses/y2">
+          <relatedParameterUID>/dataSchema/analyses/y2</relatedParameterUID>
+          <label>y2^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+      </couplingCopyVariables>
+      <initialGuessDesignVariables>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z2">
+          <relatedParameterUID>/dataSchema/geometry/z2</relatedParameterUID>
+          <label>z2^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/x1">
+          <relatedParameterUID>/dataSchema/geometry/x1</relatedParameterUID>
+          <label>x1^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/geometry/z1">
+          <relatedParameterUID>/dataSchema/geometry/z1</relatedParameterUID>
+          <label>z1^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+      </initialGuessDesignVariables>
+      <finalDesignVariables>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/x1">
+          <relatedParameterUID>/dataSchema/geometry/x1</relatedParameterUID>
+          <label>x1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z1">
+          <relatedParameterUID>/dataSchema/geometry/z1</relatedParameterUID>
+          <label>z1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/geometry/z2">
+          <relatedParameterUID>/dataSchema/geometry/z2</relatedParameterUID>
+          <label>z2^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+      </finalDesignVariables>
+      <finalOutputVariables>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g1">
+          <relatedParameterUID>/dataSchema/analyses/g1</relatedParameterUID>
+          <label>g1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/f">
+          <relatedParameterUID>/dataSchema/analyses/f</relatedParameterUID>
+          <label>f^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/analyses/g2">
+          <relatedParameterUID>/dataSchema/analyses/g2</relatedParameterUID>
+          <label>g2^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+      </finalOutputVariables>
+    </parameters>
+    <executableBlocks>
+      <coordinators>
+        <coordinator uID="Coordinator">
+          <label>COOR</label>
+        </coordinator>
+      </coordinators>
+      <optimizers>
+        <optimizer uID="Optimizer">
+          <label>OPT</label>
+          <settings>
+            <package>SciPy</package>
+            <algorithm>SLSQP</algorithm>
+            <maximumIterations>1000</maximumIterations>
+            <maximumFunctionEvaluations>1000</maximumFunctionEvaluations>
+            <convergenceTolerance>1e-06</convergenceTolerance>
+            <constraintTolerance>1e-06</constraintTolerance>
+            <applyScaling>true</applyScaling>
+          </settings>
+          <designVariables>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/geometry/x1</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/geometry/z1</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/geometry/z2</designVariableUID>
+            </designVariable>
+          </designVariables>
+          <objectiveVariables>
+            <objectiveVariable>
+              <objectiveVariableUID>__objVar__/dataSchema/analyses/f</objectiveVariableUID>
+            </objectiveVariable>
+          </objectiveVariables>
+          <constraintVariables>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/analyses/g1</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/analyses/g2</constraintVariableUID>
+            </constraintVariable>
+          </constraintVariables>
+        </optimizer>
+      </optimizers>
+      <convergers>
+        <converger uID="Converger">
+          <label>CONV</label>
+          <settings>
+            <linearSolver>
+              <method>Jacobi</method>
+              <lastIterationsToConsider>1</lastIterationsToConsider>
+              <maximumIterations>100</maximumIterations>
+              <convergenceToleranceRelative>1e-06</convergenceToleranceRelative>
+              <convergenceToleranceAbsolute>1e-06</convergenceToleranceAbsolute>
+            </linearSolver>
+            <nonlinearSolver>
+              <method>Jacobi</method>
+              <lastIterationsToConsider>1</lastIterationsToConsider>
+              <maximumIterations>100</maximumIterations>
+              <convergenceToleranceRelative>1e-06</convergenceToleranceRelative>
+              <convergenceToleranceAbsolute>1e-06</convergenceToleranceAbsolute>
+            </nonlinearSolver>
+          </settings>
+        </converger>
+      </convergers>
+      <coupledAnalyses>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>D2</relatedExecutableBlockUID>
+        </coupledAnalysis>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>D1</relatedExecutableBlockUID>
+        </coupledAnalysis>
+      </coupledAnalyses>
+      <postCouplingAnalyses>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>G2</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>G1</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>F1</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+      </postCouplingAnalyses>
+    </executableBlocks>
+  </architectureElements>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/sellar_problem_rcg.xml b/kadmos/vistoms/downloads/sellar_problem_rcg.xml
new file mode 100644
index 000000000..1a160657e
--- /dev/null
+++ b/kadmos/vistoms/downloads/sellar_problem_rcg.xml
@@ -0,0 +1,434 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>RCG CMDOWS file of the well-known Sellar problem</description>
+    <timestamp>2018-07-31T15:59:27.917199</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a repository connectivity graph (RCG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-07-31T15:59:27.917199</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="ivangent">
+          <name>Imco van Gent</name>
+          <email>i.vangent@tudelft.nl</email>
+          <company>TU Delft</company>
+        </contact>
+        <contact uID="lmuller">
+          <name>Lukas Muller</name>
+          <email>l.muller@student.tudelft.nl</email>
+          <company>TU Delft</company>
+        </contact>
+      </contacts>
+      <organigram>
+        <integrators>
+          <integrator>
+            <contactUID>ivangent</contactUID>
+          </integrator>
+        </integrators>
+        <architects>
+          <architect>
+            <contactUID>lmuller</contactUID>
+          </architect>
+          <architect>
+            <contactUID>ivangent</contactUID>
+          </architect>
+        </architects>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <designCompetences>
+      <designCompetence uID="F2">
+        <label>F2</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/f</parameterUID>
+          </output>
+        </outputs>
+        <ID>F2</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+      </designCompetence>
+      <designCompetence uID="D3">
+        <label>D3</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+          </output>
+        </outputs>
+        <ID>D3</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+      </designCompetence>
+    </designCompetences>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="A">
+        <label>A</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/settings/a</parameterUID>
+            <equationLabel>a</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/settings/c</parameterUID>
+            <equations uID="A_equation">
+              <equation language="Python">a</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="F1">
+        <label>F1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <equationLabel>x1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/f</parameterUID>
+            <equations uID="F1_equation">
+              <equation language="Python">x1**2+z2+y1+exp(-y2)</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="G2">
+        <label>G2</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/g2</parameterUID>
+            <equations uID="G2_equation">
+              <equation language="Python">1-y2/24.0</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="G1">
+        <label>G1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/g1</parameterUID>
+            <equations uID="G1_equation">
+              <equation language="Python">y1/3.16-1</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="D2">
+        <label>D2</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <equationLabel>z1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/settings/c</parameterUID>
+            <equationLabel>c</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equationLabel>y1</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equations uID="D2_equation">
+              <equation language="Python">abs(y1)**.5 + z1 + z2</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="D1">
+        <label>D1</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/geometry/z1</parameterUID>
+            <equationLabel>z1</equationLabel>
+            <validRanges>
+              <limitRange>
+                <minimum>-5</minimum>
+                <maximum>5.0</maximum>
+              </limitRange>
+              <listRange>
+                <listRangeItem>7.5</listRangeItem>
+                <listRangeItem>8</listRangeItem>
+              </listRange>
+            </validRanges>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/x1</parameterUID>
+            <equationLabel>x1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/analyses/y2</parameterUID>
+            <equationLabel>y2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/settings/c</parameterUID>
+            <equationLabel>c</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/geometry/z2</parameterUID>
+            <equationLabel>z2</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/analyses/y1</parameterUID>
+            <equations uID="D1_equation">
+              <equation language="Python">z1**2. + x1 + z2 - .2*y2</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/geometry/z2">
+      <label>z2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/settings/c">
+      <label>c</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/y1">
+      <label>y1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/x1">
+      <label>x1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/y2">
+      <label>y2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/geometry/z1">
+      <label>z1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/settings/a">
+      <label>a</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/f">
+      <label>f</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/g1">
+      <label>g1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/analyses/g2">
+      <label>g2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <workflow>
+    <dataGraph>
+      <name>Sellar problem graph</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>A</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/settings/c</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/f</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/f</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/g2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>G1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/g1</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>F2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z2</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/settings/a</fromParameterUID>
+          <toExecutableBlockUID>A</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/settings/c</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/settings/c</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>D3</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y1</fromParameterUID>
+          <toExecutableBlockUID>G1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>F2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/x1</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>F1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>D3</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>G2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/analyses/y2</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>F2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>D2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/geometry/z1</fromParameterUID>
+          <toExecutableBlockUID>D1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/y2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D3</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/geometry/x1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D3</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/geometry/z1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D3</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/geometry/z2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>D1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/analyses/y1</toParameterUID>
+        </edge>
+      </edges>
+    </dataGraph>
+  </workflow>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/ssbj_co.xml b/kadmos/vistoms/downloads/ssbj_co.xml
new file mode 100644
index 000000000..90e2042fd
--- /dev/null
+++ b/kadmos/vistoms/downloads/ssbj_co.xml
@@ -0,0 +1,3989 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>Mdao CMDOWS file of the super-sonic business jet test case optimization problem</description>
+    <timestamp>2018-08-23T12:46:36.065943</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a mdao data graph (MDG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-08-23T12:46:36.065943</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="imcovangent">
+          <function>PhD Student</function>
+          <name>Imco van Gent</name>
+          <country>The Netherlands</country>
+          <company>TU Delft</company>
+          <telephone>0031 6 53 89 42 75</telephone>
+          <address>Kluyverweg 1, 2629 HS, Delft</address>
+          <department>Flight Performance and Propulsion</department>
+          <email>i.vangent@tudelft.nl</email>
+        </contact>
+        <contact uID="remilafage">
+          <name>Remi Lafage</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Remi.Lafage@onera.fr</email>
+        </contact>
+        <contact uID="sylvaindubreuil">
+          <name>Sylvain Dubreuil</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Sylvain.Dubreuil@onera.fr</email>
+        </contact>
+      </contacts>
+      <organigram>
+        <architects>
+          <architect>
+            <contactUID>imcovangent</contactUID>
+          </architect>
+        </architects>
+        <integrators>
+          <integrator>
+            <contactUID>imcovangent</contactUID>
+          </integrator>
+        </integrators>
+        <toolSpecialists>
+          <toolSpecialist>
+            <contactUID>remilafage</contactUID>
+          </toolSpecialist>
+          <toolSpecialist>
+            <contactUID>sylvaindubreuil</contactUID>
+          </toolSpecialist>
+        </toolSpecialists>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <designCompetences>
+      <designCompetence uID="StructuralAnalysis">
+        <label>StructuralAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WFO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Nz</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </output>
+        </outputs>
+        <ID>StructuralAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>StructuralAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\structuralanalysis\StructuralAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the StructuralAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PropulsionAnalysis">
+        <label>PropulsionAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WBE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+          </output>
+        </outputs>
+        <ID>PropulsionAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PropulsionAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\propulsionanalysis\PropulsionAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the PropulsionAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="AeroAnalysis">
+        <label>AeroAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/CDmin</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/L</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </output>
+        </outputs>
+        <ID>AeroAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>AeroAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\aeroanalysis\AeroAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the AeroAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PerformanceAnalysis">
+        <label>PerformanceAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+          </output>
+        </outputs>
+        <ID>PerformanceAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PerformanceAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\performanceanalysis\PerformanceAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the PerformanceAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+    </designCompetences>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="F[R]">
+        <label>F[R]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/R/scaler</parameterUID>
+            <equationLabel>R_scaler</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+            <equationLabel>R</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+            <equations uID="F[R]_equation">
+              <equation language="Python">-R/R_scaler</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/R/value</parameterUID>
+            <equationsUID>F[R]_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[LWTbalance]">
+        <label>C[LWTbalance]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</parameterUID>
+            <equationLabel>WT</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</parameterUID>
+            <equationLabel>L</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/LWT/scaler</parameterUID>
+            <equationLabel>scaler</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/LWT/value</parameterUID>
+            <equations uID="C[LWTbalance]_equation">
+              <equation language="Python">(L-WT)/scaler</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/LWT/value</parameterUID>
+            <equationsUID>C[LWTbalance]_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[prop]">
+        <label>C[prop]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/DT/scaler</parameterUID>
+            <equationLabel>DT_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+            <equationLabel>DT</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/ESF/scaler</parameterUID>
+            <equationLabel>ESF_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Temp/scaler</parameterUID>
+            <equationLabel>Temp_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+            <equationLabel>ESF</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+            <equationLabel>Temp</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+            <equations uID="C[prop]_equation">
+              <equation language="Python">Temp/Temp_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/DT/value</parameterUID>
+            <equations uID="C[prop]_equation_1">
+              <equation language="Python">DT/DT_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Temp/value</parameterUID>
+            <equationsUID>C[prop]_equation</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+            <equationsUID>C[prop]_equation_1</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="__J2__">
+        <label>J2</label>
+        <functionType>consistency</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+            <equationLabel>x1_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2</parameterUID>
+            <equationLabel>x4_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2</parameterUID>
+            <equationLabel>x1_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC</parameterUID>
+            <equationLabel>x0_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+            <equationLabel>x2_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF</parameterUID>
+            <equationLabel>x3_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+            <equationLabel>x3_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE</parameterUID>
+            <equationLabel>x2_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+            <equationLabel>x0_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+            <equationLabel>x4_0</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group2/objective</parameterUID>
+            <equations uID="__J2___equation">
+              <equation language="Python">((x0_1-x0_0)**2+(x1_1-x1_0)**2+(x2_1-x2_0)**2+(x3_1-x3_0)**2+(x4_1-x4_0)**2)**0.5</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group2/objective</parameterUID>
+            <equationsUID>__J2___equation</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/distributedArchitectures/group2/objective</parameterUID>
+            <equationsUID>__J2___equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="__J0__">
+        <label>J0</label>
+        <functionType>consistency</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+            <equationLabel>x1_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+            <equationLabel>x2_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc</parameterUID>
+            <equationLabel>x6_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</parameterUID>
+            <equationLabel>x2_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+            <equationLabel>x4_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</parameterUID>
+            <equationLabel>x3_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+            <equationLabel>x6_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+            <equationLabel>x0_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</parameterUID>
+            <equationLabel>x0_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta</parameterUID>
+            <equationLabel>x4_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR</parameterUID>
+            <equationLabel>x5_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF</parameterUID>
+            <equationLabel>x1_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+            <equationLabel>x5_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+            <equationLabel>x3_0</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group0/objective</parameterUID>
+            <equations uID="__J0___equation">
+              <equation language="Python">((x0_1-x0_0)**2+(x1_1-x1_0)**2+(x2_1-x2_0)**2+(x3_1-x3_0)**2+(x4_1-x4_0)**2+(x5_1-x5_0)**2+(x6_1-x6_0)**2)**0.5</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/distributedArchitectures/group0/objective</parameterUID>
+            <equationsUID>__J0___equation</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group0/objective</parameterUID>
+            <equationsUID>__J0___equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[dpdx]">
+        <label>C[dpdx]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+            <equationLabel>dpdx</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/dpdx/scaler</parameterUID>
+            <equationLabel>dpdx_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+            <equations uID="C[dpdx]_equation">
+              <equation language="Python">dpdx/dpdx_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/dpdx/value</parameterUID>
+            <equationsUID>C[dpdx]_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[sigmas]">
+        <label>C[sigmas]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma4/scaler</parameterUID>
+            <equationLabel>sigma4_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+            <equationLabel>sigma4</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+            <equationLabel>sigma1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+            <equationLabel>sigma3</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+            <equationLabel>sigma2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma3/scaler</parameterUID>
+            <equationLabel>sigma3_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma2/scaler</parameterUID>
+            <equationLabel>sigma2_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma1/scaler</parameterUID>
+            <equationLabel>sigma1_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+            <equationLabel>sigma5</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma5/scaler</parameterUID>
+            <equationLabel>sigma5_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+            <equations uID="C[sigmas]_equation">
+              <equation language="Python">sigma1/sigma1_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma5/value</parameterUID>
+            <equations uID="C[sigmas]_equation_1">
+              <equation language="Python">sigma5/sigma5_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+            <equations uID="C[sigmas]_equation_2">
+              <equation language="Python">sigma2/sigma2_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+            <equations uID="C[sigmas]_equation_3">
+              <equation language="Python">sigma3/sigma3_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma3/value</parameterUID>
+            <equationsUID>C[sigmas]_equation_3</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+            <equationsUID>C[sigmas]_equation_1</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma2/value</parameterUID>
+            <equationsUID>C[sigmas]_equation_2</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma1/value</parameterUID>
+            <equationsUID>C[sigmas]_equation</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+            <equations uID="C[sigmas]_equation_4">
+              <equation language="Python">sigma4/sigma4_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma4/value</parameterUID>
+            <equationsUID>C[sigmas]_equation_4</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="__J1__">
+        <label>J1</label>
+        <functionType>consistency</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2</parameterUID>
+            <equationLabel>x2_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</parameterUID>
+            <equationLabel>x6_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+            <equationLabel>x1_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M</parameterUID>
+            <equationLabel>x8_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+            <equationLabel>x4_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D</parameterUID>
+            <equationLabel>x1_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h</parameterUID>
+            <equationLabel>x4_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/L</parameterUID>
+            <equationLabel>x6_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+            <equationLabel>x7_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+            <equationLabel>x8_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+            <equationLabel>x0_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2</parameterUID>
+            <equationLabel>x5_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+            <equationLabel>x2_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+            <equationLabel>x3_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2</parameterUID>
+            <equationLabel>x7_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+            <equationLabel>x5_0</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2</parameterUID>
+            <equationLabel>x0_1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin</parameterUID>
+            <equationLabel>x3_1</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/distributedArchitectures/group1/objective</parameterUID>
+            <equations uID="__J1___equation">
+              <equation language="Python">((x0_1-x0_0)**2+(x1_1-x1_0)**2+(x2_1-x2_0)**2+(x3_1-x3_0)**2+(x4_1-x4_0)**2+(x5_1-x5_0)**2+(x6_1-x6_0)**2+(x7_1-x7_0)**2+(x8_1-x8_0)**2)**0.5</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group1/objective</parameterUID>
+            <equationsUID>__J1___equation</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group1/objective</parameterUID>
+            <equationsUID>__J1___equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/aircraft/other/DT">
+      <label>DT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/fin">
+      <label>fin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WO">
+      <label>WO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/L">
+      <label>L</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Theta">
+      <label>Theta</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/CDmin">
+      <label>CDmin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/T">
+      <label>T</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/LWT/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Cf">
+      <label>Cf</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WFO">
+      <label>WFO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma5">
+      <label>sigma5</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma4">
+      <label>sigma4</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma1">
+      <label>sigma1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma3">
+      <label>sigma3</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma2">
+      <label>sigma2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/D">
+      <label>D</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/R">
+      <label>R</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/section">
+      <label>section</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/Temp">
+      <label>Temp</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/dpdx">
+      <label>dpdx</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/distributedArchitectures/group2/objective">
+      <label>J2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WBE">
+      <label>WBE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/distributedArchitectures/group1/objective">
+      <label>J1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/SFC">
+      <label>SFC</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Nz">
+      <label>Nz</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WT">
+      <label>WT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WF">
+      <label>WF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WE">
+      <label>WE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/LWT/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/distributedArchitectures/group0/objective">
+      <label>J0</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/lambda">
+      <label>lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/AR">
+      <label>AR</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Lambda">
+      <label>Lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/ESF">
+      <label>ESF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/tc">
+      <label>tc</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/M">
+      <label>M</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Sref">
+      <label>Sref</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/h">
+      <label>h</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <problemDefinition uID="CONone">
+    <problemFormulation>
+      <mdaoArchitecture>CO</mdaoArchitecture>
+      <executableBlocksOrder>
+        <executableBlock position="1">StructuralAnalysis</executableBlock>
+        <executableBlock position="2">AeroAnalysis</executableBlock>
+        <executableBlock position="3">PropulsionAnalysis</executableBlock>
+        <executableBlock position="4">PerformanceAnalysis</executableBlock>
+        <executableBlock position="5">C[sigmas]</executableBlock>
+        <executableBlock position="6">C[dpdx]</executableBlock>
+        <executableBlock position="7">C[prop]</executableBlock>
+        <executableBlock position="8">C[LWTbalance]</executableBlock>
+        <executableBlock position="9">F[R]</executableBlock>
+      </executableBlocksOrder>
+      <allowUnconvergedCouplings>false</allowUnconvergedCouplings>
+    </problemFormulation>
+    <problemRoles>
+      <parameters>
+        <designVariables>
+          <designVariable uID="__desVar__/dataSchema/aircraft/other/T">
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+            <nominalValue>0.2</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.09</minimum>
+                <maximum>0.905</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/other/Cf">
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+            <nominalValue>1.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.75</minimum>
+                <maximum>1.25</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/section">
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+            <nominalValue>1.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.75</minimum>
+                <maximum>1.25</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/lambda">
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+            <nominalValue>0.25</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.1</minimum>
+                <maximum>0.4</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2</parameterUID>
+            <nominalValue>1.6</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>1.4</minimum>
+                <maximum>1.8</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/AR">
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+            <nominalValue>5.5</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>2.475</minimum>
+                <maximum>7.975</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</parameterUID>
+            <validRanges>
+              <limitRange>
+                <minimum>20000.0</minimum>
+                <maximum>80000.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D</parameterUID>
+            <validRanges>
+              <limitRange>
+                <minimum>1000.0</minimum>
+                <maximum>15000.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M</parameterUID>
+            <nominalValue>1.6</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>1.4</minimum>
+                <maximum>1.8</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin</parameterUID>
+            <validRanges>
+              <limitRange>
+                <minimum>2.0</minimum>
+                <maximum>12.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h</parameterUID>
+            <nominalValue>45000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>30000.0</minimum>
+                <maximum>60000.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta</parameterUID>
+            <validRanges>
+              <limitRange>
+                <minimum>0.96</minimum>
+                <maximum>1.04</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC</parameterUID>
+            <validRanges>
+              <limitRange>
+                <minimum>0.5</minimum>
+                <maximum>1.5</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2</parameterUID>
+            <nominalValue>55.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>39.6</minimum>
+                <maximum>69.85</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2</parameterUID>
+            <nominalValue>1000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>500.0</minimum>
+                <maximum>1500.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc</parameterUID>
+            <nominalValue>0.05</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.01</minimum>
+                <maximum>0.09</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/Lambda">
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+            <nominalValue>55.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>39.6</minimum>
+                <maximum>69.85</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2</parameterUID>
+            <nominalValue>0.05</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.01</minimum>
+                <maximum>0.09</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/tc">
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+            <nominalValue>0.05</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.01</minimum>
+                <maximum>0.09</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/reference/M">
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+            <nominalValue>1.6</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>1.4</minimum>
+                <maximum>1.8</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2</parameterUID>
+            <nominalValue>5.5</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>2.475</minimum>
+                <maximum>7.975</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/Sref">
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+            <nominalValue>1000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>500.0</minimum>
+                <maximum>1500.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/reference/h">
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+            <nominalValue>45000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>30000.0</minimum>
+                <maximum>60000.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</parameterUID>
+            <nominalValue>55.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>39.6</minimum>
+                <maximum>69.85</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</parameterUID>
+            <validRanges>
+              <limitRange>
+                <minimum>20000.0</minimum>
+                <maximum>80000.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2</parameterUID>
+            <nominalValue>45000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>30000.0</minimum>
+                <maximum>60000.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR</parameterUID>
+            <nominalValue>5.5</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>2.475</minimum>
+                <maximum>7.975</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE</parameterUID>
+            <validRanges>
+              <limitRange>
+                <minimum>0.0</minimum>
+                <maximum>20000.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF</parameterUID>
+            <validRanges>
+              <limitRange>
+                <minimum>5000.0</minimum>
+                <maximum>25000.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</parameterUID>
+            <nominalValue>1000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>500.0</minimum>
+                <maximum>1500.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF">
+            <parameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF</parameterUID>
+            <validRanges>
+              <limitRange>
+                <minimum>0.5</minimum>
+                <maximum>1.5</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+        </designVariables>
+        <objectiveVariables>
+          <objectiveVariable uID="__objVar__/dataSchema/scaledData/R/value">
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+          </objectiveVariable>
+          <objectiveVariable uID="__objVar__/dataSchema/distributedArchitectures/group2/objective">
+            <parameterUID>/dataSchema/distributedArchitectures/group2/objective</parameterUID>
+          </objectiveVariable>
+          <objectiveVariable uID="__objVar__/dataSchema/distributedArchitectures/group1/objective">
+            <parameterUID>/dataSchema/distributedArchitectures/group1/objective</parameterUID>
+          </objectiveVariable>
+          <objectiveVariable uID="__objVar__/dataSchema/distributedArchitectures/group0/objective">
+            <parameterUID>/dataSchema/distributedArchitectures/group0/objective</parameterUID>
+          </objectiveVariable>
+        </objectiveVariables>
+        <constraintVariables>
+          <constraintVariable uID="__conVar__/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group0/objective">
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group0/objective</parameterUID>
+            <constraintType>equality</constraintType>
+            <constraintOperator>==</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group2/objective">
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group2/objective</parameterUID>
+            <constraintType>equality</constraintType>
+            <constraintOperator>==</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/dpdx/value">
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.04</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/LWT/value">
+            <parameterUID>/dataSchema/scaledData/LWT/value</parameterUID>
+            <constraintType>equality</constraintType>
+            <constraintOperator>==</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma2/value">
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/Temp/value">
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.02</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group1/objective">
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group1/objective</parameterUID>
+            <constraintType>equality</constraintType>
+            <constraintOperator>==</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma5/value">
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma4/value">
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma1/value">
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/DT/value">
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma3/value">
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+        </constraintVariables>
+      </parameters>
+      <executableBlocks>
+        <postCouplingBlocks>
+          <postCouplingBlock>PropulsionAnalysis</postCouplingBlock>
+          <postCouplingBlock>AeroAnalysis</postCouplingBlock>
+          <postCouplingBlock>StructuralAnalysis</postCouplingBlock>
+          <postCouplingBlock>PerformanceAnalysis</postCouplingBlock>
+          <postCouplingBlock>C[sigmas]</postCouplingBlock>
+          <postCouplingBlock>C[dpdx]</postCouplingBlock>
+          <postCouplingBlock>C[prop]</postCouplingBlock>
+          <postCouplingBlock>C[LWTbalance]</postCouplingBlock>
+          <postCouplingBlock>F[R]</postCouplingBlock>
+        </postCouplingBlocks>
+      </executableBlocks>
+    </problemRoles>
+  </problemDefinition>
+  <workflow>
+    <problemDefinitionUID>CONone</problemDefinitionUID>
+    <dataGraph>
+      <name>XDSM - CO</name>
+      <edges>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group0/objective</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2</fromParameterUID>
+          <toExecutableBlockUID>__J2__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/DT</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/value</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/scaler</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/fin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/dpdx</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/fin</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group0/objective</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>C[LWTbalance]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/CDmin</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WBE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/Cf</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/Nz</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WFO</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/section</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/LWT/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WO</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/CDmin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/T</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/ESF/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma2/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>__J1__</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/distributedArchitectures/group1/objective</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>__J1__</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group1/objective</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>__J1__</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group1/objective</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group2/objective</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/value</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/LWT/value</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>__J2__</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group2/objective</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>__J2__</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group2/objective</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>__J2__</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/distributedArchitectures/group2/objective</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma5/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WFO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/R/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/h</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/value</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma5</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma4</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma1</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma3</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma2</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC</fromParameterUID>
+          <toExecutableBlockUID>__J2__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/value</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma5</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma4</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma3</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/R/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[LWTbalance]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/LWT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[LWTbalance]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/LWT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/DT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Temp/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group1/objective</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/R</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/value</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group2/objective</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/section</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/section</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/Cf</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/Cf</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/T</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-2</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/T</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>__J2__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/value</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/value</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/R</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/dpdx/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma4/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/value</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/SFC</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/DT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/Temp</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/M</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/Temp</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/dpdx</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/distributedArchitectures/group2/objective</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WBE</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>__J2__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/distributedArchitectures/group1/objective</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/SFC</fromParameterUID>
+          <toExecutableBlockUID>__J2__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/dpdx/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Nz</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>__J0__</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group0/objective</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>__J0__</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/distributedArchitectures/group0/objective</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>__J0__</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group0/objective</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Temp/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-1</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>__J2__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma5/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma3/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma2/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma1/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma4/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>C[LWTbalance]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/h</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma3/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2</fromParameterUID>
+          <toExecutableBlockUID>__J2__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WF</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/LWT/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>__J2__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/LWT/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[LWTbalance]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>__J2__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group1/objective</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-2</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/DT/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/distributedArchitectures/group0/objective</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/M</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/ESF/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>__J2__</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/value</fromParameterUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma1/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+        </edge>
+      </edges>
+    </dataGraph>
+    <processGraph>
+      <name>XDSM - CO</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[LWTbalance]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[LWTbalance]</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sub-Optimizer-1</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sub-Optimizer-2</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sys-Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>__J2__</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-0</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sub-Optimizer-2</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>__J2__</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sub-Optimizer-2</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-1</fromExecutableBlockUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>__J0__</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+          <processStepNumber>1</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-2</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sys-Optimizer</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Sub-Optimizer-2</fromExecutableBlockUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sub-Optimizer-1</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>__J1__</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sub-Optimizer-0</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>__J1__</fromExecutableBlockUID>
+          <toExecutableBlockUID>Sub-Optimizer-1</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>__J0__</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+      </edges>
+      <nodes>
+        <node>
+          <referenceUID>F[R]</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>4</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[LWTbalance]</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <diagonalPosition>3</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Sys-Optimizer</referenceUID>
+          <processStepNumber>1</processStepNumber>
+          <convergerStepNumber>6</convergerStepNumber>
+          <diagonalPosition>1</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>PropulsionAnalysis</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>14</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Sub-Optimizer-0</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <convergerStepNumber>5</convergerStepNumber>
+          <diagonalPosition>5</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[prop]</referenceUID>
+          <processStepNumber>4</processStepNumber>
+          <diagonalPosition>15</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>__J2__</referenceUID>
+          <processStepNumber>4</processStepNumber>
+          <diagonalPosition>16</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Sub-Optimizer-1</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <convergerStepNumber>5</convergerStepNumber>
+          <diagonalPosition>9</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>__J0__</referenceUID>
+          <processStepNumber>4</processStepNumber>
+          <diagonalPosition>8</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Coordinator</referenceUID>
+          <processStepNumber>0</processStepNumber>
+          <convergerStepNumber>7</convergerStepNumber>
+          <diagonalPosition>0</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Sub-Optimizer-2</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <convergerStepNumber>5</convergerStepNumber>
+          <diagonalPosition>13</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[dpdx]</referenceUID>
+          <processStepNumber>4</processStepNumber>
+          <diagonalPosition>11</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>AeroAnalysis</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>10</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[sigmas]</referenceUID>
+          <processStepNumber>4</processStepNumber>
+          <diagonalPosition>7</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>__J1__</referenceUID>
+          <processStepNumber>4</processStepNumber>
+          <diagonalPosition>12</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>StructuralAnalysis</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>6</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>PerformanceAnalysis</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <diagonalPosition>2</diagonalPosition>
+        </node>
+      </nodes>
+      <metadata>
+        <loopNesting>
+          <loopElements>
+            <loopElement relatedUID="Coordinator">
+              <loopElements>
+                <loopElement relatedUID="Sys-Optimizer">
+                  <loopElements>
+                    <loopElement relatedUID="Sub-Optimizer-0">
+                      <functionElements>
+                        <functionElement>StructuralAnalysis</functionElement>
+                        <functionElement>C[sigmas]</functionElement>
+                        <functionElement>__J0__</functionElement>
+                      </functionElements>
+                    </loopElement>
+                    <loopElement relatedUID="Sub-Optimizer-1">
+                      <functionElements>
+                        <functionElement>AeroAnalysis</functionElement>
+                        <functionElement>C[dpdx]</functionElement>
+                        <functionElement>__J1__</functionElement>
+                      </functionElements>
+                    </loopElement>
+                    <loopElement relatedUID="Sub-Optimizer-2">
+                      <functionElements>
+                        <functionElement>PropulsionAnalysis</functionElement>
+                        <functionElement>C[prop]</functionElement>
+                        <functionElement>__J2__</functionElement>
+                      </functionElements>
+                    </loopElement>
+                  </loopElements>
+                  <functionElements>
+                    <functionElement>C[LWTbalance]</functionElement>
+                    <functionElement>PerformanceAnalysis</functionElement>
+                    <functionElement>F[R]</functionElement>
+                  </functionElements>
+                </loopElement>
+              </loopElements>
+            </loopElement>
+          </loopElements>
+        </loopNesting>
+      </metadata>
+    </processGraph>
+  </workflow>
+  <architectureElements>
+    <parameters>
+      <initialGuessDesignVariables>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/Cf">
+          <relatedParameterUID>/dataSchema/aircraft/other/Cf</relatedParameterUID>
+          <label>Cf^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Lambda</relatedParameterUID>
+          <label>Lambda^{c,i2,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D">
+          <relatedParameterUID>/dataSchema/aircraft/other/D</relatedParameterUID>
+          <label>D^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/tc">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/tc</relatedParameterUID>
+          <label>tc^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Theta</relatedParameterUID>
+          <label>Theta^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/AR</relatedParameterUID>
+          <label>AR^{c,i2,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/h">
+          <relatedParameterUID>/dataSchema/reference/h</relatedParameterUID>
+          <label>h^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/section">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/section</relatedParameterUID>
+          <label>section^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WT</relatedParameterUID>
+          <label>WT^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WF</relatedParameterUID>
+          <label>WF^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/tc</relatedParameterUID>
+          <label>tc^{c,i2,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/tc</relatedParameterUID>
+          <label>tc^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/T">
+          <relatedParameterUID>/dataSchema/aircraft/other/T</relatedParameterUID>
+          <label>T^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin">
+          <relatedParameterUID>/dataSchema/aircraft/other/fin</relatedParameterUID>
+          <label>fin^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC">
+          <relatedParameterUID>/dataSchema/aircraft/other/SFC</relatedParameterUID>
+          <label>SFC^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2">
+          <relatedParameterUID>/dataSchema/reference/M</relatedParameterUID>
+          <label>M^{c,i2,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/AR">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/AR</relatedParameterUID>
+          <label>AR^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Lambda</relatedParameterUID>
+          <label>Lambda^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Lambda</relatedParameterUID>
+          <label>Lambda^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/AR</relatedParameterUID>
+          <label>AR^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h">
+          <relatedParameterUID>/dataSchema/reference/h</relatedParameterUID>
+          <label>h^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/M">
+          <relatedParameterUID>/dataSchema/reference/M</relatedParameterUID>
+          <label>M^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M">
+          <relatedParameterUID>/dataSchema/reference/M</relatedParameterUID>
+          <label>M^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/lambda</relatedParameterUID>
+          <label>lambda^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Sref</relatedParameterUID>
+          <label>Sref^{c,i2,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Sref</relatedParameterUID>
+          <label>Sref^{c,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2">
+          <relatedParameterUID>/dataSchema/reference/h</relatedParameterUID>
+          <label>h^{c,i2,0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Sref">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Sref</relatedParameterUID>
+          <label>Sref^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+      </initialGuessDesignVariables>
+      <finalDesignVariables>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Sref">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Sref</relatedParameterUID>
+          <label>Sref^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC">
+          <relatedParameterUID>/dataSchema/aircraft/other/SFC</relatedParameterUID>
+          <label>SFC^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/Cf">
+          <relatedParameterUID>/dataSchema/aircraft/other/Cf</relatedParameterUID>
+          <label>Cf^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Sref</relatedParameterUID>
+          <label>Sref^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/tc">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/tc</relatedParameterUID>
+          <label>tc^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2">
+          <relatedParameterUID>/dataSchema/reference/M</relatedParameterUID>
+          <label>M^{c,i2,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/AR">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/AR</relatedParameterUID>
+          <label>AR^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h">
+          <relatedParameterUID>/dataSchema/reference/h</relatedParameterUID>
+          <label>h^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/tc</relatedParameterUID>
+          <label>tc^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/tc</relatedParameterUID>
+          <label>tc^{c,i2,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M">
+          <relatedParameterUID>/dataSchema/reference/M</relatedParameterUID>
+          <label>M^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Theta</relatedParameterUID>
+          <label>Theta^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Sref</relatedParameterUID>
+          <label>Sref^{c,i2,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/lambda</relatedParameterUID>
+          <label>lambda^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/T">
+          <relatedParameterUID>/dataSchema/aircraft/other/T</relatedParameterUID>
+          <label>T^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/AR</relatedParameterUID>
+          <label>AR^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/section">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/section</relatedParameterUID>
+          <label>section^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Lambda</relatedParameterUID>
+          <label>Lambda^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D">
+          <relatedParameterUID>/dataSchema/aircraft/other/D</relatedParameterUID>
+          <label>D^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2">
+          <relatedParameterUID>/dataSchema/reference/h</relatedParameterUID>
+          <label>h^{c,i2,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/AR</relatedParameterUID>
+          <label>AR^{c,i2,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Lambda</relatedParameterUID>
+          <label>Lambda^{c,i2,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WF</relatedParameterUID>
+          <label>WF^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/h">
+          <relatedParameterUID>/dataSchema/reference/h</relatedParameterUID>
+          <label>h^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WT</relatedParameterUID>
+          <label>WT^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/M">
+          <relatedParameterUID>/dataSchema/reference/M</relatedParameterUID>
+          <label>M^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Lambda</relatedParameterUID>
+          <label>Lambda^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin">
+          <relatedParameterUID>/dataSchema/aircraft/other/fin</relatedParameterUID>
+          <label>fin^{c,*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+      </finalDesignVariables>
+      <finalOutputVariables>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group0/objective">
+          <relatedParameterUID>/dataSchema/distributedArchitectures/group0/objective</relatedParameterUID>
+          <label>J0^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group0/objective">
+          <relatedParameterUID>/dataSchema/distributedArchitectures/group0/objective</relatedParameterUID>
+          <label>J0^{*,*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma2/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma2/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group2/objective">
+          <relatedParameterUID>/dataSchema/distributedArchitectures/group2/objective</relatedParameterUID>
+          <label>J2^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma5/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma5/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/R/value">
+          <relatedParameterUID>/dataSchema/scaledData/R/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group1/objective">
+          <relatedParameterUID>/dataSchema/distributedArchitectures/group1/objective</relatedParameterUID>
+          <label>J1^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group2/objective">
+          <relatedParameterUID>/dataSchema/distributedArchitectures/group2/objective</relatedParameterUID>
+          <label>J2^{*,*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma4/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma4/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/dpdx/value">
+          <relatedParameterUID>/dataSchema/scaledData/dpdx/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Temp/value">
+          <relatedParameterUID>/dataSchema/scaledData/Temp/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma3/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma3/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/LWT/value">
+          <relatedParameterUID>/dataSchema/scaledData/LWT/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group1/objective">
+          <relatedParameterUID>/dataSchema/distributedArchitectures/group1/objective</relatedParameterUID>
+          <label>J1^{*,*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/DT/value">
+          <relatedParameterUID>/dataSchema/scaledData/DT/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma1/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma1/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+      </finalOutputVariables>
+      <copyDesignVariables>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2">
+          <relatedInstanceUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M</relatedInstanceUID>
+          <label>M^{c,i2}</label>
+          <instanceID>2</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D">
+          <relatedParameterUID>/dataSchema/aircraft/other/D</relatedParameterUID>
+          <label>D^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M">
+          <relatedParameterUID>/dataSchema/reference/M</relatedParameterUID>
+          <label>M^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin">
+          <relatedParameterUID>/dataSchema/aircraft/other/fin</relatedParameterUID>
+          <label>fin^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h">
+          <relatedParameterUID>/dataSchema/reference/h</relatedParameterUID>
+          <label>h^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Theta</relatedParameterUID>
+          <label>Theta^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC">
+          <relatedParameterUID>/dataSchema/aircraft/other/SFC</relatedParameterUID>
+          <label>SFC^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2">
+          <relatedInstanceUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</relatedInstanceUID>
+          <label>Lambda^{c,i2}</label>
+          <instanceID>2</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2">
+          <relatedInstanceUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</relatedInstanceUID>
+          <label>Sref^{c,i2}</label>
+          <instanceID>2</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/tc</relatedParameterUID>
+          <label>tc^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2">
+          <relatedInstanceUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc</relatedInstanceUID>
+          <label>tc^{c,i2}</label>
+          <instanceID>2</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2">
+          <relatedInstanceUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR</relatedInstanceUID>
+          <label>AR^{c,i2}</label>
+          <instanceID>2</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Lambda</relatedParameterUID>
+          <label>Lambda^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WT</relatedParameterUID>
+          <label>WT^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2">
+          <relatedInstanceUID>/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h</relatedInstanceUID>
+          <label>h^{c,i2}</label>
+          <instanceID>2</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/AR</relatedParameterUID>
+          <label>AR^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WF</relatedParameterUID>
+          <label>WF^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Sref</relatedParameterUID>
+          <label>Sref^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+        <copyDesignVariable uID="/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{c}</label>
+          <instanceID>1</instanceID>
+        </copyDesignVariable>
+      </copyDesignVariables>
+    </parameters>
+    <executableBlocks>
+      <coordinators>
+        <coordinator uID="Coordinator">
+          <label>COOR</label>
+        </coordinator>
+      </coordinators>
+      <optimizers>
+        <optimizer uID="Sys-Optimizer">
+          <label>Sys-OPT</label>
+          <settings>
+            <package>pyOptSparse</package>
+            <algorithm>SLSQP</algorithm>
+            <maximumIterations>1000</maximumIterations>
+            <maximumFunctionEvaluations>1000</maximumFunctionEvaluations>
+            <convergenceTolerance>1e-06</convergenceTolerance>
+            <constraintTolerance>1e-06</constraintTolerance>
+            <applyScaling>true</applyScaling>
+          </settings>
+          <designVariables>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/L</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WT</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/reference/h</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/D</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/tc</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/reference/M</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/Lambda</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/SFC</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/ESF</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/Sref</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WE</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/weight/WF</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/AR</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/other/fin</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Theta</designVariableUID>
+            </designVariable>
+          </designVariables>
+          <objectiveVariables>
+            <objectiveVariable>
+              <objectiveVariableUID>__objVar__/dataSchema/scaledData/R/value</objectiveVariableUID>
+            </objectiveVariable>
+          </objectiveVariables>
+          <constraintVariables>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group0/objective</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group2/objective</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/LWT/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/distributedArchitectures/group1/objective</constraintVariableUID>
+            </constraintVariable>
+          </constraintVariables>
+        </optimizer>
+        <optimizer uID="Sub-Optimizer-0">
+          <label>Sub-OPT-0</label>
+          <settings>
+            <package>SciPy</package>
+            <algorithm>SLSQP</algorithm>
+            <maximumIterations>1000</maximumIterations>
+            <maximumFunctionEvaluations>1000</maximumFunctionEvaluations>
+            <convergenceTolerance>1e-06</convergenceTolerance>
+            <constraintTolerance>1e-06</constraintTolerance>
+            <applyScaling>true</applyScaling>
+          </settings>
+          <designVariables>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/lambda</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/section</designVariableUID>
+            </designVariable>
+          </designVariables>
+          <objectiveVariables>
+            <objectiveVariable>
+              <objectiveVariableUID>__objVar__/dataSchema/distributedArchitectures/group0/objective</objectiveVariableUID>
+            </objectiveVariable>
+          </objectiveVariables>
+          <constraintVariables>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma1/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma4/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma5/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma2/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma3/value</constraintVariableUID>
+            </constraintVariable>
+          </constraintVariables>
+        </optimizer>
+        <optimizer uID="Sub-Optimizer-1">
+          <label>Sub-OPT-1</label>
+          <settings>
+            <package>SciPy</package>
+            <algorithm>SLSQP</algorithm>
+            <maximumIterations>1000</maximumIterations>
+            <maximumFunctionEvaluations>1000</maximumFunctionEvaluations>
+            <convergenceTolerance>1e-06</convergenceTolerance>
+            <constraintTolerance>1e-06</constraintTolerance>
+            <applyScaling>true</applyScaling>
+          </settings>
+          <designVariables>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/other/Cf</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Sref__i2</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/AR__i2</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/tc__i2</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda__i2</designVariableUID>
+            </designVariable>
+          </designVariables>
+          <objectiveVariables>
+            <objectiveVariable>
+              <objectiveVariableUID>__objVar__/dataSchema/distributedArchitectures/group1/objective</objectiveVariableUID>
+            </objectiveVariable>
+          </objectiveVariables>
+          <constraintVariables>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/dpdx/value</constraintVariableUID>
+            </constraintVariable>
+          </constraintVariables>
+        </optimizer>
+        <optimizer uID="Sub-Optimizer-2">
+          <label>Sub-OPT-2</label>
+          <settings>
+            <package>SciPy</package>
+            <algorithm>SLSQP</algorithm>
+            <maximumIterations>1000</maximumIterations>
+            <maximumFunctionEvaluations>1000</maximumFunctionEvaluations>
+            <convergenceTolerance>1e-06</convergenceTolerance>
+            <constraintTolerance>1e-06</constraintTolerance>
+            <applyScaling>true</applyScaling>
+          </settings>
+          <designVariables>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/other/T</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/M__i2</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/architectureNodes/copyDesignVariables/dataSchemaCopy/reference/h__i2</designVariableUID>
+            </designVariable>
+          </designVariables>
+          <objectiveVariables>
+            <objectiveVariable>
+              <objectiveVariableUID>__objVar__/dataSchema/distributedArchitectures/group2/objective</objectiveVariableUID>
+            </objectiveVariable>
+          </objectiveVariables>
+          <constraintVariables>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/Temp/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/DT/value</constraintVariableUID>
+            </constraintVariable>
+          </constraintVariables>
+        </optimizer>
+      </optimizers>
+      <postCouplingAnalyses>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>AeroAnalysis</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>__J1__</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>__J2__</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>StructuralAnalysis</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>F[R]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[LWTbalance]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[prop]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>PerformanceAnalysis</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[dpdx]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>PropulsionAnalysis</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>__J0__</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[sigmas]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+      </postCouplingAnalyses>
+    </executableBlocks>
+  </architectureElements>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/ssbj_doegs.xml b/kadmos/vistoms/downloads/ssbj_doegs.xml
new file mode 100644
index 000000000..78bb06ff8
--- /dev/null
+++ b/kadmos/vistoms/downloads/ssbj_doegs.xml
@@ -0,0 +1,2334 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>Mdao CMDOWS file of the super-sonic business jet test case optimization problem</description>
+    <timestamp>2018-08-21T14:14:28.234958</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a mdao data graph (MDG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-08-21T14:14:28.234958</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="imcovangent">
+          <function>PhD Student</function>
+          <name>Imco van Gent</name>
+          <country>The Netherlands</country>
+          <company>TU Delft</company>
+          <telephone>0031 6 53 89 42 75</telephone>
+          <address>Kluyverweg 1, 2629 HS, Delft</address>
+          <department>Flight Performance and Propulsion</department>
+          <email>i.vangent@tudelft.nl</email>
+        </contact>
+        <contact uID="remilafage">
+          <name>Remi Lafage</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Remi.Lafage@onera.fr</email>
+        </contact>
+        <contact uID="sylvaindubreuil">
+          <name>Sylvain Dubreuil</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Sylvain.Dubreuil@onera.fr</email>
+        </contact>
+      </contacts>
+      <organigram>
+        <architects>
+          <architect>
+            <contactUID>imcovangent</contactUID>
+          </architect>
+        </architects>
+        <integrators>
+          <integrator>
+            <contactUID>imcovangent</contactUID>
+          </integrator>
+        </integrators>
+        <toolSpecialists>
+          <toolSpecialist>
+            <contactUID>remilafage</contactUID>
+          </toolSpecialist>
+          <toolSpecialist>
+            <contactUID>sylvaindubreuil</contactUID>
+          </toolSpecialist>
+        </toolSpecialists>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <designCompetences>
+      <designCompetence uID="StructuralAnalysis">
+        <label>StructuralAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WFO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Nz</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </output>
+        </outputs>
+        <ID>StructuralAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>StructuralAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\structuralanalysis\StructuralAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the StructuralAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PropulsionAnalysis">
+        <label>PropulsionAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WBE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </output>
+        </outputs>
+        <ID>PropulsionAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PropulsionAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\propulsionanalysis\PropulsionAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the PropulsionAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="AeroAnalysis">
+        <label>AeroAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/CDmin</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/L</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </output>
+        </outputs>
+        <ID>AeroAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>AeroAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\aeroanalysis\AeroAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the AeroAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PerformanceAnalysis">
+        <label>PerformanceAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+          </output>
+        </outputs>
+        <ID>PerformanceAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PerformanceAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\performanceanalysis\PerformanceAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the PerformanceAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+    </designCompetences>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="F[R]">
+        <label>F[R]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/R/scaler</parameterUID>
+            <equationLabel>R_scaler</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+            <equationLabel>R</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+            <equations uID="F[R]_equation">
+              <equation language="Python">-R/R_scaler</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[Theta]">
+        <label>C[Theta]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Theta/scaler</parameterUID>
+            <equationLabel>Theta_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+            <equationLabel>Theta</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+            <equations uID="C[Theta]_equation">
+              <equation language="Python">Theta/Theta_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[dpdx]">
+        <label>C[dpdx]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+            <equationLabel>dpdx</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/dpdx/scaler</parameterUID>
+            <equationLabel>dpdx_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+            <equations uID="C[dpdx]_equation">
+              <equation language="Python">dpdx/dpdx_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[prop]">
+        <label>C[prop]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/DT/scaler</parameterUID>
+            <equationLabel>DT_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+            <equationLabel>DT</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/ESF/scaler</parameterUID>
+            <equationLabel>ESF_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Temp/scaler</parameterUID>
+            <equationLabel>Temp_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+            <equationLabel>ESF</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+            <equationLabel>Temp</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+            <equations uID="C[prop]_equation">
+              <equation language="Python">Temp/Temp_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+            <equations uID="C[prop]_equation_1">
+              <equation language="Python">ESF/ESF_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+            <equations uID="C[prop]_equation_2">
+              <equation language="Python">DT/DT_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[sigmas]">
+        <label>C[sigmas]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma4/scaler</parameterUID>
+            <equationLabel>sigma4_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+            <equationLabel>sigma4</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+            <equationLabel>sigma1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+            <equationLabel>sigma3</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+            <equationLabel>sigma2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma3/scaler</parameterUID>
+            <equationLabel>sigma3_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma2/scaler</parameterUID>
+            <equationLabel>sigma2_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma1/scaler</parameterUID>
+            <equationLabel>sigma1_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+            <equationLabel>sigma5</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma5/scaler</parameterUID>
+            <equationLabel>sigma5_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+            <equations uID="C[sigmas]_equation">
+              <equation language="Python">sigma1/sigma1_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+            <equations uID="C[sigmas]_equation_1">
+              <equation language="Python">sigma4/sigma4_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+            <equations uID="C[sigmas]_equation_2">
+              <equation language="Python">sigma5/sigma5_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+            <equations uID="C[sigmas]_equation_3">
+              <equation language="Python">sigma2/sigma2_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+            <equations uID="C[sigmas]_equation_4">
+              <equation language="Python">sigma3/sigma3_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/scaledData/R/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/fin">
+      <label>fin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/L">
+      <label>L</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/CDmin">
+      <label>CDmin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/T">
+      <label>T</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Cf">
+      <label>Cf</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WFO">
+      <label>WFO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma5">
+      <label>sigma5</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma4">
+      <label>sigma4</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma1">
+      <label>sigma1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma3">
+      <label>sigma3</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma2">
+      <label>sigma2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/D">
+      <label>D</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/R">
+      <label>R</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/section">
+      <label>section</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/Temp">
+      <label>Temp</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/dpdx">
+      <label>dpdx</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WBE">
+      <label>WBE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/SFC">
+      <label>SFC</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Nz">
+      <label>Nz</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/DT">
+      <label>DT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WF">
+      <label>WF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WO">
+      <label>WO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/lambda">
+      <label>lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/AR">
+      <label>AR</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Theta">
+      <label>Theta</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WT">
+      <label>WT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Lambda">
+      <label>Lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/ESF">
+      <label>ESF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/M">
+      <label>M</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/tc">
+      <label>tc</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Sref">
+      <label>Sref</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/h">
+      <label>h</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WE">
+      <label>WE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <problemDefinition uID="converged-DOEGauss-Seidel">
+    <problemFormulation>
+      <mdaoArchitecture>converged-DOE</mdaoArchitecture>
+      <convergerType>Gauss-Seidel</convergerType>
+      <executableBlocksOrder>
+        <executableBlock position="1">StructuralAnalysis</executableBlock>
+        <executableBlock position="2">AeroAnalysis</executableBlock>
+        <executableBlock position="3">PropulsionAnalysis</executableBlock>
+        <executableBlock position="4">PerformanceAnalysis</executableBlock>
+        <executableBlock position="5">C[sigmas]</executableBlock>
+        <executableBlock position="6">C[Theta]</executableBlock>
+        <executableBlock position="7">C[dpdx]</executableBlock>
+        <executableBlock position="8">C[prop]</executableBlock>
+        <executableBlock position="9">F[R]</executableBlock>
+      </executableBlocksOrder>
+      <allowUnconvergedCouplings>false</allowUnconvergedCouplings>
+      <doeSettings>
+        <method>Latin hypercube design</method>
+        <runs>10</runs>
+        <seed>5</seed>
+      </doeSettings>
+    </problemFormulation>
+    <problemRoles>
+      <parameters>
+        <designVariables>
+          <designVariable uID="__desVar__/dataSchema/aircraft/other/T">
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+            <nominalValue>0.55</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.1</minimum>
+                <maximum>1.0</maximum>
+              </limitRange>
+            </validRanges>
+            <samples>
+              <sample position="1">0.100000000000</sample>
+              <sample position="2">0.200000000000</sample>
+              <sample position="3">0.300000000000</sample>
+              <sample position="4">0.400000000000</sample>
+              <sample position="5">0.500000000000</sample>
+              <sample position="6">0.600000000000</sample>
+              <sample position="7">0.700000000000</sample>
+              <sample position="8">0.800000000000</sample>
+              <sample position="9">0.900000000000</sample>
+              <sample position="10">1.000000000000</sample>
+            </samples>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/other/Cf">
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+            <nominalValue>1.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.75</minimum>
+                <maximum>1.25</maximum>
+              </limitRange>
+            </validRanges>
+            <samples>
+              <sample position="1">0.750000000000</sample>
+              <sample position="2">0.805555555556</sample>
+              <sample position="3">0.861111111111</sample>
+              <sample position="4">0.916666666667</sample>
+              <sample position="5">0.972222222222</sample>
+              <sample position="6">1.027777777778</sample>
+              <sample position="7">1.083333333333</sample>
+              <sample position="8">1.138888888889</sample>
+              <sample position="9">1.194444444444</sample>
+              <sample position="10">1.250000000000</sample>
+            </samples>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/section">
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+            <nominalValue>1.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.75</minimum>
+                <maximum>1.25</maximum>
+              </limitRange>
+            </validRanges>
+            <samples>
+              <sample position="1">0.750000000000</sample>
+              <sample position="2">0.805555555556</sample>
+              <sample position="3">0.861111111111</sample>
+              <sample position="4">0.916666666667</sample>
+              <sample position="5">0.972222222222</sample>
+              <sample position="6">1.027777777778</sample>
+              <sample position="7">1.083333333333</sample>
+              <sample position="8">1.138888888889</sample>
+              <sample position="9">1.194444444444</sample>
+              <sample position="10">1.250000000000</sample>
+            </samples>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/lambda">
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+            <nominalValue>0.25</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.1</minimum>
+                <maximum>0.4</maximum>
+              </limitRange>
+            </validRanges>
+            <samples>
+              <sample position="1">0.100000000000</sample>
+              <sample position="2">0.133333333333</sample>
+              <sample position="3">0.166666666667</sample>
+              <sample position="4">0.200000000000</sample>
+              <sample position="5">0.233333333333</sample>
+              <sample position="6">0.266666666667</sample>
+              <sample position="7">0.300000000000</sample>
+              <sample position="8">0.333333333333</sample>
+              <sample position="9">0.366666666667</sample>
+              <sample position="10">0.400000000000</sample>
+            </samples>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/AR">
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+            <nominalValue>5.5</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>2.5</minimum>
+                <maximum>8.5</maximum>
+              </limitRange>
+            </validRanges>
+            <samples>
+              <sample position="1">2.500000000000</sample>
+              <sample position="2">3.166666666667</sample>
+              <sample position="3">3.833333333333</sample>
+              <sample position="4">4.500000000000</sample>
+              <sample position="5">5.166666666667</sample>
+              <sample position="6">5.833333333333</sample>
+              <sample position="7">6.500000000000</sample>
+              <sample position="8">7.166666666667</sample>
+              <sample position="9">7.833333333333</sample>
+              <sample position="10">8.500000000000</sample>
+            </samples>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/Lambda">
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+            <nominalValue>55</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>40</minimum>
+                <maximum>70</maximum>
+              </limitRange>
+            </validRanges>
+            <samples>
+              <sample position="1">40.000000000000</sample>
+              <sample position="2">43.333333333333</sample>
+              <sample position="3">46.666666666667</sample>
+              <sample position="4">50.000000000000</sample>
+              <sample position="5">53.333333333333</sample>
+              <sample position="6">56.666666666667</sample>
+              <sample position="7">60.000000000000</sample>
+              <sample position="8">63.333333333333</sample>
+              <sample position="9">66.666666666667</sample>
+              <sample position="10">70.000000000000</sample>
+            </samples>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/reference/M">
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+            <nominalValue>1.6</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>1.4</minimum>
+                <maximum>1.8</maximum>
+              </limitRange>
+            </validRanges>
+            <samples>
+              <sample position="1">1.400000000000</sample>
+              <sample position="2">1.444444444444</sample>
+              <sample position="3">1.488888888889</sample>
+              <sample position="4">1.533333333333</sample>
+              <sample position="5">1.577777777778</sample>
+              <sample position="6">1.622222222222</sample>
+              <sample position="7">1.666666666667</sample>
+              <sample position="8">1.711111111111</sample>
+              <sample position="9">1.755555555556</sample>
+              <sample position="10">1.800000000000</sample>
+            </samples>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/tc">
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+            <nominalValue>0.05</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.01</minimum>
+                <maximum>0.09</maximum>
+              </limitRange>
+            </validRanges>
+            <samples>
+              <sample position="1">0.010000000000</sample>
+              <sample position="2">0.018888888889</sample>
+              <sample position="3">0.027777777778</sample>
+              <sample position="4">0.036666666667</sample>
+              <sample position="5">0.045555555556</sample>
+              <sample position="6">0.054444444444</sample>
+              <sample position="7">0.063333333333</sample>
+              <sample position="8">0.072222222222</sample>
+              <sample position="9">0.081111111111</sample>
+              <sample position="10">0.090000000000</sample>
+            </samples>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/Sref">
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+            <nominalValue>1000</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>500</minimum>
+                <maximum>1500</maximum>
+              </limitRange>
+            </validRanges>
+            <samples>
+              <sample position="1">500.000000000000</sample>
+              <sample position="2">611.111111111111</sample>
+              <sample position="3">722.222222222222</sample>
+              <sample position="4">833.333333333333</sample>
+              <sample position="5">944.444444444444</sample>
+              <sample position="6">1055.555555555556</sample>
+              <sample position="7">1166.666666666667</sample>
+              <sample position="8">1277.777777777778</sample>
+              <sample position="9">1388.888888888889</sample>
+              <sample position="10">1500.000000000000</sample>
+            </samples>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/reference/h">
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+            <nominalValue>45000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>30000.0</minimum>
+                <maximum>60000.0</maximum>
+              </limitRange>
+            </validRanges>
+            <samples>
+              <sample position="1">30000.000000000000</sample>
+              <sample position="2">33333.333333333336</sample>
+              <sample position="3">36666.666666666664</sample>
+              <sample position="4">40000.000000000000</sample>
+              <sample position="5">43333.333333333336</sample>
+              <sample position="6">46666.666666666672</sample>
+              <sample position="7">50000.000000000000</sample>
+              <sample position="8">53333.333333333336</sample>
+              <sample position="9">56666.666666666672</sample>
+              <sample position="10">60000.000000000000</sample>
+            </samples>
+          </designVariable>
+        </designVariables>
+        <stateVariables>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/R/value">
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/Theta/value">
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/ESF/value">
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/dpdx/value">
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma2/value">
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/Temp/value">
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma5/value">
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma4/value">
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/DT/value">
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma1/value">
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma3/value">
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/aircraft/weight/WE">
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </stateVariable>
+        </stateVariables>
+      </parameters>
+      <executableBlocks>
+        <coupledBlocks>
+          <coupledBlock>StructuralAnalysis</coupledBlock>
+          <coupledBlock>AeroAnalysis</coupledBlock>
+          <coupledBlock>PropulsionAnalysis</coupledBlock>
+        </coupledBlocks>
+        <postCouplingBlocks>
+          <postCouplingBlock>PerformanceAnalysis</postCouplingBlock>
+          <postCouplingBlock>C[sigmas]</postCouplingBlock>
+          <postCouplingBlock>C[Theta]</postCouplingBlock>
+          <postCouplingBlock>C[dpdx]</postCouplingBlock>
+          <postCouplingBlock>C[prop]</postCouplingBlock>
+          <postCouplingBlock>F[R]</postCouplingBlock>
+        </postCouplingBlocks>
+      </executableBlocks>
+    </problemRoles>
+  </problemDefinition>
+  <workflow>
+    <problemDefinitionUID>converged-DOEGauss-Seidel</problemDefinitionUID>
+    <dataGraph>
+      <name>XDSM - converged-DOE-GS-LH</name>
+      <edges>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/Theta/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/value</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/scaler</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/fin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/dpdx</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/fin</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Theta/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma2/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Theta/value</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/ESF/value</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/ESF/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/CDmin</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/dpdx/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WBE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/section</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/other/T</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/Nz</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Theta/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/other/Cf</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WO</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WFO</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/CDmin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/ESF/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/value</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WFO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/value</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma5</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma4</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma1</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma3</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma2</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma3/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma1/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/value</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma5</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma4</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma3</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/ESF/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/Theta/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/DT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/dpdx/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/section</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/Cf</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma4/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/R/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/Temp/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma5/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma2/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma3/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma1/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/ESF/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/T</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/R</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/value</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Theta/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/value</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/R</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/value</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/Temp/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/Temp</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/dpdx</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WBE</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/DT/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/DT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/Temp</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/SFC</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/SFC</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Nz</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma4/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/R/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma5/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/DT</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/reference/M</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WF</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/value</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/reference/h</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/ESF/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/value</fromParameterUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+      </edges>
+    </dataGraph>
+    <processGraph>
+      <name>XDSM - converged-DOE-GS-LH</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+          <processStepNumber>9</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+          <processStepNumber>9</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+          <processStepNumber>9</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+          <processStepNumber>9</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+          <processStepNumber>10</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>DOE</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+          <processStepNumber>1</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toExecutableBlockUID>DOE</toExecutableBlockUID>
+          <processStepNumber>9</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+          <processStepNumber>8</processStepNumber>
+        </edge>
+      </edges>
+      <nodes>
+        <node>
+          <referenceUID>F[R]</referenceUID>
+          <processStepNumber>8</processStepNumber>
+          <diagonalPosition>11</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[sigmas]</referenceUID>
+          <processStepNumber>7</processStepNumber>
+          <diagonalPosition>7</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[Theta]</referenceUID>
+          <processStepNumber>7</processStepNumber>
+          <diagonalPosition>8</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[prop]</referenceUID>
+          <processStepNumber>7</processStepNumber>
+          <diagonalPosition>10</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Converger</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <convergerStepNumber>6</convergerStepNumber>
+          <diagonalPosition>2</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>DOE</referenceUID>
+          <processStepNumber>1</processStepNumber>
+          <convergerStepNumber>9</convergerStepNumber>
+          <diagonalPosition>1</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Coordinator</referenceUID>
+          <processStepNumber>0</processStepNumber>
+          <convergerStepNumber>10</convergerStepNumber>
+          <diagonalPosition>0</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[dpdx]</referenceUID>
+          <processStepNumber>7</processStepNumber>
+          <diagonalPosition>9</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>AeroAnalysis</referenceUID>
+          <processStepNumber>4</processStepNumber>
+          <diagonalPosition>4</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>PropulsionAnalysis</referenceUID>
+          <processStepNumber>5</processStepNumber>
+          <diagonalPosition>5</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>StructuralAnalysis</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>3</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>PerformanceAnalysis</referenceUID>
+          <processStepNumber>7</processStepNumber>
+          <diagonalPosition>6</diagonalPosition>
+        </node>
+      </nodes>
+      <metadata>
+        <loopNesting>
+          <loopElements>
+            <loopElement relatedUID="Coordinator">
+              <loopElements>
+                <loopElement relatedUID="DOE">
+                  <loopElements>
+                    <loopElement relatedUID="Converger">
+                      <functionElements>
+                        <functionElement>StructuralAnalysis</functionElement>
+                        <functionElement>AeroAnalysis</functionElement>
+                        <functionElement>PropulsionAnalysis</functionElement>
+                      </functionElements>
+                    </loopElement>
+                  </loopElements>
+                  <functionElements>
+                    <functionElement>C[Theta]</functionElement>
+                    <functionElement>C[dpdx]</functionElement>
+                    <functionElement>C[prop]</functionElement>
+                    <functionElement>C[sigmas]</functionElement>
+                    <functionElement>PerformanceAnalysis</functionElement>
+                    <functionElement>F[R]</functionElement>
+                  </functionElements>
+                </loopElement>
+              </loopElements>
+            </loopElement>
+          </loopElements>
+        </loopNesting>
+      </metadata>
+    </processGraph>
+  </workflow>
+  <architectureElements>
+    <parameters>
+      <initialGuessCouplingVariables>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+      </initialGuessCouplingVariables>
+      <finalCouplingVariables>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+      </finalCouplingVariables>
+      <couplingCopyVariables>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+      </couplingCopyVariables>
+      <doeInputSampleLists>
+        <doeInputSampleList uID="/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/section">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/section</relatedParameterUID>
+          <label>DOE_section_{inp}</label>
+          <instanceID>1</instanceID>
+        </doeInputSampleList>
+        <doeInputSampleList uID="/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/AR">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/AR</relatedParameterUID>
+          <label>DOE_AR_{inp}</label>
+          <instanceID>1</instanceID>
+        </doeInputSampleList>
+        <doeInputSampleList uID="/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/Sref">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Sref</relatedParameterUID>
+          <label>DOE_Sref_{inp}</label>
+          <instanceID>1</instanceID>
+        </doeInputSampleList>
+        <doeInputSampleList uID="/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/other/Cf">
+          <relatedParameterUID>/dataSchema/aircraft/other/Cf</relatedParameterUID>
+          <label>DOE_Cf_{inp}</label>
+          <instanceID>1</instanceID>
+        </doeInputSampleList>
+        <doeInputSampleList uID="/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/lambda</relatedParameterUID>
+          <label>DOE_lambda_{inp}</label>
+          <instanceID>1</instanceID>
+        </doeInputSampleList>
+        <doeInputSampleList uID="/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/Lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Lambda</relatedParameterUID>
+          <label>DOE_Lambda_{inp}</label>
+          <instanceID>1</instanceID>
+        </doeInputSampleList>
+        <doeInputSampleList uID="/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/other/T">
+          <relatedParameterUID>/dataSchema/aircraft/other/T</relatedParameterUID>
+          <label>DOE_T_{inp}</label>
+          <instanceID>1</instanceID>
+        </doeInputSampleList>
+        <doeInputSampleList uID="/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/aircraft/geometry/tc">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/tc</relatedParameterUID>
+          <label>DOE_tc_{inp}</label>
+          <instanceID>1</instanceID>
+        </doeInputSampleList>
+        <doeInputSampleList uID="/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/reference/M">
+          <relatedParameterUID>/dataSchema/reference/M</relatedParameterUID>
+          <label>DOE_M_{inp}</label>
+          <instanceID>1</instanceID>
+        </doeInputSampleList>
+        <doeInputSampleList uID="/dataSchema/architectureNodes/doeInputSampleLists/dataSchemaCopy/reference/h">
+          <relatedParameterUID>/dataSchema/reference/h</relatedParameterUID>
+          <label>DOE_h_{inp}</label>
+          <instanceID>1</instanceID>
+        </doeInputSampleList>
+      </doeInputSampleLists>
+      <doeOutputSampleLists>
+        <doeOutputSampleList uID="/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/Theta/value">
+          <relatedParameterUID>/dataSchema/scaledData/Theta/value</relatedParameterUID>
+          <label>DOE_value_{out}</label>
+          <instanceID>1</instanceID>
+        </doeOutputSampleList>
+        <doeOutputSampleList uID="/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma2/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma2/value</relatedParameterUID>
+          <label>DOE_value_{out}</label>
+          <instanceID>1</instanceID>
+        </doeOutputSampleList>
+        <doeOutputSampleList uID="/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/ESF/value">
+          <relatedParameterUID>/dataSchema/scaledData/ESF/value</relatedParameterUID>
+          <label>DOE_value_{out}</label>
+          <instanceID>1</instanceID>
+        </doeOutputSampleList>
+        <doeOutputSampleList uID="/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/dpdx/value">
+          <relatedParameterUID>/dataSchema/scaledData/dpdx/value</relatedParameterUID>
+          <label>DOE_value_{out}</label>
+          <instanceID>1</instanceID>
+        </doeOutputSampleList>
+        <doeOutputSampleList uID="/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>DOE_WE_{out}</label>
+          <instanceID>1</instanceID>
+        </doeOutputSampleList>
+        <doeOutputSampleList uID="/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma3/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma3/value</relatedParameterUID>
+          <label>DOE_value_{out}</label>
+          <instanceID>1</instanceID>
+        </doeOutputSampleList>
+        <doeOutputSampleList uID="/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma1/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma1/value</relatedParameterUID>
+          <label>DOE_value_{out}</label>
+          <instanceID>1</instanceID>
+        </doeOutputSampleList>
+        <doeOutputSampleList uID="/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/Temp/value">
+          <relatedParameterUID>/dataSchema/scaledData/Temp/value</relatedParameterUID>
+          <label>DOE_value_{out}</label>
+          <instanceID>1</instanceID>
+        </doeOutputSampleList>
+        <doeOutputSampleList uID="/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/DT/value">
+          <relatedParameterUID>/dataSchema/scaledData/DT/value</relatedParameterUID>
+          <label>DOE_value_{out}</label>
+          <instanceID>1</instanceID>
+        </doeOutputSampleList>
+        <doeOutputSampleList uID="/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma4/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma4/value</relatedParameterUID>
+          <label>DOE_value_{out}</label>
+          <instanceID>1</instanceID>
+        </doeOutputSampleList>
+        <doeOutputSampleList uID="/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/R/value">
+          <relatedParameterUID>/dataSchema/scaledData/R/value</relatedParameterUID>
+          <label>DOE_value_{out}</label>
+          <instanceID>1</instanceID>
+        </doeOutputSampleList>
+        <doeOutputSampleList uID="/dataSchema/architectureNodes/doeOutputSampleLists/dataSchemaCopy/scaledData/sigma5/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma5/value</relatedParameterUID>
+          <label>DOE_value_{out}</label>
+          <instanceID>1</instanceID>
+        </doeOutputSampleList>
+      </doeOutputSampleLists>
+    </parameters>
+    <executableBlocks>
+      <coordinators>
+        <coordinator uID="Coordinator">
+          <label>COOR</label>
+        </coordinator>
+      </coordinators>
+      <convergers>
+        <converger uID="Converger">
+          <label>CONV</label>
+          <settings>
+            <linearSolver>
+              <method>Gauss-Seidel</method>
+              <lastIterationsToConsider>1</lastIterationsToConsider>
+              <maximumIterations>100</maximumIterations>
+              <convergenceToleranceRelative>1e-06</convergenceToleranceRelative>
+              <convergenceToleranceAbsolute>1e-06</convergenceToleranceAbsolute>
+            </linearSolver>
+            <nonlinearSolver>
+              <method>Gauss-Seidel</method>
+              <lastIterationsToConsider>1</lastIterationsToConsider>
+              <maximumIterations>100</maximumIterations>
+              <convergenceToleranceRelative>1e-06</convergenceToleranceRelative>
+              <convergenceToleranceAbsolute>1e-06</convergenceToleranceAbsolute>
+            </nonlinearSolver>
+          </settings>
+        </converger>
+      </convergers>
+      <does>
+        <doe uID="DOE">
+          <label>DOE</label>
+          <settings>
+            <method>Latin hypercube design</method>
+            <runs>10</runs>
+            <seed>5</seed>
+          </settings>
+          <designVariables>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/other/Cf</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/reference/h</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/Lambda</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/reference/M</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/lambda</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/other/T</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/tc</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/section</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/AR</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/Sref</designVariableUID>
+            </designVariable>
+          </designVariables>
+        </doe>
+      </does>
+      <coupledAnalyses>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>AeroAnalysis</relatedExecutableBlockUID>
+        </coupledAnalysis>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>StructuralAnalysis</relatedExecutableBlockUID>
+        </coupledAnalysis>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>PropulsionAnalysis</relatedExecutableBlockUID>
+        </coupledAnalysis>
+      </coupledAnalyses>
+      <postCouplingAnalyses>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>F[R]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[prop]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[Theta]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>PerformanceAnalysis</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[dpdx]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[sigmas]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+      </postCouplingAnalyses>
+    </executableBlocks>
+  </architectureElements>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/ssbj_fpg_mda.xml b/kadmos/vistoms/downloads/ssbj_fpg_mda.xml
new file mode 100644
index 000000000..a4b2e6a01
--- /dev/null
+++ b/kadmos/vistoms/downloads/ssbj_fpg_mda.xml
@@ -0,0 +1,1270 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>RCG CMDOWS file of the super-sonic business jet test case</description>
+    <timestamp>2018-09-05T13:58:10.328136</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a fundamental problem graph (FPG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-09-05T13:58:10.328136</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="imcovangent">
+          <function>PhD Student</function>
+          <name>Imco van Gent</name>
+          <country>The Netherlands</country>
+          <company>TU Delft</company>
+          <telephone>0031 6 53 89 42 75</telephone>
+          <address>Kluyverweg 1, 2629 HS, Delft</address>
+          <department>Flight Performance and Propulsion</department>
+          <email>i.vangent@tudelft.nl</email>
+        </contact>
+        <contact uID="remilafage">
+          <name>Remi Lafage</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Remi.Lafage@onera.fr</email>
+        </contact>
+        <contact uID="sylvaindubreuil">
+          <name>Sylvain Dubreuil</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Sylvain.Dubreuil@onera.fr</email>
+        </contact>
+      </contacts>
+      <organigram>
+        <architects>
+          <architect>
+            <contactUID>imcovangent</contactUID>
+          </architect>
+        </architects>
+        <integrators>
+          <integrator>
+            <contactUID>imcovangent</contactUID>
+          </integrator>
+        </integrators>
+        <toolSpecialists>
+          <toolSpecialist>
+            <contactUID>remilafage</contactUID>
+          </toolSpecialist>
+          <toolSpecialist>
+            <contactUID>sylvaindubreuil</contactUID>
+          </toolSpecialist>
+        </toolSpecialists>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <designCompetences>
+      <designCompetence uID="StructuralAnalysis">
+        <label>StructuralAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/L</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WFO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Nz</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </output>
+        </outputs>
+        <ID>StructuralAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>StructuralAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <operatingSystem>Windows</operatingSystem>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\structuralanalysis\StructuralAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <description>Details for the command line execution of the StructuralAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PropulsionAnalysis">
+        <label>PropulsionAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WBE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+          </output>
+        </outputs>
+        <ID>PropulsionAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PropulsionAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <operatingSystem>Windows</operatingSystem>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\propulsionanalysis\PropulsionAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <description>Details for the command line execution of the PropulsionAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="AeroAnalysis">
+        <label>AeroAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/CDmin</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/L</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </output>
+        </outputs>
+        <ID>AeroAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>AeroAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <operatingSystem>Windows</operatingSystem>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\aeroanalysis\AeroAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <description>Details for the command line execution of the AeroAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PerformanceAnalysis">
+        <label>PerformanceAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+          </output>
+        </outputs>
+        <ID>PerformanceAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PerformanceAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <operatingSystem>Windows</operatingSystem>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\performanceanalysis\PerformanceAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <description>Details for the command line execution of the PerformanceAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+    </designCompetences>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="F[R]">
+        <label>F[R]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/R/scaler</parameterUID>
+            <equationLabel>R_scaler</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+            <equationLabel>R</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+            <equations uID="F[R]_equation">
+              <equation language="Python">-R/R_scaler</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[Theta]">
+        <label>C[Theta]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Theta/scaler</parameterUID>
+            <equationLabel>Theta_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+            <equationLabel>Theta</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+            <equations uID="C[Theta]_equation">
+              <equation language="Python">Theta/Theta_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[dpdx]">
+        <label>C[dpdx]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+            <equationLabel>dpdx</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/dpdx/scaler</parameterUID>
+            <equationLabel>dpdx_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+            <equations uID="C[dpdx]_equation">
+              <equation language="Python">dpdx/dpdx_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[prop]">
+        <label>C[prop]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/DT/scaler</parameterUID>
+            <equationLabel>DT_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+            <equationLabel>DT</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/ESF/scaler</parameterUID>
+            <equationLabel>ESF_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Temp/scaler</parameterUID>
+            <equationLabel>Temp_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+            <equationLabel>ESF</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+            <equationLabel>Temp</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+            <equations uID="C[prop]_equation">
+              <equation language="Python">Temp/Temp_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+            <equations uID="C[prop]_equation_1">
+              <equation language="Python">ESF/ESF_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+            <equations uID="C[prop]_equation_2">
+              <equation language="Python">DT/DT_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[sigmas]">
+        <label>C[sigmas]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma4/scaler</parameterUID>
+            <equationLabel>sigma4_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+            <equationLabel>sigma4</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+            <equationLabel>sigma1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+            <equationLabel>sigma3</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+            <equationLabel>sigma2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma3/scaler</parameterUID>
+            <equationLabel>sigma3_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma2/scaler</parameterUID>
+            <equationLabel>sigma2_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma1/scaler</parameterUID>
+            <equationLabel>sigma1_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+            <equationLabel>sigma5</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma5/scaler</parameterUID>
+            <equationLabel>sigma5_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+            <equations uID="C[sigmas]_equation">
+              <equation language="Python">sigma1/sigma1_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+            <equations uID="C[sigmas]_equation_1">
+              <equation language="Python">sigma4/sigma4_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+            <equations uID="C[sigmas]_equation_2">
+              <equation language="Python">sigma5/sigma5_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+            <equations uID="C[sigmas]_equation_3">
+              <equation language="Python">sigma2/sigma2_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+            <equations uID="C[sigmas]_equation_4">
+              <equation language="Python">sigma3/sigma3_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/aircraft/other/D">
+      <label>D</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/L">
+      <label>L</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/R">
+      <label>R</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/SFC">
+      <label>SFC</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma5">
+      <label>sigma5</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/fin">
+      <label>fin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/DT">
+      <label>DT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma4">
+      <label>sigma4</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma1">
+      <label>sigma1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma3">
+      <label>sigma3</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma2">
+      <label>sigma2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WF">
+      <label>WF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WE">
+      <label>WE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/Temp">
+      <label>Temp</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/dpdx">
+      <label>dpdx</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WT">
+      <label>WT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/ESF">
+      <label>ESF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Theta">
+      <label>Theta</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WBE">
+      <label>WBE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/T">
+      <label>T</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Nz">
+      <label>Nz</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/section">
+      <label>section</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Cf">
+      <label>Cf</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WFO">
+      <label>WFO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WO">
+      <label>WO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/CDmin">
+      <label>CDmin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/lambda">
+      <label>lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/tc">
+      <label>tc</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/M">
+      <label>M</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Lambda">
+      <label>Lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/h">
+      <label>h</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/AR">
+      <label>AR</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Sref">
+      <label>Sref</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <problemDefinition uID="unconverged-MDAGauss-Seidel">
+    <problemFormulation>
+      <mdaoArchitecture>unconverged-MDA</mdaoArchitecture>
+      <convergerType>Gauss-Seidel</convergerType>
+      <executableBlocksOrder>
+        <executableBlock position="1">StructuralAnalysis</executableBlock>
+        <executableBlock position="2">AeroAnalysis</executableBlock>
+        <executableBlock position="3">PropulsionAnalysis</executableBlock>
+        <executableBlock position="4">PerformanceAnalysis</executableBlock>
+        <executableBlock position="5">C[sigmas]</executableBlock>
+        <executableBlock position="6">C[Theta]</executableBlock>
+        <executableBlock position="7">C[dpdx]</executableBlock>
+        <executableBlock position="8">C[prop]</executableBlock>
+        <executableBlock position="9">F[R]</executableBlock>
+      </executableBlocksOrder>
+      <allowUnconvergedCouplings>true</allowUnconvergedCouplings>
+    </problemFormulation>
+    <problemRoles>
+      <parameters>
+        <stateVariables>
+          <stateVariable uID="__statVar__/dataSchema/aircraft/weight/WE">
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/dpdx/value">
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma5/value">
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/R/value">
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma2/value">
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/Theta/value">
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/DT/value">
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/ESF/value">
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma1/value">
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma4/value">
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/Temp/value">
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma3/value">
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+          </stateVariable>
+        </stateVariables>
+      </parameters>
+      <executableBlocks>
+        <coupledBlocks>
+          <coupledBlock>StructuralAnalysis</coupledBlock>
+          <coupledBlock>AeroAnalysis</coupledBlock>
+          <coupledBlock>PropulsionAnalysis</coupledBlock>
+        </coupledBlocks>
+        <postCouplingBlocks>
+          <postCouplingBlock>PerformanceAnalysis</postCouplingBlock>
+          <postCouplingBlock>C[sigmas]</postCouplingBlock>
+          <postCouplingBlock>C[Theta]</postCouplingBlock>
+          <postCouplingBlock>C[dpdx]</postCouplingBlock>
+          <postCouplingBlock>C[prop]</postCouplingBlock>
+          <postCouplingBlock>F[R]</postCouplingBlock>
+        </postCouplingBlocks>
+      </executableBlocks>
+    </problemRoles>
+  </problemDefinition>
+  <workflow>
+    <dataGraph>
+      <name>FPG - MDA</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WBE</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/R</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/SFC</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Nz</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Theta/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/scaler</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma5</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/ESF/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/fin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/dpdx</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/fin</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WFO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/DT</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma4</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma1</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma3</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma2</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WF</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/R</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Theta/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/Temp</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/CDmin</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/ESF/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/SFC</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/DT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/Temp</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/dpdx</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma5</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma4</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma3</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+      </edges>
+    </dataGraph>
+  </workflow>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/ssbj_fpg_mdo.xml b/kadmos/vistoms/downloads/ssbj_fpg_mdo.xml
new file mode 100644
index 000000000..347f35309
--- /dev/null
+++ b/kadmos/vistoms/downloads/ssbj_fpg_mdo.xml
@@ -0,0 +1,1401 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>FPG CMDOWS file of the super-sonic business jet test case</description>
+    <timestamp>2018-09-05T13:58:10.328136</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a fundamental problem graph (FPG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-09-05T13:58:10.328136</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="imcovangent">
+          <function>PhD Student</function>
+          <name>Imco van Gent</name>
+          <country>The Netherlands</country>
+          <company>TU Delft</company>
+          <telephone>0031 6 53 89 42 75</telephone>
+          <address>Kluyverweg 1, 2629 HS, Delft</address>
+          <department>Flight Performance and Propulsion</department>
+          <email>i.vangent@tudelft.nl</email>
+        </contact>
+        <contact uID="remilafage">
+          <name>Remi Lafage</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Remi.Lafage@onera.fr</email>
+        </contact>
+        <contact uID="sylvaindubreuil">
+          <name>Sylvain Dubreuil</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Sylvain.Dubreuil@onera.fr</email>
+        </contact>
+      </contacts>
+      <organigram>
+        <architects>
+          <architect>
+            <contactUID>imcovangent</contactUID>
+          </architect>
+        </architects>
+        <integrators>
+          <integrator>
+            <contactUID>imcovangent</contactUID>
+          </integrator>
+        </integrators>
+        <toolSpecialists>
+          <toolSpecialist>
+            <contactUID>remilafage</contactUID>
+          </toolSpecialist>
+          <toolSpecialist>
+            <contactUID>sylvaindubreuil</contactUID>
+          </toolSpecialist>
+        </toolSpecialists>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <designCompetences>
+      <designCompetence uID="StructuralAnalysis">
+        <label>StructuralAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/L</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WFO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Nz</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </output>
+        </outputs>
+        <ID>StructuralAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>StructuralAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <operatingSystem>Windows</operatingSystem>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\structuralanalysis\StructuralAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <description>Details for the command line execution of the StructuralAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PropulsionAnalysis">
+        <label>PropulsionAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WBE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+          </output>
+        </outputs>
+        <ID>PropulsionAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PropulsionAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <operatingSystem>Windows</operatingSystem>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\propulsionanalysis\PropulsionAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <description>Details for the command line execution of the PropulsionAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="AeroAnalysis">
+        <label>AeroAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/CDmin</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/L</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </output>
+        </outputs>
+        <ID>AeroAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>AeroAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <operatingSystem>Windows</operatingSystem>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\aeroanalysis\AeroAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <description>Details for the command line execution of the AeroAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PerformanceAnalysis">
+        <label>PerformanceAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+          </output>
+        </outputs>
+        <ID>PerformanceAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PerformanceAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <operatingSystem>Windows</operatingSystem>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\performanceanalysis\PerformanceAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <description>Details for the command line execution of the PerformanceAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+    </designCompetences>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="F[R]">
+        <label>F[R]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/R/scaler</parameterUID>
+            <equationLabel>R_scaler</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+            <equationLabel>R</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+            <equations uID="F[R]_equation">
+              <equation language="Python">-R/R_scaler</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[Theta]">
+        <label>C[Theta]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Theta/scaler</parameterUID>
+            <equationLabel>Theta_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+            <equationLabel>Theta</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+            <equations uID="C[Theta]_equation">
+              <equation language="Python">Theta/Theta_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[dpdx]">
+        <label>C[dpdx]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+            <equationLabel>dpdx</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/dpdx/scaler</parameterUID>
+            <equationLabel>dpdx_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+            <equations uID="C[dpdx]_equation">
+              <equation language="Python">dpdx/dpdx_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[prop]">
+        <label>C[prop]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/DT/scaler</parameterUID>
+            <equationLabel>DT_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+            <equationLabel>DT</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/ESF/scaler</parameterUID>
+            <equationLabel>ESF_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Temp/scaler</parameterUID>
+            <equationLabel>Temp_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+            <equationLabel>ESF</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+            <equationLabel>Temp</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+            <equations uID="C[prop]_equation">
+              <equation language="Python">Temp/Temp_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+            <equations uID="C[prop]_equation_1">
+              <equation language="Python">ESF/ESF_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+            <equations uID="C[prop]_equation_2">
+              <equation language="Python">DT/DT_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[sigmas]">
+        <label>C[sigmas]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma4/scaler</parameterUID>
+            <equationLabel>sigma4_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+            <equationLabel>sigma4</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+            <equationLabel>sigma1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+            <equationLabel>sigma3</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+            <equationLabel>sigma2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma3/scaler</parameterUID>
+            <equationLabel>sigma3_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma2/scaler</parameterUID>
+            <equationLabel>sigma2_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma1/scaler</parameterUID>
+            <equationLabel>sigma1_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+            <equationLabel>sigma5</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma5/scaler</parameterUID>
+            <equationLabel>sigma5_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+            <equations uID="C[sigmas]_equation">
+              <equation language="Python">sigma1/sigma1_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+            <equations uID="C[sigmas]_equation_1">
+              <equation language="Python">sigma4/sigma4_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+            <equations uID="C[sigmas]_equation_2">
+              <equation language="Python">sigma5/sigma5_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+            <equations uID="C[sigmas]_equation_3">
+              <equation language="Python">sigma2/sigma2_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+            <equations uID="C[sigmas]_equation_4">
+              <equation language="Python">sigma3/sigma3_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/aircraft/other/D">
+      <label>D</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/R">
+      <label>R</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/SFC">
+      <label>SFC</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma5">
+      <label>sigma5</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/fin">
+      <label>fin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/DT">
+      <label>DT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma4">
+      <label>sigma4</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma1">
+      <label>sigma1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma3">
+      <label>sigma3</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma2">
+      <label>sigma2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WF">
+      <label>WF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WE">
+      <label>WE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/Temp">
+      <label>Temp</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/L">
+      <label>L</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/dpdx">
+      <label>dpdx</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WT">
+      <label>WT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/ESF">
+      <label>ESF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Theta">
+      <label>Theta</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WBE">
+      <label>WBE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/T">
+      <label>T</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Nz">
+      <label>Nz</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/section">
+      <label>section</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Cf">
+      <label>Cf</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WFO">
+      <label>WFO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WO">
+      <label>WO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/CDmin">
+      <label>CDmin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/lambda">
+      <label>lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/tc">
+      <label>tc</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/M">
+      <label>M</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Lambda">
+      <label>Lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/h">
+      <label>h</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/AR">
+      <label>AR</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Sref">
+      <label>Sref</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <problemDefinition uID="MDFGauss-Seidel">
+    <problemFormulation>
+      <mdaoArchitecture>MDF</mdaoArchitecture>
+      <convergerType>Gauss-Seidel</convergerType>
+      <executableBlocksOrder>
+        <executableBlock position="1">StructuralAnalysis</executableBlock>
+        <executableBlock position="2">AeroAnalysis</executableBlock>
+        <executableBlock position="3">PropulsionAnalysis</executableBlock>
+        <executableBlock position="4">PerformanceAnalysis</executableBlock>
+        <executableBlock position="5">C[sigmas]</executableBlock>
+        <executableBlock position="6">C[Theta]</executableBlock>
+        <executableBlock position="7">C[dpdx]</executableBlock>
+        <executableBlock position="8">C[prop]</executableBlock>
+        <executableBlock position="9">F[R]</executableBlock>
+      </executableBlocksOrder>
+      <allowUnconvergedCouplings>false</allowUnconvergedCouplings>
+    </problemFormulation>
+    <problemRoles>
+      <parameters>
+        <designVariables>
+          <designVariable uID="__desVar__/dataSchema/aircraft/other/T">
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+            <nominalValue>0.2</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.09</minimum>
+                <maximum>0.905</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/section">
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+            <nominalValue>1.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.75</minimum>
+                <maximum>1.25</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/other/Cf">
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+            <nominalValue>1.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.75</minimum>
+                <maximum>1.25</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/lambda">
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+            <nominalValue>0.25</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.1</minimum>
+                <maximum>0.4</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/tc">
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+            <nominalValue>0.05</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.01</minimum>
+                <maximum>0.09</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/reference/M">
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+            <nominalValue>1.6</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>1.4</minimum>
+                <maximum>1.8</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/Lambda">
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+            <nominalValue>55.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>39.6</minimum>
+                <maximum>69.85</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/reference/h">
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+            <nominalValue>45000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>30000.0</minimum>
+                <maximum>60000.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/AR">
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+            <nominalValue>5.5</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>2.475</minimum>
+                <maximum>7.975</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/Sref">
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+            <nominalValue>1000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>500.0</minimum>
+                <maximum>1500.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+        </designVariables>
+        <objectiveVariables>
+          <objectiveVariable uID="__objVar__/dataSchema/scaledData/R/value">
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+          </objectiveVariable>
+        </objectiveVariables>
+        <constraintVariables>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/dpdx/value">
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.04</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma5/value">
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma2/value">
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/Theta/value">
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=;&lt;=</constraintOperator>
+            <referenceValue>0.96;1.04</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/DT/value">
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/ESF/value">
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=;&lt;=</constraintOperator>
+            <referenceValue>0.5;1.5</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma1/value">
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma4/value">
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/Temp/value">
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.02</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma3/value">
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+        </constraintVariables>
+      </parameters>
+      <executableBlocks>
+        <coupledBlocks>
+          <coupledBlock>StructuralAnalysis</coupledBlock>
+          <coupledBlock>AeroAnalysis</coupledBlock>
+          <coupledBlock>PropulsionAnalysis</coupledBlock>
+        </coupledBlocks>
+        <postCouplingBlocks>
+          <postCouplingBlock>PerformanceAnalysis</postCouplingBlock>
+          <postCouplingBlock>C[sigmas]</postCouplingBlock>
+          <postCouplingBlock>C[Theta]</postCouplingBlock>
+          <postCouplingBlock>C[dpdx]</postCouplingBlock>
+          <postCouplingBlock>C[prop]</postCouplingBlock>
+          <postCouplingBlock>F[R]</postCouplingBlock>
+        </postCouplingBlocks>
+      </executableBlocks>
+    </problemRoles>
+  </problemDefinition>
+  <workflow>
+    <dataGraph>
+      <name>FPG - MDO</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WBE</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/ESF/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/R</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/SFC</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Nz</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Theta/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/scaler</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma5</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/fin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/dpdx</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/fin</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WFO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/DT</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma4</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma1</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma3</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma2</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WF</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/R</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Theta/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/Temp</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/CDmin</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/ESF/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/SFC</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/DT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/Temp</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/dpdx</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma5</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma4</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma3</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+      </edges>
+    </dataGraph>
+  </workflow>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/ssbj_mdags.xml b/kadmos/vistoms/downloads/ssbj_mdags.xml
new file mode 100644
index 000000000..e41a881d2
--- /dev/null
+++ b/kadmos/vistoms/downloads/ssbj_mdags.xml
@@ -0,0 +1,1783 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>Mdao CMDOWS file of the super-sonic business jet test case optimization problem</description>
+    <timestamp>2018-08-23T10:26:33.106807</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a mdao data graph (MDG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-08-23T10:26:33.106807</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="imcovangent">
+          <function>PhD Student</function>
+          <name>Imco van Gent</name>
+          <country>The Netherlands</country>
+          <company>TU Delft</company>
+          <telephone>0031 6 53 89 42 75</telephone>
+          <address>Kluyverweg 1, 2629 HS, Delft</address>
+          <department>Flight Performance and Propulsion</department>
+          <email>i.vangent@tudelft.nl</email>
+        </contact>
+        <contact uID="remilafage">
+          <name>Remi Lafage</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Remi.Lafage@onera.fr</email>
+        </contact>
+        <contact uID="sylvaindubreuil">
+          <name>Sylvain Dubreuil</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Sylvain.Dubreuil@onera.fr</email>
+        </contact>
+      </contacts>
+      <organigram>
+        <architects>
+          <architect>
+            <contactUID>imcovangent</contactUID>
+          </architect>
+        </architects>
+        <integrators>
+          <integrator>
+            <contactUID>imcovangent</contactUID>
+          </integrator>
+        </integrators>
+        <toolSpecialists>
+          <toolSpecialist>
+            <contactUID>remilafage</contactUID>
+          </toolSpecialist>
+          <toolSpecialist>
+            <contactUID>sylvaindubreuil</contactUID>
+          </toolSpecialist>
+        </toolSpecialists>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <designCompetences>
+      <designCompetence uID="StructuralAnalysis">
+        <label>StructuralAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WFO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Nz</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </output>
+        </outputs>
+        <ID>StructuralAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>StructuralAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\structuralanalysis\StructuralAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the StructuralAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PropulsionAnalysis">
+        <label>PropulsionAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WBE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/reference/ESF</parameterUID>
+          </output>
+        </outputs>
+        <ID>PropulsionAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PropulsionAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\propulsionanalysis\PropulsionAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the PropulsionAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="AeroAnalysis">
+        <label>AeroAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/CDmin</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/L</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/L</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </output>
+        </outputs>
+        <ID>AeroAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>AeroAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\aeroanalysis\AeroAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the AeroAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PerformanceAnalysis">
+        <label>PerformanceAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+          </output>
+        </outputs>
+        <ID>PerformanceAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PerformanceAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\performanceanalysis\PerformanceAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the PerformanceAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+    </designCompetences>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="F[R]">
+        <label>F[R]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/R/scaler</parameterUID>
+            <equationLabel>R_scaler</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+            <equationLabel>R</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+            <equations uID="F[R]_equation">
+              <equation language="Python">-R/R_scaler</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[Theta]">
+        <label>C[Theta]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Theta/scaler</parameterUID>
+            <equationLabel>Theta_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+            <equationLabel>Theta</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+            <equations uID="C[Theta]_equation">
+              <equation language="Python">Theta/Theta_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[dpdx]">
+        <label>C[dpdx]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+            <equationLabel>dpdx</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/dpdx/scaler</parameterUID>
+            <equationLabel>dpdx_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+            <equations uID="C[dpdx]_equation">
+              <equation language="Python">dpdx/dpdx_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[prop]">
+        <label>C[prop]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/DT/scaler</parameterUID>
+            <equationLabel>DT_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+            <equationLabel>DT</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/ESF/scaler</parameterUID>
+            <equationLabel>ESF_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Temp/scaler</parameterUID>
+            <equationLabel>Temp_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+            <equationLabel>ESF</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+            <equationLabel>Temp</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+            <equations uID="C[prop]_equation">
+              <equation language="Python">Temp/Temp_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+            <equations uID="C[prop]_equation_1">
+              <equation language="Python">ESF/ESF_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+            <equations uID="C[prop]_equation_2">
+              <equation language="Python">DT/DT_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[sigmas]">
+        <label>C[sigmas]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma4/scaler</parameterUID>
+            <equationLabel>sigma4_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+            <equationLabel>sigma4</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+            <equationLabel>sigma1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+            <equationLabel>sigma3</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+            <equationLabel>sigma2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma3/scaler</parameterUID>
+            <equationLabel>sigma3_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma2/scaler</parameterUID>
+            <equationLabel>sigma2_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma1/scaler</parameterUID>
+            <equationLabel>sigma1_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+            <equationLabel>sigma5</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma5/scaler</parameterUID>
+            <equationLabel>sigma5_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+            <equations uID="C[sigmas]_equation">
+              <equation language="Python">sigma1/sigma1_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+            <equations uID="C[sigmas]_equation_1">
+              <equation language="Python">sigma4/sigma4_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+            <equations uID="C[sigmas]_equation_2">
+              <equation language="Python">sigma5/sigma5_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+            <equations uID="C[sigmas]_equation_3">
+              <equation language="Python">sigma2/sigma2_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+            <equations uID="C[sigmas]_equation_4">
+              <equation language="Python">sigma3/sigma3_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/scaledData/dpdx/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WBE">
+      <label>WBE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/D">
+      <label>D</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/L">
+      <label>L</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/R">
+      <label>R</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/SFC">
+      <label>SFC</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Nz">
+      <label>Nz</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/section">
+      <label>section</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Cf">
+      <label>Cf</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma5">
+      <label>sigma5</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/T">
+      <label>T</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/fin">
+      <label>fin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WFO">
+      <label>WFO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma2">
+      <label>sigma2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/DT">
+      <label>DT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma4">
+      <label>sigma4</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma1">
+      <label>sigma1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma3">
+      <label>sigma3</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WF">
+      <label>WF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WE">
+      <label>WE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WO">
+      <label>WO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/Temp">
+      <label>Temp</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/CDmin">
+      <label>CDmin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/lambda">
+      <label>lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/dpdx">
+      <label>dpdx</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WT">
+      <label>WT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/tc">
+      <label>tc</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Lambda">
+      <label>Lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/h">
+      <label>h</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/ESF">
+      <label>ESF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/AR">
+      <label>AR</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/M">
+      <label>M</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Theta">
+      <label>Theta</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Sref">
+      <label>Sref</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <problemDefinition uID="converged-MDAGauss-Seidel">
+    <problemFormulation>
+      <mdaoArchitecture>converged-MDA</mdaoArchitecture>
+      <convergerType>Gauss-Seidel</convergerType>
+      <executableBlocksOrder>
+        <executableBlock position="1">StructuralAnalysis</executableBlock>
+        <executableBlock position="2">AeroAnalysis</executableBlock>
+        <executableBlock position="3">PropulsionAnalysis</executableBlock>
+        <executableBlock position="4">PerformanceAnalysis</executableBlock>
+        <executableBlock position="5">C[sigmas]</executableBlock>
+        <executableBlock position="6">C[Theta]</executableBlock>
+        <executableBlock position="7">C[dpdx]</executableBlock>
+        <executableBlock position="8">C[prop]</executableBlock>
+        <executableBlock position="9">F[R]</executableBlock>
+      </executableBlocksOrder>
+      <allowUnconvergedCouplings>false</allowUnconvergedCouplings>
+    </problemFormulation>
+    <problemRoles>
+      <parameters>
+        <stateVariables>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/dpdx/value">
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma5/value">
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/R/value">
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma2/value">
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/Theta/value">
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/aircraft/weight/WE">
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/DT/value">
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/ESF/value">
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma1/value">
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma4/value">
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/Temp/value">
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+          </stateVariable>
+          <stateVariable uID="__statVar__/dataSchema/scaledData/sigma3/value">
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+          </stateVariable>
+        </stateVariables>
+      </parameters>
+      <executableBlocks>
+        <coupledBlocks>
+          <coupledBlock>StructuralAnalysis</coupledBlock>
+          <coupledBlock>AeroAnalysis</coupledBlock>
+          <coupledBlock>PropulsionAnalysis</coupledBlock>
+        </coupledBlocks>
+        <postCouplingBlocks>
+          <postCouplingBlock>PerformanceAnalysis</postCouplingBlock>
+          <postCouplingBlock>C[sigmas]</postCouplingBlock>
+          <postCouplingBlock>C[Theta]</postCouplingBlock>
+          <postCouplingBlock>C[dpdx]</postCouplingBlock>
+          <postCouplingBlock>C[prop]</postCouplingBlock>
+          <postCouplingBlock>F[R]</postCouplingBlock>
+        </postCouplingBlocks>
+      </executableBlocks>
+    </problemRoles>
+  </problemDefinition>
+  <workflow>
+    <problemDefinitionUID>converged-MDAGauss-Seidel</problemDefinitionUID>
+    <dataGraph>
+      <name>XDSM - converged-MDA-GS</name>
+      <edges>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WBE</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/DT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/Temp</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/SFC</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/R</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/R</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/SFC</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Nz</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Theta/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/scaler</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma5</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/fin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/dpdx</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/fin</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WFO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma2</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/DT</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma4</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma1</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma3</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/ESF/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WF</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Theta/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Theta/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/ESF/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/Temp</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/CDmin</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WBE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/T</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/Nz</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/section</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/Cf</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Theta/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WO</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WFO</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/CDmin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/ESF/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/ESF/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/dpdx</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma5</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma4</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma3</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+      </edges>
+    </dataGraph>
+    <processGraph>
+      <name>XDSM - converged-MDA-GS</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+          <processStepNumber>8</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+          <processStepNumber>8</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+          <processStepNumber>8</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>1</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+          <processStepNumber>8</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+          <processStepNumber>8</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+      </edges>
+      <nodes>
+        <node>
+          <referenceUID>F[R]</referenceUID>
+          <processStepNumber>7</processStepNumber>
+          <diagonalPosition>10</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[Theta]</referenceUID>
+          <processStepNumber>6</processStepNumber>
+          <diagonalPosition>7</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[prop]</referenceUID>
+          <processStepNumber>6</processStepNumber>
+          <diagonalPosition>9</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Converger</referenceUID>
+          <processStepNumber>1</processStepNumber>
+          <convergerStepNumber>5</convergerStepNumber>
+          <diagonalPosition>1</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>PropulsionAnalysis</referenceUID>
+          <processStepNumber>4</processStepNumber>
+          <diagonalPosition>4</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Coordinator</referenceUID>
+          <processStepNumber>0</processStepNumber>
+          <convergerStepNumber>8</convergerStepNumber>
+          <diagonalPosition>0</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[dpdx]</referenceUID>
+          <processStepNumber>6</processStepNumber>
+          <diagonalPosition>8</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>AeroAnalysis</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>3</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[sigmas]</referenceUID>
+          <processStepNumber>6</processStepNumber>
+          <diagonalPosition>6</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>StructuralAnalysis</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <diagonalPosition>2</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>PerformanceAnalysis</referenceUID>
+          <processStepNumber>6</processStepNumber>
+          <diagonalPosition>5</diagonalPosition>
+        </node>
+      </nodes>
+      <metadata>
+        <loopNesting>
+          <loopElements>
+            <loopElement relatedUID="Coordinator">
+              <loopElements>
+                <loopElement relatedUID="Converger">
+                  <functionElements>
+                    <functionElement>StructuralAnalysis</functionElement>
+                    <functionElement>AeroAnalysis</functionElement>
+                    <functionElement>PropulsionAnalysis</functionElement>
+                  </functionElements>
+                </loopElement>
+              </loopElements>
+              <functionElements>
+                <functionElement>C[Theta]</functionElement>
+                <functionElement>C[dpdx]</functionElement>
+                <functionElement>C[prop]</functionElement>
+                <functionElement>C[sigmas]</functionElement>
+                <functionElement>PerformanceAnalysis</functionElement>
+                <functionElement>F[R]</functionElement>
+              </functionElements>
+            </loopElement>
+          </loopElements>
+        </loopNesting>
+      </metadata>
+    </processGraph>
+  </workflow>
+  <architectureElements>
+    <parameters>
+      <initialGuessCouplingVariables>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+      </initialGuessCouplingVariables>
+      <finalCouplingVariables>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+      </finalCouplingVariables>
+      <couplingCopyVariables>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+      </couplingCopyVariables>
+    </parameters>
+    <executableBlocks>
+      <coordinators>
+        <coordinator uID="Coordinator">
+          <label>COOR</label>
+        </coordinator>
+      </coordinators>
+      <convergers>
+        <converger uID="Converger">
+          <label>CONV</label>
+          <settings>
+            <linearSolver>
+              <method>Gauss-Seidel</method>
+              <lastIterationsToConsider>1</lastIterationsToConsider>
+              <maximumIterations>100</maximumIterations>
+              <convergenceToleranceRelative>1e-06</convergenceToleranceRelative>
+              <convergenceToleranceAbsolute>1e-06</convergenceToleranceAbsolute>
+            </linearSolver>
+            <nonlinearSolver>
+              <method>Gauss-Seidel</method>
+              <lastIterationsToConsider>1</lastIterationsToConsider>
+              <maximumIterations>100</maximumIterations>
+              <convergenceToleranceRelative>1e-06</convergenceToleranceRelative>
+              <convergenceToleranceAbsolute>1e-06</convergenceToleranceAbsolute>
+            </nonlinearSolver>
+          </settings>
+        </converger>
+      </convergers>
+      <coupledAnalyses>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>PropulsionAnalysis</relatedExecutableBlockUID>
+        </coupledAnalysis>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>AeroAnalysis</relatedExecutableBlockUID>
+        </coupledAnalysis>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>StructuralAnalysis</relatedExecutableBlockUID>
+        </coupledAnalysis>
+      </coupledAnalyses>
+      <postCouplingAnalyses>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>F[R]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>PerformanceAnalysis</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[Theta]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[prop]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[dpdx]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[sigmas]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+      </postCouplingAnalyses>
+    </executableBlocks>
+  </architectureElements>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/ssbj_mdfgs.xml b/kadmos/vistoms/downloads/ssbj_mdfgs.xml
new file mode 100644
index 000000000..88ff86f32
--- /dev/null
+++ b/kadmos/vistoms/downloads/ssbj_mdfgs.xml
@@ -0,0 +1,2470 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>Mdao CMDOWS file of the super-sonic business jet test case optimization problem</description>
+    <timestamp>2018-08-23T18:03:45.528051</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a mdao data graph (MDG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-08-23T18:03:45.528051</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="imcovangent">
+          <function>PhD Student</function>
+          <name>Imco van Gent</name>
+          <country>The Netherlands</country>
+          <company>TU Delft</company>
+          <telephone>0031 6 53 89 42 75</telephone>
+          <address>Kluyverweg 1, 2629 HS, Delft</address>
+          <department>Flight Performance and Propulsion</department>
+          <email>i.vangent@tudelft.nl</email>
+        </contact>
+        <contact uID="remilafage">
+          <name>Remi Lafage</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Remi.Lafage@onera.fr</email>
+        </contact>
+        <contact uID="sylvaindubreuil">
+          <name>Sylvain Dubreuil</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Sylvain.Dubreuil@onera.fr</email>
+        </contact>
+      </contacts>
+      <organigram>
+        <architects>
+          <architect>
+            <contactUID>imcovangent</contactUID>
+          </architect>
+        </architects>
+        <integrators>
+          <integrator>
+            <contactUID>imcovangent</contactUID>
+          </integrator>
+        </integrators>
+        <toolSpecialists>
+          <toolSpecialist>
+            <contactUID>remilafage</contactUID>
+          </toolSpecialist>
+          <toolSpecialist>
+            <contactUID>sylvaindubreuil</contactUID>
+          </toolSpecialist>
+        </toolSpecialists>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <designCompetences>
+      <designCompetence uID="StructuralAnalysis">
+        <label>StructuralAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WFO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Nz</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </output>
+        </outputs>
+        <ID>StructuralAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>StructuralAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\structuralanalysis\StructuralAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the StructuralAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PropulsionAnalysis">
+        <label>PropulsionAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WBE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/reference/ESF</parameterUID>
+          </output>
+        </outputs>
+        <ID>PropulsionAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PropulsionAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\propulsionanalysis\PropulsionAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the PropulsionAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="AeroAnalysis">
+        <label>AeroAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/CDmin</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/L</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/L</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </output>
+        </outputs>
+        <ID>AeroAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>AeroAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\aeroanalysis\AeroAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the AeroAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PerformanceAnalysis">
+        <label>PerformanceAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+          </output>
+        </outputs>
+        <ID>PerformanceAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PerformanceAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\performanceanalysis\PerformanceAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the PerformanceAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+    </designCompetences>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="F[R]">
+        <label>F[R]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/R/scaler</parameterUID>
+            <equationLabel>R_scaler</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+            <equationLabel>R</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+            <equations uID="F[R]_equation">
+              <equation language="Python">-R/R_scaler</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/R/value</parameterUID>
+            <equationsUID>F[R]_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[Theta]">
+        <label>C[Theta]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Theta/scaler</parameterUID>
+            <equationLabel>Theta_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+            <equationLabel>Theta</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Theta/value</parameterUID>
+            <equations uID="C[Theta]_equation">
+              <equation language="Python">Theta/Theta_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+            <equationsUID>C[Theta]_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[dpdx]">
+        <label>C[dpdx]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+            <equationLabel>dpdx</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/dpdx/scaler</parameterUID>
+            <equationLabel>dpdx_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+            <equations uID="C[dpdx]_equation">
+              <equation language="Python">dpdx/dpdx_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/dpdx/value</parameterUID>
+            <equationsUID>C[dpdx]_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[prop]">
+        <label>C[prop]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/DT/scaler</parameterUID>
+            <equationLabel>DT_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+            <equationLabel>DT</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/ESF/scaler</parameterUID>
+            <equationLabel>ESF_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Temp/scaler</parameterUID>
+            <equationLabel>Temp_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+            <equationLabel>ESF</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+            <equationLabel>Temp</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/ESF/value</parameterUID>
+            <equations uID="C[prop]_equation">
+              <equation language="Python">ESF/ESF_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/DT/value</parameterUID>
+            <equations uID="C[prop]_equation_1">
+              <equation language="Python">DT/DT_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+            <equations uID="C[prop]_equation_2">
+              <equation language="Python">Temp/Temp_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Temp/value</parameterUID>
+            <equationsUID>C[prop]_equation_2</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+            <equationsUID>C[prop]_equation_1</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+            <equationsUID>C[prop]_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[sigmas]">
+        <label>C[sigmas]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma4/scaler</parameterUID>
+            <equationLabel>sigma4_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+            <equationLabel>sigma4</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+            <equationLabel>sigma1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+            <equationLabel>sigma3</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+            <equationLabel>sigma2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma3/scaler</parameterUID>
+            <equationLabel>sigma3_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma2/scaler</parameterUID>
+            <equationLabel>sigma2_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma1/scaler</parameterUID>
+            <equationLabel>sigma1_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+            <equationLabel>sigma5</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma5/scaler</parameterUID>
+            <equationLabel>sigma5_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+            <equations uID="C[sigmas]_equation">
+              <equation language="Python">sigma1/sigma1_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma5/value</parameterUID>
+            <equations uID="C[sigmas]_equation_1">
+              <equation language="Python">sigma5/sigma5_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+            <equations uID="C[sigmas]_equation_2">
+              <equation language="Python">sigma2/sigma2_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma2/value</parameterUID>
+            <equationsUID>C[sigmas]_equation_2</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma3/value</parameterUID>
+            <equations uID="C[sigmas]_equation_3">
+              <equation language="Python">sigma3/sigma3_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+            <equationsUID>C[sigmas]_equation_1</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+            <equationsUID>C[sigmas]_equation_3</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma1/value</parameterUID>
+            <equationsUID>C[sigmas]_equation</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+            <equations uID="C[sigmas]_equation_4">
+              <equation language="Python">sigma4/sigma4_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma4/value</parameterUID>
+            <equationsUID>C[sigmas]_equation_4</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/scaledData/R/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/fin">
+      <label>fin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/L">
+      <label>L</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/CDmin">
+      <label>CDmin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/T">
+      <label>T</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/DT">
+      <label>DT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Cf">
+      <label>Cf</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma5">
+      <label>sigma5</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WFO">
+      <label>WFO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma4">
+      <label>sigma4</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma1">
+      <label>sigma1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma3">
+      <label>sigma3</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma2">
+      <label>sigma2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/D">
+      <label>D</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/R">
+      <label>R</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/section">
+      <label>section</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/Temp">
+      <label>Temp</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/dpdx">
+      <label>dpdx</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WBE">
+      <label>WBE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/SFC">
+      <label>SFC</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Nz">
+      <label>Nz</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WF">
+      <label>WF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WE">
+      <label>WE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WO">
+      <label>WO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/lambda">
+      <label>lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/AR">
+      <label>AR</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Theta">
+      <label>Theta</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Lambda">
+      <label>Lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/ESF">
+      <label>ESF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/tc">
+      <label>tc</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/M">
+      <label>M</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Sref">
+      <label>Sref</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/h">
+      <label>h</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WT">
+      <label>WT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <problemDefinition uID="MDFGauss-Seidel">
+    <problemFormulation>
+      <mdaoArchitecture>MDF</mdaoArchitecture>
+      <convergerType>Gauss-Seidel</convergerType>
+      <executableBlocksOrder>
+        <executableBlock position="1">StructuralAnalysis</executableBlock>
+        <executableBlock position="2">AeroAnalysis</executableBlock>
+        <executableBlock position="3">PropulsionAnalysis</executableBlock>
+        <executableBlock position="4">PerformanceAnalysis</executableBlock>
+        <executableBlock position="5">C[sigmas]</executableBlock>
+        <executableBlock position="6">C[Theta]</executableBlock>
+        <executableBlock position="7">C[dpdx]</executableBlock>
+        <executableBlock position="8">C[prop]</executableBlock>
+        <executableBlock position="9">F[R]</executableBlock>
+      </executableBlocksOrder>
+      <allowUnconvergedCouplings>false</allowUnconvergedCouplings>
+    </problemFormulation>
+    <problemRoles>
+      <parameters>
+        <designVariables>
+          <designVariable uID="__desVar__/dataSchema/aircraft/other/T">
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+            <nominalValue>0.2</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.09</minimum>
+                <maximum>0.905</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/other/Cf">
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+            <nominalValue>1.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.75</minimum>
+                <maximum>1.25</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/section">
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+            <nominalValue>1.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.75</minimum>
+                <maximum>1.25</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/lambda">
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+            <nominalValue>0.25</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.1</minimum>
+                <maximum>0.4</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/AR">
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+            <nominalValue>5.5</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>2.475</minimum>
+                <maximum>7.975</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/Lambda">
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+            <nominalValue>55.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>39.6</minimum>
+                <maximum>69.85</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/tc">
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+            <nominalValue>0.05</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.01</minimum>
+                <maximum>0.09</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/reference/M">
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+            <nominalValue>1.6</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>1.4</minimum>
+                <maximum>1.8</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/Sref">
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+            <nominalValue>1000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>500.0</minimum>
+                <maximum>1500.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/reference/h">
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+            <nominalValue>45000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>30000.0</minimum>
+                <maximum>60000.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+        </designVariables>
+        <objectiveVariables>
+          <objectiveVariable uID="__objVar__/dataSchema/scaledData/R/value">
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+          </objectiveVariable>
+        </objectiveVariables>
+        <constraintVariables>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/Theta/value">
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=;&lt;=</constraintOperator>
+            <referenceValue>0.96;1.04</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/ESF/value">
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=;&lt;=</constraintOperator>
+            <referenceValue>0.5;1.5</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/dpdx/value">
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.04</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma2/value">
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/Temp/value">
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.02</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma5/value">
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma4/value">
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/DT/value">
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma1/value">
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma3/value">
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+        </constraintVariables>
+      </parameters>
+      <executableBlocks>
+        <coupledBlocks>
+          <coupledBlock>StructuralAnalysis</coupledBlock>
+          <coupledBlock>AeroAnalysis</coupledBlock>
+          <coupledBlock>PropulsionAnalysis</coupledBlock>
+        </coupledBlocks>
+        <postCouplingBlocks>
+          <postCouplingBlock>PerformanceAnalysis</postCouplingBlock>
+          <postCouplingBlock>C[sigmas]</postCouplingBlock>
+          <postCouplingBlock>C[Theta]</postCouplingBlock>
+          <postCouplingBlock>C[dpdx]</postCouplingBlock>
+          <postCouplingBlock>C[prop]</postCouplingBlock>
+          <postCouplingBlock>F[R]</postCouplingBlock>
+        </postCouplingBlocks>
+      </executableBlocks>
+    </problemRoles>
+  </problemDefinition>
+  <workflow>
+    <problemDefinitionUID>MDFGauss-Seidel</problemDefinitionUID>
+    <dataGraph>
+      <name>XDSM - MDF-GS</name>
+      <edges>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/scaler</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Theta/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/fin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/dpdx</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/fin</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Theta/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Theta/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/ESF/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/CDmin</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WBE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/Cf</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/Nz</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Theta/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WO</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WFO</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/section</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/CDmin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/T</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/ESF/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma2/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/DT</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/Cf</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/T</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/T</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/section</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/Cf</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/section</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma5</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WFO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/R/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/h</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma4</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma1</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma3</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma2</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/M</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma5</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma4</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma3</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/R/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/ESF/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/DT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Temp/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/ESF/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/R</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Theta/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Theta/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/R</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/dpdx/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/DT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/Temp</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/SFC</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma4/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/Temp</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/dpdx</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WBE</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/SFC</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/dpdx/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Nz</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/ESF/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma5/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma2/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma3/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma1/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma4/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/h</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma3/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WF</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma5/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Temp/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/DT/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/M</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/ESF/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma1/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+      </edges>
+    </dataGraph>
+    <processGraph>
+      <name>XDSM - MDF-GS</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>9</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+          <processStepNumber>10</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>9</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>9</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+          <processStepNumber>8</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>1</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>9</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>9</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+      </edges>
+      <nodes>
+        <node>
+          <referenceUID>F[R]</referenceUID>
+          <processStepNumber>8</processStepNumber>
+          <diagonalPosition>11</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Optimizer</referenceUID>
+          <processStepNumber>1</processStepNumber>
+          <convergerStepNumber>9</convergerStepNumber>
+          <diagonalPosition>1</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[Theta]</referenceUID>
+          <processStepNumber>7</processStepNumber>
+          <diagonalPosition>8</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[prop]</referenceUID>
+          <processStepNumber>7</processStepNumber>
+          <diagonalPosition>10</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Converger</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <convergerStepNumber>6</convergerStepNumber>
+          <diagonalPosition>2</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>PerformanceAnalysis</referenceUID>
+          <processStepNumber>7</processStepNumber>
+          <diagonalPosition>6</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Coordinator</referenceUID>
+          <processStepNumber>0</processStepNumber>
+          <convergerStepNumber>10</convergerStepNumber>
+          <diagonalPosition>0</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[dpdx]</referenceUID>
+          <processStepNumber>7</processStepNumber>
+          <diagonalPosition>9</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>AeroAnalysis</referenceUID>
+          <processStepNumber>4</processStepNumber>
+          <diagonalPosition>4</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[sigmas]</referenceUID>
+          <processStepNumber>7</processStepNumber>
+          <diagonalPosition>7</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>StructuralAnalysis</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>3</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>PropulsionAnalysis</referenceUID>
+          <processStepNumber>5</processStepNumber>
+          <diagonalPosition>5</diagonalPosition>
+        </node>
+      </nodes>
+      <metadata>
+        <loopNesting>
+          <loopElements>
+            <loopElement relatedUID="Coordinator">
+              <loopElements>
+                <loopElement relatedUID="Optimizer">
+                  <loopElements>
+                    <loopElement relatedUID="Converger">
+                      <functionElements>
+                        <functionElement>StructuralAnalysis</functionElement>
+                        <functionElement>AeroAnalysis</functionElement>
+                        <functionElement>PropulsionAnalysis</functionElement>
+                      </functionElements>
+                    </loopElement>
+                  </loopElements>
+                  <functionElements>
+                    <functionElement>C[Theta]</functionElement>
+                    <functionElement>C[dpdx]</functionElement>
+                    <functionElement>C[prop]</functionElement>
+                    <functionElement>C[sigmas]</functionElement>
+                    <functionElement>PerformanceAnalysis</functionElement>
+                    <functionElement>F[R]</functionElement>
+                  </functionElements>
+                </loopElement>
+              </loopElements>
+            </loopElement>
+          </loopElements>
+        </loopNesting>
+      </metadata>
+    </processGraph>
+  </workflow>
+  <architectureElements>
+    <parameters>
+      <initialGuessCouplingVariables>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+      </initialGuessCouplingVariables>
+      <finalCouplingVariables>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+      </finalCouplingVariables>
+      <couplingCopyVariables>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+      </couplingCopyVariables>
+      <initialGuessDesignVariables>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/Cf">
+          <relatedParameterUID>/dataSchema/aircraft/other/Cf</relatedParameterUID>
+          <label>Cf^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/tc">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/tc</relatedParameterUID>
+          <label>tc^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/h">
+          <relatedParameterUID>/dataSchema/reference/h</relatedParameterUID>
+          <label>h^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/section">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/section</relatedParameterUID>
+          <label>section^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/M">
+          <relatedParameterUID>/dataSchema/reference/M</relatedParameterUID>
+          <label>M^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/T">
+          <relatedParameterUID>/dataSchema/aircraft/other/T</relatedParameterUID>
+          <label>T^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/AR">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/AR</relatedParameterUID>
+          <label>AR^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Lambda</relatedParameterUID>
+          <label>Lambda^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/lambda</relatedParameterUID>
+          <label>lambda^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Sref">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Sref</relatedParameterUID>
+          <label>Sref^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+      </initialGuessDesignVariables>
+      <finalDesignVariables>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Sref">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Sref</relatedParameterUID>
+          <label>Sref^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/Cf">
+          <relatedParameterUID>/dataSchema/aircraft/other/Cf</relatedParameterUID>
+          <label>Cf^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/tc">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/tc</relatedParameterUID>
+          <label>tc^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/AR">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/AR</relatedParameterUID>
+          <label>AR^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/lambda</relatedParameterUID>
+          <label>lambda^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/T">
+          <relatedParameterUID>/dataSchema/aircraft/other/T</relatedParameterUID>
+          <label>T^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/section">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/section</relatedParameterUID>
+          <label>section^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Lambda</relatedParameterUID>
+          <label>Lambda^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/h">
+          <relatedParameterUID>/dataSchema/reference/h</relatedParameterUID>
+          <label>h^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/M">
+          <relatedParameterUID>/dataSchema/reference/M</relatedParameterUID>
+          <label>M^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+      </finalDesignVariables>
+      <finalOutputVariables>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Theta/value">
+          <relatedParameterUID>/dataSchema/scaledData/Theta/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma2/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma2/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/R/value">
+          <relatedParameterUID>/dataSchema/scaledData/R/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma4/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma4/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/dpdx/value">
+          <relatedParameterUID>/dataSchema/scaledData/dpdx/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/ESF/value">
+          <relatedParameterUID>/dataSchema/scaledData/ESF/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma3/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma3/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma5/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma5/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Temp/value">
+          <relatedParameterUID>/dataSchema/scaledData/Temp/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/DT/value">
+          <relatedParameterUID>/dataSchema/scaledData/DT/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma1/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma1/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+      </finalOutputVariables>
+    </parameters>
+    <executableBlocks>
+      <coordinators>
+        <coordinator uID="Coordinator">
+          <label>COOR</label>
+        </coordinator>
+      </coordinators>
+      <optimizers>
+        <optimizer uID="Optimizer">
+          <label>OPT</label>
+          <settings>
+            <package>SciPy</package>
+            <algorithm>SLSQP</algorithm>
+            <maximumIterations>1000</maximumIterations>
+            <maximumFunctionEvaluations>1000</maximumFunctionEvaluations>
+            <convergenceTolerance>1e-06</convergenceTolerance>
+            <constraintTolerance>1e-06</constraintTolerance>
+            <applyScaling>true</applyScaling>
+          </settings>
+          <designVariables>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/other/Cf</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/reference/h</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/Lambda</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/reference/M</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/lambda</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/other/T</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/tc</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/section</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/AR</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/Sref</designVariableUID>
+            </designVariable>
+          </designVariables>
+          <objectiveVariables>
+            <objectiveVariable>
+              <objectiveVariableUID>__objVar__/dataSchema/scaledData/R/value</objectiveVariableUID>
+            </objectiveVariable>
+          </objectiveVariables>
+          <constraintVariables>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/dpdx/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma2/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma1/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/Temp/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/Theta/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma5/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/DT/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma3/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma4/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/ESF/value</constraintVariableUID>
+            </constraintVariable>
+          </constraintVariables>
+        </optimizer>
+      </optimizers>
+      <convergers>
+        <converger uID="Converger">
+          <label>CONV</label>
+          <settings>
+            <linearSolver>
+              <method>Gauss-Seidel</method>
+              <lastIterationsToConsider>1</lastIterationsToConsider>
+              <maximumIterations>100</maximumIterations>
+              <convergenceToleranceRelative>1e-06</convergenceToleranceRelative>
+              <convergenceToleranceAbsolute>1e-06</convergenceToleranceAbsolute>
+            </linearSolver>
+            <nonlinearSolver>
+              <method>Gauss-Seidel</method>
+              <lastIterationsToConsider>1</lastIterationsToConsider>
+              <maximumIterations>100</maximumIterations>
+              <convergenceToleranceRelative>1e-06</convergenceToleranceRelative>
+              <convergenceToleranceAbsolute>1e-06</convergenceToleranceAbsolute>
+            </nonlinearSolver>
+          </settings>
+        </converger>
+      </convergers>
+      <coupledAnalyses>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>AeroAnalysis</relatedExecutableBlockUID>
+        </coupledAnalysis>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>StructuralAnalysis</relatedExecutableBlockUID>
+        </coupledAnalysis>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>PropulsionAnalysis</relatedExecutableBlockUID>
+        </coupledAnalysis>
+      </coupledAnalyses>
+      <postCouplingAnalyses>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>F[R]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[prop]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[Theta]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>PerformanceAnalysis</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[dpdx]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[sigmas]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+      </postCouplingAnalyses>
+    </executableBlocks>
+  </architectureElements>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/ssbj_mdfj.xml b/kadmos/vistoms/downloads/ssbj_mdfj.xml
new file mode 100644
index 000000000..e2413af25
--- /dev/null
+++ b/kadmos/vistoms/downloads/ssbj_mdfj.xml
@@ -0,0 +1,2606 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>Mdao CMDOWS file of the super-sonic business jet test case optimization problem</description>
+    <timestamp>2018-08-23T09:37:26.622553</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a mdao data graph (MDG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-08-23T09:37:26.622553</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="imcovangent">
+          <function>PhD Student</function>
+          <name>Imco van Gent</name>
+          <country>The Netherlands</country>
+          <company>TU Delft</company>
+          <telephone>0031 6 53 89 42 75</telephone>
+          <address>Kluyverweg 1, 2629 HS, Delft</address>
+          <department>Flight Performance and Propulsion</department>
+          <email>i.vangent@tudelft.nl</email>
+        </contact>
+        <contact uID="remilafage">
+          <name>Remi Lafage</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Remi.Lafage@onera.fr</email>
+        </contact>
+        <contact uID="sylvaindubreuil">
+          <name>Sylvain Dubreuil</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Sylvain.Dubreuil@onera.fr</email>
+        </contact>
+      </contacts>
+      <organigram>
+        <architects>
+          <architect>
+            <contactUID>imcovangent</contactUID>
+          </architect>
+        </architects>
+        <integrators>
+          <integrator>
+            <contactUID>imcovangent</contactUID>
+          </integrator>
+        </integrators>
+        <toolSpecialists>
+          <toolSpecialist>
+            <contactUID>remilafage</contactUID>
+          </toolSpecialist>
+          <toolSpecialist>
+            <contactUID>sylvaindubreuil</contactUID>
+          </toolSpecialist>
+        </toolSpecialists>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <designCompetences>
+      <designCompetence uID="StructuralAnalysis">
+        <label>StructuralAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WFO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Nz</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/geometry/Theta</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WT</parameterUID>
+          </output>
+        </outputs>
+        <ID>StructuralAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>StructuralAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\structuralanalysis\StructuralAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the StructuralAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PropulsionAnalysis">
+        <label>PropulsionAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WBE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/D</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/reference/ESF</parameterUID>
+          </output>
+        </outputs>
+        <ID>PropulsionAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PropulsionAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\propulsionanalysis\PropulsionAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the PropulsionAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="AeroAnalysis">
+        <label>AeroAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/geometry/Theta</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/CDmin</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/L</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/L</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/D</parameterUID>
+          </output>
+        </outputs>
+        <ID>AeroAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>AeroAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\aeroanalysis\AeroAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the AeroAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PerformanceAnalysis">
+        <label>PerformanceAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+          </output>
+        </outputs>
+        <ID>PerformanceAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PerformanceAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\performanceanalysis\PerformanceAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <operatingSystem>Windows</operatingSystem>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <description>Details for the command line execution of the PerformanceAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+    </designCompetences>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="F[R]">
+        <label>F[R]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/R/scaler</parameterUID>
+            <equationLabel>R_scaler</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+            <equationLabel>R</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+            <equations uID="F[R]_equation">
+              <equation language="Python">-R/R_scaler</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/R/value</parameterUID>
+            <equationsUID>F[R]_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[Theta]">
+        <label>C[Theta]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Theta/scaler</parameterUID>
+            <equationLabel>Theta_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+            <equationLabel>Theta</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Theta/value</parameterUID>
+            <equations uID="C[Theta]_equation">
+              <equation language="Python">Theta/Theta_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+            <equationsUID>C[Theta]_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[dpdx]">
+        <label>C[dpdx]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+            <equationLabel>dpdx</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/dpdx/scaler</parameterUID>
+            <equationLabel>dpdx_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+            <equations uID="C[dpdx]_equation">
+              <equation language="Python">dpdx/dpdx_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/dpdx/value</parameterUID>
+            <equationsUID>C[dpdx]_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[prop]">
+        <label>C[prop]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/DT/scaler</parameterUID>
+            <equationLabel>DT_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+            <equationLabel>DT</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/ESF/scaler</parameterUID>
+            <equationLabel>ESF_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Temp/scaler</parameterUID>
+            <equationLabel>Temp_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+            <equationLabel>ESF</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+            <equationLabel>Temp</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/ESF/value</parameterUID>
+            <equations uID="C[prop]_equation">
+              <equation language="Python">ESF/ESF_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/DT/value</parameterUID>
+            <equations uID="C[prop]_equation_1">
+              <equation language="Python">DT/DT_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+            <equations uID="C[prop]_equation_2">
+              <equation language="Python">Temp/Temp_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Temp/value</parameterUID>
+            <equationsUID>C[prop]_equation_2</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+            <equationsUID>C[prop]_equation_1</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+            <equationsUID>C[prop]_equation</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[sigmas]">
+        <label>C[sigmas]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma4/scaler</parameterUID>
+            <equationLabel>sigma4_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+            <equationLabel>sigma4</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+            <equationLabel>sigma1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+            <equationLabel>sigma3</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+            <equationLabel>sigma2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma3/scaler</parameterUID>
+            <equationLabel>sigma3_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma2/scaler</parameterUID>
+            <equationLabel>sigma2_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma1/scaler</parameterUID>
+            <equationLabel>sigma1_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+            <equationLabel>sigma5</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma5/scaler</parameterUID>
+            <equationLabel>sigma5_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+            <equations uID="C[sigmas]_equation">
+              <equation language="Python">sigma1/sigma1_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma5/value</parameterUID>
+            <equations uID="C[sigmas]_equation_1">
+              <equation language="Python">sigma5/sigma5_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+            <equations uID="C[sigmas]_equation_2">
+              <equation language="Python">sigma2/sigma2_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma2/value</parameterUID>
+            <equationsUID>C[sigmas]_equation_2</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma3/value</parameterUID>
+            <equations uID="C[sigmas]_equation_3">
+              <equation language="Python">sigma3/sigma3_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+            <equationsUID>C[sigmas]_equation_1</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+            <equationsUID>C[sigmas]_equation_3</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma1/value</parameterUID>
+            <equationsUID>C[sigmas]_equation</equationsUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+            <equations uID="C[sigmas]_equation_4">
+              <equation language="Python">sigma4/sigma4_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma4/value</parameterUID>
+            <equationsUID>C[sigmas]_equation_4</equationsUID>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/scaledData/R/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/fin">
+      <label>fin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/L">
+      <label>L</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/CDmin">
+      <label>CDmin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/T">
+      <label>T</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/DT">
+      <label>DT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Cf">
+      <label>Cf</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma5">
+      <label>sigma5</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WFO">
+      <label>WFO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma4">
+      <label>sigma4</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma1">
+      <label>sigma1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma3">
+      <label>sigma3</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma2">
+      <label>sigma2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/D">
+      <label>D</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/R">
+      <label>R</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/section">
+      <label>section</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/Temp">
+      <label>Temp</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/dpdx">
+      <label>dpdx</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WBE">
+      <label>WBE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/SFC">
+      <label>SFC</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Nz">
+      <label>Nz</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WF">
+      <label>WF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WE">
+      <label>WE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WO">
+      <label>WO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/lambda">
+      <label>lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/AR">
+      <label>AR</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Theta">
+      <label>Theta</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Lambda">
+      <label>Lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/ESF">
+      <label>ESF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/tc">
+      <label>tc</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/M">
+      <label>M</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Sref">
+      <label>Sref</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/h">
+      <label>h</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WT">
+      <label>WT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <problemDefinition uID="MDFJacobi">
+    <problemFormulation>
+      <mdaoArchitecture>MDF</mdaoArchitecture>
+      <convergerType>Jacobi</convergerType>
+      <executableBlocksOrder>
+        <executableBlock position="1">StructuralAnalysis</executableBlock>
+        <executableBlock position="2">AeroAnalysis</executableBlock>
+        <executableBlock position="3">PropulsionAnalysis</executableBlock>
+        <executableBlock position="4">PerformanceAnalysis</executableBlock>
+        <executableBlock position="5">C[sigmas]</executableBlock>
+        <executableBlock position="6">C[Theta]</executableBlock>
+        <executableBlock position="7">C[dpdx]</executableBlock>
+        <executableBlock position="8">C[prop]</executableBlock>
+        <executableBlock position="9">F[R]</executableBlock>
+      </executableBlocksOrder>
+      <allowUnconvergedCouplings>false</allowUnconvergedCouplings>
+    </problemFormulation>
+    <problemRoles>
+      <parameters>
+        <designVariables>
+          <designVariable uID="__desVar__/dataSchema/aircraft/other/T">
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+            <nominalValue>0.2</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.09</minimum>
+                <maximum>0.905</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/other/Cf">
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+            <nominalValue>1.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.75</minimum>
+                <maximum>1.25</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/section">
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+            <nominalValue>1.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.75</minimum>
+                <maximum>1.25</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/lambda">
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+            <nominalValue>0.25</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.1</minimum>
+                <maximum>0.4</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/AR">
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+            <nominalValue>5.5</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>2.475</minimum>
+                <maximum>7.975</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/Lambda">
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+            <nominalValue>55.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>39.6</minimum>
+                <maximum>69.85</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/tc">
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+            <nominalValue>0.05</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>0.01</minimum>
+                <maximum>0.09</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/reference/M">
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+            <nominalValue>1.6</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>1.4</minimum>
+                <maximum>1.8</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/aircraft/geometry/Sref">
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+            <nominalValue>1000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>500.0</minimum>
+                <maximum>1500.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+          <designVariable uID="__desVar__/dataSchema/reference/h">
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+            <nominalValue>45000.0</nominalValue>
+            <validRanges>
+              <limitRange>
+                <minimum>30000.0</minimum>
+                <maximum>60000.0</maximum>
+              </limitRange>
+            </validRanges>
+          </designVariable>
+        </designVariables>
+        <objectiveVariables>
+          <objectiveVariable uID="__objVar__/dataSchema/scaledData/R/value">
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+          </objectiveVariable>
+        </objectiveVariables>
+        <constraintVariables>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/Theta/value">
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=;&lt;=</constraintOperator>
+            <referenceValue>0.96;1.04</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/ESF/value">
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&gt;=;&lt;=</constraintOperator>
+            <referenceValue>0.5;1.5</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/dpdx/value">
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.04</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma2/value">
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/Temp/value">
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.02</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma5/value">
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma4/value">
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/DT/value">
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>0.0</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma1/value">
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+          <constraintVariable uID="__conVar__/dataSchema/scaledData/sigma3/value">
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+            <constraintType>inequality</constraintType>
+            <constraintOperator>&lt;=</constraintOperator>
+            <referenceValue>1.09</referenceValue>
+          </constraintVariable>
+        </constraintVariables>
+      </parameters>
+      <executableBlocks>
+        <coupledBlocks>
+          <coupledBlock>StructuralAnalysis</coupledBlock>
+          <coupledBlock>AeroAnalysis</coupledBlock>
+          <coupledBlock>PropulsionAnalysis</coupledBlock>
+        </coupledBlocks>
+        <postCouplingBlocks>
+          <postCouplingBlock>PerformanceAnalysis</postCouplingBlock>
+          <postCouplingBlock>C[sigmas]</postCouplingBlock>
+          <postCouplingBlock>C[Theta]</postCouplingBlock>
+          <postCouplingBlock>C[dpdx]</postCouplingBlock>
+          <postCouplingBlock>C[prop]</postCouplingBlock>
+          <postCouplingBlock>F[R]</postCouplingBlock>
+        </postCouplingBlocks>
+      </executableBlocks>
+    </problemRoles>
+  </problemDefinition>
+  <workflow>
+    <problemDefinitionUID>MDFJacobi</problemDefinitionUID>
+    <dataGraph>
+      <name>XDSM - MDF-J</name>
+      <edges>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/scaler</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Theta/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/dpdx</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/fin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/fin</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Theta/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Theta/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/ESF/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/CDmin</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WBE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/Cf</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/Nz</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Theta/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/section</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WO</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WFO</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/CDmin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/T</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/ESF/scaler</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma2/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/DT</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/Cf</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/T</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/T</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/tc</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Lambda</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/M</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Sref</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/h</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/section</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/AR</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/Cf</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/section</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma5</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WFO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/R/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/h</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma4</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma1</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma3</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma2</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/M</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma5</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma4</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma3</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/R/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/ESF/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/DT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Temp/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/ESF/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/R</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Theta/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Theta/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/R</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/dpdx/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/DT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/Temp</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/SFC</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma4/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/Temp</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/dpdx</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WBE</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/SFC</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/dpdx/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Nz</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/ESF/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma5/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma2/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma3/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma1/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma4/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/h</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma3/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WF</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma5/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Temp/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/DT/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/M</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/ESF/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/value</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma1/value</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+        </edge>
+      </edges>
+    </dataGraph>
+    <processGraph>
+      <name>XDSM - MDF-J</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Coordinator</toExecutableBlockUID>
+          <processStepNumber>8</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Optimizer</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>2</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+          <processStepNumber>3</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Converger</fromExecutableBlockUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+          <processStepNumber>5</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+          <processStepNumber>6</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>Coordinator</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>1</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toExecutableBlockUID>Optimizer</toExecutableBlockUID>
+          <processStepNumber>7</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toExecutableBlockUID>Converger</toExecutableBlockUID>
+          <processStepNumber>4</processStepNumber>
+        </edge>
+      </edges>
+      <nodes>
+        <node>
+          <referenceUID>F[R]</referenceUID>
+          <processStepNumber>6</processStepNumber>
+          <diagonalPosition>11</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Optimizer</referenceUID>
+          <processStepNumber>1</processStepNumber>
+          <convergerStepNumber>7</convergerStepNumber>
+          <diagonalPosition>1</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[Theta]</referenceUID>
+          <processStepNumber>5</processStepNumber>
+          <diagonalPosition>8</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[prop]</referenceUID>
+          <processStepNumber>5</processStepNumber>
+          <diagonalPosition>10</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Converger</referenceUID>
+          <processStepNumber>2</processStepNumber>
+          <convergerStepNumber>4</convergerStepNumber>
+          <diagonalPosition>2</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>PerformanceAnalysis</referenceUID>
+          <processStepNumber>5</processStepNumber>
+          <diagonalPosition>6</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>Coordinator</referenceUID>
+          <processStepNumber>0</processStepNumber>
+          <convergerStepNumber>8</convergerStepNumber>
+          <diagonalPosition>0</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[dpdx]</referenceUID>
+          <processStepNumber>5</processStepNumber>
+          <diagonalPosition>9</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>AeroAnalysis</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>4</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>C[sigmas]</referenceUID>
+          <processStepNumber>5</processStepNumber>
+          <diagonalPosition>7</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>StructuralAnalysis</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>3</diagonalPosition>
+        </node>
+        <node>
+          <referenceUID>PropulsionAnalysis</referenceUID>
+          <processStepNumber>3</processStepNumber>
+          <diagonalPosition>5</diagonalPosition>
+        </node>
+      </nodes>
+      <metadata>
+        <loopNesting>
+          <loopElements>
+            <loopElement relatedUID="Coordinator">
+              <loopElements>
+                <loopElement relatedUID="Optimizer">
+                  <loopElements>
+                    <loopElement relatedUID="Converger">
+                      <functionElements>
+                        <functionElement>AeroAnalysis</functionElement>
+                        <functionElement>PropulsionAnalysis</functionElement>
+                        <functionElement>StructuralAnalysis</functionElement>
+                      </functionElements>
+                    </loopElement>
+                  </loopElements>
+                  <functionElements>
+                    <functionElement>C[Theta]</functionElement>
+                    <functionElement>C[dpdx]</functionElement>
+                    <functionElement>C[prop]</functionElement>
+                    <functionElement>C[sigmas]</functionElement>
+                    <functionElement>PerformanceAnalysis</functionElement>
+                    <functionElement>F[R]</functionElement>
+                  </functionElements>
+                </loopElement>
+              </loopElements>
+            </loopElement>
+          </loopElements>
+        </loopNesting>
+      </metadata>
+    </processGraph>
+  </workflow>
+  <architectureElements>
+    <parameters>
+      <initialGuessCouplingVariables>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/D">
+          <relatedParameterUID>/dataSchema/aircraft/other/D</relatedParameterUID>
+          <label>D^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/geometry/Theta">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Theta</relatedParameterUID>
+          <label>Theta^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+        <initialGuessCouplingVariable uID="/dataSchema/architectureNodes/initialGuessCouplingVariables/dataSchemaCopy/aircraft/weight/WT">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WT</relatedParameterUID>
+          <label>WT^{c0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessCouplingVariable>
+      </initialGuessCouplingVariables>
+      <finalCouplingVariables>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/weight/WT">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WT</relatedParameterUID>
+          <label>WT^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/geometry/Theta">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Theta</relatedParameterUID>
+          <label>Theta^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+        <finalCouplingVariable uID="/dataSchema/architectureNodes/finalCouplingVariables/dataSchemaCopy/aircraft/other/D">
+          <relatedParameterUID>/dataSchema/aircraft/other/D</relatedParameterUID>
+          <label>D^{*}</label>
+          <instanceID>1</instanceID>
+        </finalCouplingVariable>
+      </finalCouplingVariables>
+      <couplingCopyVariables>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/geometry/Theta">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Theta</relatedParameterUID>
+          <label>Theta^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WE">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WE</relatedParameterUID>
+          <label>WE^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/weight/WT">
+          <relatedParameterUID>/dataSchema/aircraft/weight/WT</relatedParameterUID>
+          <label>WT^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/L">
+          <relatedParameterUID>/dataSchema/aircraft/other/L</relatedParameterUID>
+          <label>L^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/aircraft/other/D">
+          <relatedParameterUID>/dataSchema/aircraft/other/D</relatedParameterUID>
+          <label>D^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+        <couplingCopyVariable uID="/dataSchema/architectureNodes/couplingCopyVariables/dataSchemaCopy/reference/ESF">
+          <relatedParameterUID>/dataSchema/reference/ESF</relatedParameterUID>
+          <label>ESF^{c}</label>
+          <instanceID>1</instanceID>
+        </couplingCopyVariable>
+      </couplingCopyVariables>
+      <initialGuessDesignVariables>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/Cf">
+          <relatedParameterUID>/dataSchema/aircraft/other/Cf</relatedParameterUID>
+          <label>Cf^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/tc">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/tc</relatedParameterUID>
+          <label>tc^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/h">
+          <relatedParameterUID>/dataSchema/reference/h</relatedParameterUID>
+          <label>h^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/section">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/section</relatedParameterUID>
+          <label>section^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/reference/M">
+          <relatedParameterUID>/dataSchema/reference/M</relatedParameterUID>
+          <label>M^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/other/T">
+          <relatedParameterUID>/dataSchema/aircraft/other/T</relatedParameterUID>
+          <label>T^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/AR">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/AR</relatedParameterUID>
+          <label>AR^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Lambda</relatedParameterUID>
+          <label>Lambda^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/lambda</relatedParameterUID>
+          <label>lambda^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+        <initialGuessDesignVariable uID="/dataSchema/architectureNodes/initialGuessDesignVariables/dataSchemaCopy/aircraft/geometry/Sref">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Sref</relatedParameterUID>
+          <label>Sref^{0}</label>
+          <instanceID>1</instanceID>
+        </initialGuessDesignVariable>
+      </initialGuessDesignVariables>
+      <finalDesignVariables>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Sref">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Sref</relatedParameterUID>
+          <label>Sref^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/Cf">
+          <relatedParameterUID>/dataSchema/aircraft/other/Cf</relatedParameterUID>
+          <label>Cf^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/tc">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/tc</relatedParameterUID>
+          <label>tc^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/AR">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/AR</relatedParameterUID>
+          <label>AR^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/other/T">
+          <relatedParameterUID>/dataSchema/aircraft/other/T</relatedParameterUID>
+          <label>T^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/lambda</relatedParameterUID>
+          <label>lambda^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/section">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/section</relatedParameterUID>
+          <label>section^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/aircraft/geometry/Lambda">
+          <relatedParameterUID>/dataSchema/aircraft/geometry/Lambda</relatedParameterUID>
+          <label>Lambda^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/h">
+          <relatedParameterUID>/dataSchema/reference/h</relatedParameterUID>
+          <label>h^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+        <finalDesignVariable uID="/dataSchema/architectureNodes/finalDesignVariables/dataSchemaCopy/reference/M">
+          <relatedParameterUID>/dataSchema/reference/M</relatedParameterUID>
+          <label>M^{*}</label>
+          <instanceID>1</instanceID>
+        </finalDesignVariable>
+      </finalDesignVariables>
+      <finalOutputVariables>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Theta/value">
+          <relatedParameterUID>/dataSchema/scaledData/Theta/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma2/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma2/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/R/value">
+          <relatedParameterUID>/dataSchema/scaledData/R/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma4/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma4/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/dpdx/value">
+          <relatedParameterUID>/dataSchema/scaledData/dpdx/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/ESF/value">
+          <relatedParameterUID>/dataSchema/scaledData/ESF/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma3/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma3/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma5/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma5/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/Temp/value">
+          <relatedParameterUID>/dataSchema/scaledData/Temp/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/DT/value">
+          <relatedParameterUID>/dataSchema/scaledData/DT/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+        <finalOutputVariable uID="/dataSchema/architectureNodes/finalOutputVariables/dataSchemaCopy/scaledData/sigma1/value">
+          <relatedParameterUID>/dataSchema/scaledData/sigma1/value</relatedParameterUID>
+          <label>value^{*}</label>
+          <instanceID>1</instanceID>
+        </finalOutputVariable>
+      </finalOutputVariables>
+    </parameters>
+    <executableBlocks>
+      <coordinators>
+        <coordinator uID="Coordinator">
+          <label>COOR</label>
+        </coordinator>
+      </coordinators>
+      <optimizers>
+        <optimizer uID="Optimizer">
+          <label>OPT</label>
+          <settings>
+            <package>SciPy</package>
+            <algorithm>SLSQP</algorithm>
+            <maximumIterations>1000</maximumIterations>
+            <maximumFunctionEvaluations>1000</maximumFunctionEvaluations>
+            <convergenceTolerance>1e-06</convergenceTolerance>
+            <constraintTolerance>1e-06</constraintTolerance>
+            <applyScaling>true</applyScaling>
+          </settings>
+          <designVariables>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/other/Cf</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/reference/h</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/Lambda</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/reference/M</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/lambda</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/other/T</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/tc</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/section</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/AR</designVariableUID>
+            </designVariable>
+            <designVariable>
+              <designVariableUID>__desVar__/dataSchema/aircraft/geometry/Sref</designVariableUID>
+            </designVariable>
+          </designVariables>
+          <objectiveVariables>
+            <objectiveVariable>
+              <objectiveVariableUID>__objVar__/dataSchema/scaledData/R/value</objectiveVariableUID>
+            </objectiveVariable>
+          </objectiveVariables>
+          <constraintVariables>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/dpdx/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma2/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma1/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/Temp/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/Theta/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma5/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/DT/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma3/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/sigma4/value</constraintVariableUID>
+            </constraintVariable>
+            <constraintVariable>
+              <constraintVariableUID>__conVar__/dataSchema/scaledData/ESF/value</constraintVariableUID>
+            </constraintVariable>
+          </constraintVariables>
+        </optimizer>
+      </optimizers>
+      <convergers>
+        <converger uID="Converger">
+          <label>CONV</label>
+          <settings>
+            <linearSolver>
+              <method>Jacobi</method>
+              <lastIterationsToConsider>1</lastIterationsToConsider>
+              <maximumIterations>100</maximumIterations>
+              <convergenceToleranceRelative>1e-06</convergenceToleranceRelative>
+              <convergenceToleranceAbsolute>1e-06</convergenceToleranceAbsolute>
+            </linearSolver>
+            <nonlinearSolver>
+              <method>Jacobi</method>
+              <lastIterationsToConsider>1</lastIterationsToConsider>
+              <maximumIterations>100</maximumIterations>
+              <convergenceToleranceRelative>1e-06</convergenceToleranceRelative>
+              <convergenceToleranceAbsolute>1e-06</convergenceToleranceAbsolute>
+            </nonlinearSolver>
+          </settings>
+        </converger>
+      </convergers>
+      <coupledAnalyses>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>AeroAnalysis</relatedExecutableBlockUID>
+        </coupledAnalysis>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>StructuralAnalysis</relatedExecutableBlockUID>
+        </coupledAnalysis>
+        <coupledAnalysis>
+          <relatedExecutableBlockUID>PropulsionAnalysis</relatedExecutableBlockUID>
+        </coupledAnalysis>
+      </coupledAnalyses>
+      <postCouplingAnalyses>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>F[R]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[prop]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[Theta]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>PerformanceAnalysis</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[dpdx]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+        <postCouplingAnalysis>
+          <relatedExecutableBlockUID>C[sigmas]</relatedExecutableBlockUID>
+        </postCouplingAnalysis>
+      </postCouplingAnalyses>
+    </executableBlocks>
+  </architectureElements>
+</cmdows>
diff --git a/kadmos/vistoms/downloads/ssbj_rcg.xml b/kadmos/vistoms/downloads/ssbj_rcg.xml
new file mode 100644
index 000000000..b7c295d41
--- /dev/null
+++ b/kadmos/vistoms/downloads/ssbj_rcg.xml
@@ -0,0 +1,1195 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<cmdows xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://bitbucket.org/imcovangent/cmdows/raw/master/schema/0.9/cmdows.xsd">
+  <header>
+    <creator>Imco van Gent</creator>
+    <description>RCG CMDOWS file of the super-sonic business jet test case</description>
+    <timestamp>2018-09-05T13:58:10.328136</timestamp>
+    <fileVersion>0.1</fileVersion>
+    <cmdowsVersion>0.9</cmdowsVersion>
+    <updates>
+      <update>
+        <modification>KADMOS export of a repository connectivity graph (RCG).</modification>
+        <creator>Imco van Gent</creator>
+        <timestamp>2018-09-05T13:58:10.328136</timestamp>
+        <fileVersion>0.1</fileVersion>
+        <cmdowsVersion>0.9</cmdowsVersion>
+      </update>
+    </updates>
+    <organization>
+      <contacts>
+        <contact uID="imcovangent">
+          <function>PhD Student</function>
+          <name>Imco van Gent</name>
+          <country>The Netherlands</country>
+          <company>TU Delft</company>
+          <telephone>0031 6 53 89 42 75</telephone>
+          <address>Kluyverweg 1, 2629 HS, Delft</address>
+          <department>Flight Performance and Propulsion</department>
+          <email>i.vangent@tudelft.nl</email>
+        </contact>
+        <contact uID="remilafage">
+          <name>Remi Lafage</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Remi.Lafage@onera.fr</email>
+        </contact>
+        <contact uID="sylvaindubreuil">
+          <name>Sylvain Dubreuil</name>
+          <country>France</country>
+          <company>ONERA - French Aerospace Lab</company>
+          <email>Sylvain.Dubreuil@onera.fr</email>
+        </contact>
+      </contacts>
+      <organigram>
+        <architects>
+          <architect>
+            <contactUID>imcovangent</contactUID>
+          </architect>
+        </architects>
+        <integrators>
+          <integrator>
+            <contactUID>imcovangent</contactUID>
+          </integrator>
+        </integrators>
+        <toolSpecialists>
+          <toolSpecialist>
+            <contactUID>remilafage</contactUID>
+          </toolSpecialist>
+          <toolSpecialist>
+            <contactUID>sylvaindubreuil</contactUID>
+          </toolSpecialist>
+        </toolSpecialists>
+      </organigram>
+    </organization>
+  </header>
+  <executableBlocks>
+    <designCompetences>
+      <designCompetence uID="StructuralAnalysis">
+        <label>StructuralAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/L</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WFO</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Nz</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/section</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </output>
+        </outputs>
+        <ID>StructuralAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>StructuralAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <operatingSystem>Windows</operatingSystem>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\structuralanalysis\StructuralAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <description>Details for the command line execution of the StructuralAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PropulsionAnalysis">
+        <label>PropulsionAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/T</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WBE</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/weight/WE</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+          </output>
+        </outputs>
+        <ID>PropulsionAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PropulsionAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <operatingSystem>Windows</operatingSystem>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\propulsionanalysis\PropulsionAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <description>Details for the command line execution of the PropulsionAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="AeroAnalysis">
+        <label>AeroAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/Cf</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/AR</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/CDmin</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/tc</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Lambda</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Sref</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/L</parameterUID>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/D</parameterUID>
+          </output>
+        </outputs>
+        <ID>AeroAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>AeroAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <operatingSystem>Windows</operatingSystem>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\aeroanalysis\AeroAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <description>Details for the command line execution of the AeroAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+      <designCompetence uID="PerformanceAnalysis">
+        <label>PerformanceAnalysis</label>
+        <instanceID>1</instanceID>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WT</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/h</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/M</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/weight/WF</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/fin</parameterUID>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/SFC</parameterUID>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+          </output>
+        </outputs>
+        <ID>PerformanceAnalysis</ID>
+        <modeID>main</modeID>
+        <version>1.0</version>
+        <metadata>
+          <generalInfo>
+            <status>Available</status>
+            <description>PerformanceAnalysis discipline of the SSBJ tool set.</description>
+            <creator>
+              <contactUID>sylvaindubreuil</contactUID>
+            </creator>
+            <operator>
+              <contactUID>imcovangent</contactUID>
+            </operator>
+            <sources>
+              <repositoryLink>https://bitbucket.org/imcovangent/ssbj-kadmos/src/master/</repositoryLink>
+              <references>
+                <reference>ONERA SSBJ-OpenMDAO GitHub repository: https://github.com/OneraHub/SSBJ-OpenMDAO</reference>
+                <reference>NASA report using SSBJ: https://ntrs.nasa.gov/archive/nasa/casi.ntrs.nasa.gov/19980234657.pdf</reference>
+              </references>
+              <downloadLink>https://bitbucket.org/imcovangent/ssbj-kadmos/downloads/</downloadLink>
+            </sources>
+            <licensing>
+              <licenseType>open-source</licenseType>
+              <licenseInfo>https://www.apache.org/licenses/LICENSE-2.0</licenseInfo>
+              <licenseSpecification>Apache License 2.0</licenseSpecification>
+            </licensing>
+            <owner>
+              <contactUID>remilafage</contactUID>
+            </owner>
+          </generalInfo>
+          <executionInfo>
+            <localComponentInfo>
+              <executionDetails>
+                <integrationPlatform>Optimus</integrationPlatform>
+                <operatingSystem>Windows</operatingSystem>
+                <command>cd %PROJECTDIR%\SSBJ\n"ssbjkadmos\tools\performanceanalysis\PerformanceAnalysis.py"  -i "cpacsInputUpdated.xml" -o "cpacsOutput.xml"\necho doing some analysis\ncopy %PROJECTDIR%\SSBJ\cpacsOutput.xml %METHODDIR%\cpacsOutput.xml</command>
+                <description>Details for the command line execution of the PerformanceAnalysis Python tool in Windows using an Optimus integration.</description>
+                <softwareRequirements>
+                  <softwareRequirement>Python 2.7.11 or higher installed</softwareRequirement>
+                  <softwareRequirement>kadmos Python package version 0.8 or higher installed</softwareRequirement>
+                </softwareRequirements>
+              </executionDetails>
+            </localComponentInfo>
+          </executionInfo>
+        </metadata>
+      </designCompetence>
+    </designCompetences>
+    <mathematicalFunctions>
+      <mathematicalFunction uID="F[R]">
+        <label>F[R]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/R/scaler</parameterUID>
+            <equationLabel>R_scaler</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/R</parameterUID>
+            <equationLabel>R</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/R/value</parameterUID>
+            <equations uID="F[R]_equation">
+              <equation language="Python">-R/R_scaler</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[Theta]">
+        <label>C[Theta]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Theta/scaler</parameterUID>
+            <equationLabel>Theta_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/geometry/Theta</parameterUID>
+            <equationLabel>Theta</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Theta/value</parameterUID>
+            <equations uID="C[Theta]_equation">
+              <equation language="Python">Theta/Theta_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[dpdx]">
+        <label>C[dpdx]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/dpdx</parameterUID>
+            <equationLabel>dpdx</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/dpdx/scaler</parameterUID>
+            <equationLabel>dpdx_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/dpdx/value</parameterUID>
+            <equations uID="C[dpdx]_equation">
+              <equation language="Python">dpdx/dpdx_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[prop]">
+        <label>C[prop]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/scaledData/DT/scaler</parameterUID>
+            <equationLabel>DT_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/DT</parameterUID>
+            <equationLabel>DT</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/ESF/scaler</parameterUID>
+            <equationLabel>ESF_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/Temp/scaler</parameterUID>
+            <equationLabel>Temp_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/ESF</parameterUID>
+            <equationLabel>ESF</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/reference/Temp</parameterUID>
+            <equationLabel>Temp</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/Temp/value</parameterUID>
+            <equations uID="C[prop]_equation">
+              <equation language="Python">Temp/Temp_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/ESF/value</parameterUID>
+            <equations uID="C[prop]_equation_1">
+              <equation language="Python">ESF/ESF_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/DT/value</parameterUID>
+            <equations uID="C[prop]_equation_2">
+              <equation language="Python">DT/DT_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+      <mathematicalFunction uID="C[sigmas]">
+        <label>C[sigmas]</label>
+        <functionType>regular</functionType>
+        <inputs>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma5</parameterUID>
+            <equationLabel>sigma5</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma4</parameterUID>
+            <equationLabel>sigma4</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma1</parameterUID>
+            <equationLabel>sigma1</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma3</parameterUID>
+            <equationLabel>sigma3</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/aircraft/other/sigma2</parameterUID>
+            <equationLabel>sigma2</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma3/scaler</parameterUID>
+            <equationLabel>sigma3_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma2/scaler</parameterUID>
+            <equationLabel>sigma2_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma1/scaler</parameterUID>
+            <equationLabel>sigma1_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma4/scaler</parameterUID>
+            <equationLabel>sigma4_scr</equationLabel>
+          </input>
+          <input>
+            <parameterUID>/dataSchema/scaledData/sigma5/scaler</parameterUID>
+            <equationLabel>sigma5_scr</equationLabel>
+          </input>
+        </inputs>
+        <outputs>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma1/value</parameterUID>
+            <equations uID="C[sigmas]_equation">
+              <equation language="Python">sigma1/sigma1_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma4/value</parameterUID>
+            <equations uID="C[sigmas]_equation_1">
+              <equation language="Python">sigma4/sigma4_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma5/value</parameterUID>
+            <equations uID="C[sigmas]_equation_2">
+              <equation language="Python">sigma5/sigma5_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma2/value</parameterUID>
+            <equations uID="C[sigmas]_equation_3">
+              <equation language="Python">sigma2/sigma2_scr</equation>
+            </equations>
+          </output>
+          <output>
+            <parameterUID>/dataSchema/scaledData/sigma3/value</parameterUID>
+            <equations uID="C[sigmas]_equation_4">
+              <equation language="Python">sigma3/sigma3_scr</equation>
+            </equations>
+          </output>
+        </outputs>
+      </mathematicalFunction>
+    </mathematicalFunctions>
+  </executableBlocks>
+  <parameters>
+    <parameter uID="/dataSchema/aircraft/other/D">
+      <label>D</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/DT">
+      <label>DT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/L">
+      <label>L</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/R">
+      <label>R</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/SFC">
+      <label>SFC</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/fin">
+      <label>fin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma2">
+      <label>sigma2</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma5">
+      <label>sigma5</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma4">
+      <label>sigma4</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma1">
+      <label>sigma1</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/sigma3">
+      <label>sigma3</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WF">
+      <label>WF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WE">
+      <label>WE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/Temp">
+      <label>Temp</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/dpdx">
+      <label>dpdx</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/ESF">
+      <label>ESF</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WT">
+      <label>WT</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Theta">
+      <label>Theta</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WBE">
+      <label>WBE</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/T">
+      <label>T</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Nz">
+      <label>Nz</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/section">
+      <label>section</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/Cf">
+      <label>Cf</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WFO">
+      <label>WFO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/weight/WO">
+      <label>WO</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/other/CDmin">
+      <label>CDmin</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/lambda">
+      <label>lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/scaler">
+      <label>scaler</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/dpdx/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma3/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/R/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma2/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Theta/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/DT/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/ESF/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma1/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma4/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/Temp/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/scaledData/sigma5/value">
+      <label>value</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/tc">
+      <label>tc</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/M">
+      <label>M</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Lambda">
+      <label>Lambda</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/reference/h">
+      <label>h</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/AR">
+      <label>AR</label>
+      <instanceID>1</instanceID>
+    </parameter>
+    <parameter uID="/dataSchema/aircraft/geometry/Sref">
+      <label>Sref</label>
+      <instanceID>1</instanceID>
+    </parameter>
+  </parameters>
+  <workflow>
+    <dataGraph>
+      <name>RCG - Tool database</name>
+      <edges>
+        <edge>
+          <fromExecutableBlockUID>F[R]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/R/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WBE</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/D</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/DT</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/L</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/tc</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/M</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Lambda</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/R</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/T</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/SFC</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Nz</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/section</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/Cf</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/h</fromParameterUID>
+          <toExecutableBlockUID>PropulsionAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[Theta]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Theta/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/R/scaler</fromParameterUID>
+          <toExecutableBlockUID>F[R]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma4/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/fin</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/dpdx</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/L</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>AeroAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/D</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/ESF</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/fin</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WFO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/AR</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma2</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma5/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/DT/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WT</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma5</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma4</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/dpdx/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma1</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Temp/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/sigma3</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/Temp/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/ESF/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[prop]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/DT/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WF</fromParameterUID>
+          <toExecutableBlockUID>PerformanceAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma3/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WE</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[dpdx]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/dpdx/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/weight/WO</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma2/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PerformanceAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/R</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Theta</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/Theta/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[Theta]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/Sref</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/CDmin</fromParameterUID>
+          <toExecutableBlockUID>AeroAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/geometry/lambda</fromParameterUID>
+          <toExecutableBlockUID>StructuralAnalysis</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/ESF/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/SFC</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/DT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WE</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/ESF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>PropulsionAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/reference/Temp</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma1/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma4/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma5/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma2/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>C[sigmas]</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/scaledData/sigma3/value</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/reference/Temp</fromParameterUID>
+          <toExecutableBlockUID>C[prop]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/aircraft/other/dpdx</fromParameterUID>
+          <toExecutableBlockUID>C[dpdx]</toExecutableBlockUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WT</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma5</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma4</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma1</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma3</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/other/sigma2</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/weight/WF</toParameterUID>
+        </edge>
+        <edge>
+          <fromExecutableBlockUID>StructuralAnalysis</fromExecutableBlockUID>
+          <toParameterUID>/dataSchema/aircraft/geometry/Theta</toParameterUID>
+        </edge>
+        <edge>
+          <fromParameterUID>/dataSchema/scaledData/sigma1/scaler</fromParameterUID>
+          <toExecutableBlockUID>C[sigmas]</toExecutableBlockUID>
+        </edge>
+      </edges>
+    </dataGraph>
+  </workflow>
+</cmdows>
diff --git a/kadmos/vistoms/examples/SellarARCG_01.kdms b/kadmos/vistoms/examples/SellarARCG_01.kdms
deleted file mode 100644
index c0fbda72b723fc35aa2999d8a6e8d0a92d357fde..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5175
zcmbVQX?q;S5srjqOR{W(EgJ`O43J}N#k<}$5Fn1Qkc1G{g`@`Kcv+8TTib)@*qWY}
zwChX)CO8;EfFvXka^H8r<PJ&5ec$)>3-Sl@Jo!MXdUj@4GUkKzVKq}#U0wCo+uhZ3
zZ>N3Ss(69SRYR*LlHYR0imcvQUJIlX1z~+S@O^Ga&XN<=$H=S~I(FX&oiSWsvTb9t
zLo>IQ$LGq!(^K=aL&Ni<Be3o?yTq#8<2o`bJ2*HjR~$PkFIqPFgD$&VUQmu3Iexj^
zOR8R2&$@I7upx$Sll28*)$*N&6*+-#+kxv+1c5Jmr^5;ld1XY8>M235S%Qrw>$U?w
zLjMx_O0dZksM(B~EhbxUMN#N1z=bhf#4b?dBe0cqJ4=>d<$eU)Brid~$=3On$6-6$
zH164ffm&mX)H_gnvB|o)XE`qHWc^OAIr3nnD%@R+a=r_%M5{|ow!sd(n&sDF7wev9
z#t5n5Qq)~$vfc`>Sz+Xn)61t&b_K?~sC=Cj7$mt8Jy?}W$fbm<NN}~udLr)fnh1Oj
zuOiW_^(@Md5XRR`asI$8yq0n`G1uLuz#R98t!#tqDMT!U0m|-mrr6H<Ce(3D8k329
zFN$-f*vWRexy1CKq<s7+*Opcut@fE>m!KR9rqFR0O`)URZwejcHKx#!U2BSFK-Y0J
ze?6w0)DX++!SylRV6u&lA8~v~7RVCZ7{eP_Z?kR;>vBMBlNRf>LR&Zy)*Ef!XvQ!o
z4u}C6!%g@f%cXSI2QjD1=eX-yp-~Hi1($oqULy(u*C6^XSdzmK+gRb!4xJiN2X1CF
zEm9krZAP%D$4FyYAgc_^kZM8l$gq(B3*1nWSJ1$afxE<wNN{8Il#1=(l`1b2#a45C
zSRkXzHDoG`#4u{Ij-eQCVLS2^-JC6uP<fmPmq1nKEf|a8R<@ag(u6O&)&h57oOM`I
zvd&uya9a$AOm=bm=qe99jy%Y(6ksBTNiohkR|;~qk>y)%U2>VP7ho!eX)>yx+o%XL
zG2E_=ifcS&(>01P8^atKHHuPUctx0xftdoMxZ@?GXpJqvoiQBNV+&HCpSxOq#)@zx
zhBpZe;V4P#MM{3G0Hql278re5OA9Dn1w@u(wE)LrumsvKu$~l533dz>+y`dr5iTU)
ztfyYc@6Q#k+gpG|)-_?x^TSXTi){U*6^Y3S5bX2;4<C&c&-LXSuM$yIyD^_%US7^E
z@6REt^MxC3xIRzT`e$<Ds=))EGgv>6$KL~<KUlygAD@E3JU#_lwm*~QGFjoeOt`lt
zOk{ZqVNjhr+afqI+#?XP;{sE3O@XNu_STE};x)N_;EAg6#QEjYo<SN|dw#_%>{foo
zYcgRg!F_9Tp)&fcbEE)43^fWHDD0h$!k#_FoH1am6!51}#I>9&?x`0=m0j8>++AFw
zF^<}mATm%d*bC=Tt1wvB6<eV~QOSbAG)<{$x?KBmX_A;YJ)&9OOSHk@06tS$lXqvZ
zkvj4Ri<CVU|7>G4%N*$lS|#or*$-h1(j@jrP4*L5s>ylWY1$Wm#`#59iecFlxIwHC
zoOOb;e}&*2XcPzPg#o@&Gm#X#5z4JA2xTh1`vgj31n@uS0iZLuf(a6GDPAe%5rCJ;
zzd0x~LJ(6Z+xe9`YiU!UdDBBu!B*MYM`r;vLDpkatOf2>4JF3n)qrMuu?;6;c(dNF
zV*>Oo1Zana=;4oGH=h?+RuXj@gWmbxDzM=9N-Fq$xFU*hGKTwU#<$Uo+pPs@)(gA$
z?8#kAD<WAI7{#`u62j<2y%4vF&u^6{7?L}zBLdjuFcLQrwa{-P_$uK!=qzxPe}K|E
zB?V^nc9WR=V3WzDJWbCHJOL2vhw!<>){s1`#dxUDQSuIQ@Q4(+QM^+xi$}GCq9o;G
z^o*w+IeQ%2#U;yiD&>%xI_wnQg{_9`cutf^Vt6;UO`hXBp7L({--|E4h;P;ky^S60
ze}(>2tXH?I+C>T8W3nx+_cFF49y~F2@bbj?6uehFaj5$gypQYk*(fN=<jGbhPo<eC
zwyun=FuXs8r;{e&1LA~;B`w$wiY2ikiI5+{r-r1h{KLW#$0Z$M9}&mIf)vMM;lzaB
zM{$vhX>n3KC_<q`Nt6{K^f5el#UtWQaZ1dJdzDy<k=yWbB(S(u<NFB{$2=qg@uZ>y
z_mkviPRxtDQ2a28pHf7@Pm%a`e0@|L5l3-`ND;Q5Hqr7hTAoJL<BF>J88IX7*G2d&
zjhRG)J5c$UqDp;EOo<vc1sC~2g|F_2KCe3>lEW8b_+kRam#A~MuqmW_!Iy=>Hl;mr
zIjYw<Ji|7GysEIvgJ)S+(iWY;+}K8J)UtukQTy-JTpn@w3O0rvLyGYIswvQ=ct$)c
z&S0d^3Dk+(6aoIVL`9-AVxC=C<KbcudX{f<ys<1|CSNz%=0yive7yCPUB1NKL!GQU
zRDL;fJU({Qe-kRO9_;aKM`D9{s9&)@yj1Yea+^-RA#P@a73Fz#Bh3rDNGmcNY4~`6
z(Um~=px9Xkp;L9RU0c&)N{o445jDQqp3aeGI!BNRF?_3CRcfkA3dsZCMiuK`vO>qg
zCK;X=XIN*oAf99E0~OU&1mD34jwvJ=e3!f=21WEi3P%z3zLzQLG;)g+7B;qq9jKa%
z4J^EXmQ$LI-%kQLg9J+84vCTQgVaICB98B&`<#XheuyKNXg7u*WhNGyY{oqsed8pK
zPeJ||?Z)&X`$=YJ;}kUW3C-)DrgH2`n~GV@?4M-{Y!{LdGn(5!&lC;JO1rvKGyE5%
zNO^M-Rm7W<dQ<vkHfALqGogw9tM)NLb4;LcTM2_8Dkpc_UyDw5VRB)fnVp^)ot+;a
zorB+$;J0|wO9>+3cdUz+iG<(d#S^a=68=D#C16YVBikhF5_cpd8Db;hPn>O<njRS~
z4-d_k=VwPp;m<Mr#T3uS@K=*vqS3BUy`0ddrIZz}#CB%NH8m}<E6-A$Jsg)^5*2z%
z9h_~omM^8X<t?>QqLdP|#I|Q7X!_Rqme`J(!n@i_WV22LE-$f*vdFXWlrUoWo4$eK
zMV$L|)h*!-RWAV-Z``HU7J|{}iL_X;{_H+Vv*LA}?(i}E9ZQBMO61UO7Ka3Q$@H8C
z$LD@KsMQTDpi}knQ$n)xFziZzt6a}$NQ<^BgN~RIyDahJ8dZgnoIP-tgYh<lP93Cd
zL6jy(hO&ybO?LsxOY91~UrU^Y`*t0zd>Mrn-oo4Lwq}uMdsK<_k<+BfbP${E6uJgw
zb>zFG3d5j^8@S;iV_n0l;bk08R+N<3)vNP5N1WRi^{&?hrUloQw0Ooccd7z$+Lc(o
zyq~qOE4FENcob9jYWNj}D)$fkG;w%x!kFY?mCDsK-74MYaavNwOc*TT-cQQmz+Y+_
z_72Ys4bK_#_>lp*LoOx)OIuxmRxgEet4e)jK2vYbso3T;QTz~rYbb_)VpK%m<Q<nt
zmcBNi)v$WkO%3~+$TiLSvqh8Ct0~4xH8<4uwbb;1+f-LsD%*yCiKkni?$GhtPj~+o
I>(xT;|5g88F8}}l

diff --git a/kadmos/vistoms/examples/SellarBFPGIDF_02.kdms b/kadmos/vistoms/examples/SellarBFPGIDF_02.kdms
deleted file mode 100644
index 17b9dcd4a6857c77f0ac1a917a97e0389f654e1c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5506
zcmbUlS9BcJ70H&1tb#1b1sgm-fU%5rJ!=pkY+)hELPoNLtd~H-Fd6MW?Hib#**kAW
z(#n|xlHkPYo%BWsX{I=Z&=Qi6-h1!;<Uc?8AootwO16`8tdG^3d+)ow&D`Bsyvr<A
zT$w9-W>v($M#=Qe=0kx~GArEiO?%37XKh{?C6Z=n*nJN)hOkCuouku(Q#To7M~$J$
zBQw*3Lo*}8u=WJIz%1QqThccy$Kjq)vWmVjXBK_et3gxIFlGbG_ASRSnhDhm>sYhr
zy1o(V0P95~+rmp_ZkWEm>h=b)jx`xokC$L$2+b;M7z|+(+ma`hj}`^5n0d*4WL}ne
z6Iw!OWo;Y+)3;p5u+3R+LmO)_rDTnVG-waue3fmjzg^~Th5KGDzo<b+2%AM4Yh2Xi
zS%{Vj&>2D(5iJ!~5t)u@*CdzuS^>I4*g{0LvlD5sHH2*uktPGyI9h=1AzUEv>W<_p
zDm|*f&JZpXNPAI2dp5CU4R(c~2&BK5ZA_gY;gS$8RoS|!nlD@jp2s%UwEVuD*4L}S
zWvpr3oZ+{^<>E57Zo>4%#5i2RPVBGXQCY0mjy!OQ@cn9kKEJTAkXzW7bG>q2yY9Mc
z^F$r}OpISLu)ksr)b{7`cYnnh(D3Bo$sNe!$&Fz9GFUEyX?+>6cNrMN@}$B*fPq^P
zuFT2h0;nPE7U;7cfhO)z1)8Sy)(ZK;Rk^)zrMO&NDbCH7dJ9s;>g_9JYA@SYxGDoK
z8@P9sEuu4AnY)=ebI=<?PGExO$(p@nP1mB<(^J^9RM=C~_VC53ipK30m$S`_+8r7A
zj$;T7(a?XLQ_vPsLkgM<sw+b03?xS86O=o!2T3WG*1%G7DI-GoGWJY)kYZyo)&Ng9
zc<usnbO-*2m-Cf~DA6NJ3(>O5m024of)+v{>J<CPmsgQ58%%T@{#?OsJSRVyvBJyZ
zu^_Kzjl&xBg>Vgtxt7FiTcVKVls(F#hCfRMrB}%ndTIrfzH<q~whE)%UM#u3g7_=g
zGv}aK>_2N@kxGu@xa`U_qI+{`x?&2`5y?&uY8sfOlo7_3@)*nbbYjeaj8PJtq*$qY
zU59QdKz|6=lUw$aTe{6zsn)dJJw3Ur$t|&O&?lX@OYr<-H7%?IpIgz!t{`?%j@A-G
zQ2Q8EpQ4$SD}ZOQX=MY-=Eaf*2SR~n4yahxa07K`oC)GU2nVCHCIu$qAf6kFk{bAp
zNdpf=M<_6DhEyURR$0ruX<H@3Go3P*FcQKcm2I-Eisi>J7!Bbjm94K>j#UXNFn0Jq
z&pr1XKAVft^Wo8hUFSuA0c(y1al}f8n^o4n{A^f0ufX`|!HZ(z<1it{Z{Bbmj_@GX
zm^6b)I^zhWSWZPMqg80hEqEqN(AepSydZ;stu=7?!_g3C;^EAMCiY2cWX~79A}^^y
zzd)#>N77)rRqPTMOR*~yYDkQ3Q$@Sz68+)^(I=(@(Hml2!wa!^MQbGVMJgf(5qV2M
zF1(%Sw;||8u~S?Wkcv8iwutRw2U1N1<kCCn(m{M24k$o|=oZ&YGVR4gyBQIa0R_Mm
zTg5dvdz<1#WHy8%1_LLY=~zqA3Q;V&w#|#QO~~d+uf%Z^8IE?Ck`7$eVNPWmiY_iq
zMPEW$2ecG17GmzinM(_eH4ArzV6!#B*f3Ps25X+e?D*hFu7j(xwGOUbP-U%Sm7=R4
zRv9HUAl6e^6RtRx4U%<Px#Z?SKPYi~&d)hE_(&CCY82f{)pTkw&o<03Wth;gfVf4K
zHJ5nR^n6<FpmqddOQ`c);6zrzF@n4VIhduA$EAdj054V9MxWcfiYo($ml5dhNJ`+~
zt_1fS;r!ldcsben3bgf=sz4j>6&1GLt_0{Y4~~;{uTn*owTuUMnNpdE;jc#U2~|k8
z!_LK|2PN6#__;c>UV~JxRmHp@8(yc1NblFHBGUE^s)&?)qbefJ-lU2|p*M3Re+!x%
z#}LC>fwzY6HY_L0@i{)@PAYYHdkF7f%}LxC#^pZYNRu_2UQu9?U@UcbC$1Oo68DMY
zGK6>Ie+*X;S^XZisl;W`v#OL9?3TL4S*gaGvl1ngGUs}VbnSWEP8DBp<tVpp)60kg
znIfc*n(=b2Ul|)dltZ7bChb)wh9|R&NCfX?ory35#h@pnd=24!D%)Y&w!2_pgk5Kz
zdu3iSif&M~X-Pi8+S1S)F6FZh@2A4Wg6YGO+Ai8TJ3qbW6uIHos{9D+sFY0C$lMcn
zoUK7E*tUo<3P_nsT<TF4`tJjn7atUTrVbwx{U&D}DM>6Bl?ma)aZXij-0$z#;UiSH
zeVn!6!rz;!3=in=QPj|6tyNe0%kT$v_?VjL9AGDEG90(W;o~8EB5p;Wq}n9E(tF6K
z#4)x>2D2I9Bo%H2Mf)5cVomY8!ow(twPu=<@$d*+@9{D^*n>w&wdmc*@LZe2De(XX
zt6?ype)nlrpb&9VJR}~*HuH#hRGbnIimGT2s0n_i9=*K|y*;4L_}O~&&N}qY0NW*e
z4$*AGyy;mczM8>ftli^t*o`PeI6VRmpC668`g!MxlWd(E_|?FN$Hl{}v8;(xQMOZ>
zVI9B|tP?|=JQ;44M|A;Dvc`b}@DyvWLq;BWnl)S41_GQ?eht2WChZEafx{O`=f_07
zWD!d&py^MDC&g3ZX+iXAK;8bCnEoW|#&rYpk(U%HOl+x&<&d^tLds6kc&Q+83VvDO
z-1~|u#+EHRd~<Uk(VBLwK&$Lvw@e)JENgXKoR6lRxZ|tYC7LSmwOI5iw$YuvlN$Ow
z$4EVn0(((l!(2df=j*9{ZJB<tV&6cz7NRo)nuOm>>Dm+Zvt0ca5^6+PjK<ZsV?wm$
zJ7mju$(Cnsi{m74Y9~iD>7<~mTgmvE7R|NqWp}?%cYpBz?si9a3()}lVWOZQj~*bz
zl13i=5pnu4aytBPTp&c^P4TR#_ZCjfpV0j@mHU%qydQb>M;pRV>)Ce@`^AX;&xrlc
z&lIp#B5?NpqFzK_orpdx<qoRkmERG5iC+TFkH0@mO;1jZOwWvs9ED%$@M|1ZX~9bP
z4Qryi5`K%56Tc})_#NArhDXBhS*xr`T!Zja1!kOtKXBH1WO8`K7#f^0W~N6*;Ey5v
zNfnQU@Mo1>K;z#kVS*MduShLGNqOni`x4};EYR7-r=d>2j@>8j$vRt|M#wv5dHTIA
zRqVcJ(q~oD>SQ-6C~-*XXQ?<nZ4^3NE3l#ItRvGrQ!fz5LikHGLUEJe4$W#EM{Lw#
zY+M=i<xYx1BgaPIfOXYR3<dWIT0%njD~1eLS>K{@j8|Noq!nukhY{;4y49Mps=9Ty
zrQ~uYmZ(URy0$`lt<Elt`PfQ1Kuu1+xQlujQeva5VeHbTmo*Ob%*60u7S%fV8iea?
zhlTbgMyCp-*`~A2ndZteu!R`LFZLGtrkhlcoU&5$9WwAdw~X^isbI$1idn_kf(t!D
zbav@VyUwCx_Z)S+RIjudVnU_CQx>>Y7U-uPG3Ec}v)b(eYn>h%LFZJexCT<>{)W5N
ztrO$Q1g#Ymy2<6xwT)3pDN~+1k0nFMp=AHSbMw&D;LuTJ#&vCcAQt1U8By&*sxw8X
z&Y?s;RZC<BtSvPZ*DS1|5dMx@QToQuI%~_!j|eFH<1w=u-jbwLLe{mi?WgQ8QfHV}
d2{u|hWKb-^Kg7)Pmr!K9`b+3P#kycN_g@1Iv{3*6

diff --git a/kadmos/vistoms/examples/SellarCMDAOIDF_03.kdms b/kadmos/vistoms/examples/SellarCMDAOIDF_03.kdms
deleted file mode 100644
index 2b55be9a048edf0d03ea2d4b2f33c3934932ea4e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 10747
zcmcIqdwg8Qbw;vfTe2lt_yx9s1@gGIBgwmf1H=|Kk}Zs_2eO8M<Mnd2d$qIc-Mu?A
z_exrs3z&z&CJ$&58X6iJ8k#0eXhM^wp`n31nn%;T)6leO5}GEYlr(Kp`bb;yow<))
z?aIdZ2l`_*_sqHHHRqf;bMD;IoIYe`ini*>O0&%U-&DqQ%(kJ7X%Ap9NE2<MX~PlG
z?1=>iTQNAcWAv)j?tQ8Lk>T;N9sT1w2gJf-Y^|Be7jnu;<w_+>rZTy-lbSTsjx8&q
zC7nu5xVeIpE2UCxG}R^+u@=o#EcV0_gDotXMN71@^Y>YWf+=HVX-^caVyrthG%ylV
zjx-%BTZ!!+*d^N7ieNT1Y0IKpFrA!T^2AbutuqS+dphNo(spUel36R0O51L^kSk@?
zG1f7O3Bpa;GGoc4SZ1)M9jtjEA=>d97agp5FfKarn-I%c^RBq)ve@#FRw-?zoJ!dm
zW?e;CCuPbs&pB4waizr;Kr(igW(KAqBbCZZ@K;H3rjZmYc!!x3D|x$Vv91usmjwcf
zRi0RFu=cX8obFI+u_h_bGI%Fn&b!#cRBA9S&bHXHvb3rwYm;If^f1}tfW26s6z3Sc
zop)HS%T^Y%kvtJIPn>J;HT*2To}a^(61j|}rc4P*&(pM)X)!{e%a++PYnF1e+Sci`
zT_`|tm{PTkkS(pufL_&DQk)M>FEH2=n9afZD{)~`yvpF1c{OHUW3WZ0<H+2Ec&#T4
zw!qyzAU3cixhb=hwMvfIsH~*eWbjtjzPp&VV}Qp7Y2tN&cN?t5Dw?^1=wT~!J;6KM
z9XDeYCY_#ALG%J^vq7dPmd#Q{#MzQ@78{^xk-*$V25ZY$Wm7suB6{&KV3$DJa5=;l
zg1jCS%uGgFN{LGeaGAkc9jjoKxm~iv<pg?z=HiwdIQZ6K%erGsY$GlEpyd??hj!cf
z2DZ2W2Q64q>>$0aB)yjHbq|>;Hsr(m0Uj`T4_jC0@lm%c(x>F~)Tp%+Si1}!=cL1+
z!L{618C*-d+u&Nrs|~It+hg!RpuHB*hoG{*dI-3p81}@7!ItJq2q;9AO=~{tiECI}
zuwo1=GR8M5leI-I4xD|4C&u|0-=RFg@E;51YOSy3tN6KWDSRa@b7gW0wrihVaA{PH
zT*r<nyD(+N9B#$xg4|W`e?1Wf`sEbqJuX{qWwKU^9A<7tc_T;uNWpJ2;yO=UZ?OHn
zl(zPzIozW+5*v{@Y(ubKsHTvdtWvttk0H_t^uN}WITKk%)x6tpmn*$y$t+Y9;MsJl
z5*PbD@g{z@Cl0VyOSn1$lt_BwAX_wAao`am#THc(-IYXIDfJ49k`Om|!X!~9IQXYI
z@r`#^;+pTZHEPUbf?O%*<jlgL3#aZ6lH!Y70P1HvVX>wCHj-wpL=Gb+J&{#x{M7jk
zSSpt-ose7BvWphtsCOnVxF>QP4DyP-G72TcAx{*DMNzTglj{(sVe*O-N*{R(Y=v#e
zX00QLf?{qKQD63ic)7VGg!F{sAnoX1*I;Yrs1bQ@Tugal`b4t{G2@8}hj-7u5^Fgd
z7l%D@BZtd+96of@E5alpZuZ12Z1ubbm=s4maVy7q-^Srrx4V3~C+;|bJt_%t)Dw5I
zjxfek1#`kGh`U&GC7~4W^u)0fy&4zCJ#jZD)HqOK^*0m#TPRB3Y9LHoEAifodg5EU
z<Kk_sWv@AIT_^70Z)1ywOotEc75B1ZTZ<URW{QQ9+I9hVobu(pz0=dvJ<}KUAba=5
zFT3p0Uc%NtLwhgi+gi-^RkrrxcWbfK7ssfCk=@sek*#4DMX;U-7T*#9yQ@GS)=MJv
zxzGTf@mpl9x043%&>A4mBzhAU_iPsL<oED*^3xN!R?v`tts03)x~dw9iz8rFkIi)=
z&s~}*qreOA^Tcmcw7g552qz)#_r&iI&b!rIS5lUPqBW~}P4R#yewVVwdlVa*<83u%
zpugEnB25-vLdtv46Te5y-}~}XhUyP_;`fR2`(9?s3GuKe{(vaIU!h#|#2<2)=K~0U
zCKEg0-czv8i0hQyQ`mwh#Rom{N4(1uA0l7;F!|!jnfS(yiA}SKO_lg2Yo=_#H8=2k
z*qJl&gAw@PVL&~&>9eO5Su^l2iY(=p=fqd3FL2S`V9M^>1XK#RT;FW)QiKF}b#}gB
z4QG8exjrkPAnj>TwEIpHBfUk96vz?9E*m)o>%W8oAR!*{#2@o^Pke+H;G?tvtIP>y
zRN@;pZtS@vwkb9nr=J8?V8sC?q;t3u_iDhWmnnP;5IJqy3MDu!2-NjKwU(U?Cg+%Y
zmKI9C5!fk6ZZEfi;^I+H{0Z;y#K*`$A14EyHA^1a10&4%w!uNRC$X_YHd;RmFRh!2
z9Y|+vCx-cZ*%PPXufDNzeKS=<gq{;R@aCQ{w<6z0rtxR1wha9+vM5}ck}kHEc^y6?
zG}p!)yYin>w)}+R*n|I!;`ft0$v=$ja4OmJRI@`iE*|s5pVMahDUg5b%S}EZ9{0pw
z&`$VikbehuMkw+`UBMM?HYi`8^u%YV4w#86j!osWG@eZ;j?&_Dx<0@dwZiB1IIdhO
z=Ks>5=`REzj_U4<7%!l*o}-}rl77J1f?oWx#!BEt6jy&m7XFH&-@i6E^5j=JV)bhr
z{`hqcyL^LVYxyRJ3g6<`3ck&ewZG#Mv%jHu{w`GdC@eOoc#3wsw0O!Bf2*_m_sFmR
zj{LgGgahN}UUubacxkTB3_~(3G@#PoQ|NpjvV0uog;@V!aBSH>AVp_kMOfg6T4{_S
z(T^~0f-PX&r!@-M0#^S=+Kqm!h}J(D1o#Qf(lWrFKh*?adJulbV9Tb=LN1e%)N)Yb
zXP)?H9Eb}j*&QDyp7q4P;CNrenW^X&#dBBx`h^!>z_U4{pMO5MedQVY&t+}8>7_{}
z#lIS?v-+Gucc>_SF}VF)ANi>GH~xz~OOA?vw_GiH+$D{EiE*IOuQV7MxoGyFp(g&r
z6VDq|qW>o^^I1j3^nYRGDXOUd8>5>PRkr_w(d~)~-CtvLn>O12QU~aV{A~UumrU?~
z28Lhc9sH**S?d1{{t$m3f0F;0-^bs@@8|F45Ayf&hxz+?i3={dql@Ji3_io(&L8KW
zb`fLpjHWZrF!*EqQ+$fQ#YLSfn*agJX(}0Iv;R;bJIe(cx1Ik0JfCr~UUH#^bn(wZ
zu%`k2m5ZuDwg3t*;~!A)R=J2sO!99kIILXkKYUxkape;K;XAtEkgfFe6#t%r+sih8
z>Z=OwFPHicUsDJJxy*m~x<W#d?etLQw@^xw9sa|u3V|X!eY9^V#EM+*KYWW~U3TFC
zp~XMMkMK`Yw8}FzWIsQ^Z{QOYhH?eHQ06yMAj*|`I>WR4X8s9&n16*I;zj-de-Gz8
zPq8OgX^bxZIV{K*(Ac|^yg;tj(02YK80MEQLS3#2@IDW`FQWx`w~OeIXKCnB{$2hE
z{|I@$JUhVq4Bq^SivW;oHRMtLF@BtXAHLL8LK9?814XU_iteG%lw6M|PoAS++waM9
zX@CwM^<2@vmFMA^Etv}1B{D{jozj{_-;bK2h$h#P=L0(EJ32_W^8KtuAE4v~gx;cC
zDd_W|`C{TFc_E;Cny8hj8@(xMqf7QGLZv=b(4mp9Ccug+AZ3>=-L#Ugp_%4w+vIC$
zuv%JZ1Ecfm*eRu(Kq;-5fk}Rxb=7u+d{!IiwexEFLa{0rG#&lUklaXEoz)rL0G68w
zx`fV&g`887ucODM%AJS|)~yl3?t$#Vql?&;y%-pIGH0HQn6J0l4f(3E5_#W5c`{0#
z43Q_D^Q3QH>vc3wO5{n#Jc*PiLGr{q?{my}ax<Q4IAUEgK99wf_`$>J&0fgGx0I&H
z&I@`)u`D%<U>LuJUNuX+juH1{qJa_j87)Flez=a$lRlqw=JG+K4qc)umy7DS9P;GF
z4O|X|>LeP~2@F&(ZON0DG|(vp(rUBJYn9cJ9nxqARmI#Aipe?^H_?)e3?^TXDayX`
z(guDq<VSMP<rjz@(arm0%AUL|BEz@ng{C%pv0ShmOJ0sSwj|uXJ^2R0WoHI^7VSj{
z9O~E)J+pwdngv95&f!J2cECJjJ7(+}*HpRgVQbn!+ZOFOZf97#SuPhUh$uLEDSH=N
zA5sh3<tdATze;yyZKzO0Q>+hOv3AST&#v$9W~(r*zsu-vDGl?kZ<7ThqvNavwnVIN
zC9Rq+Wy^i%K&}aTww~NZ3erx~r!`%QFF*M3G-11?jJyJ%VYbvQgG2z@u0ic38@sw$
z2$I$g0HdU(v+0#YEU(|s>sRu1IM~SgUknFXexM#l=k%QoP?w!)Pvq%i$`oZ%U%RB-
z1w?+tWVHqjXO$-hi4N_*S2Yl%jd*th)b%5-)ec*e@@nGH%FDFR%RTx9N=$)c<;k7&
za`5G>Jz8%1{w4QfiY=B_7N6dv93n)@QGAWhWA&UbSTVmnnp1L^a9a6tT}h1K!Ou&L
z3_J70Azx289}wu&g~w<_V4hT3O@h8hHD}{>X_PhhZIjm!8=cJCa`>zhr1LRAA?K7!
zmfZK!*d*%M<RcdOfb5J*E<0XFRwr!=b1=Ryka;%Ff96R>z-K*qExo~?yZU)lqWtH3
z+FYesvCjIe`9>hl<FnV%`!!onEyw#qjtSy;eZX<Q&oK&*8m{^In4p$>(|k;5FM?VR
z_)MBim+HI&b1^ahpg*s-i;Z&=Vz6DT(v7uPy~0V5sxG)oh2y~n>JJ6farQo3NButS
zw)uK8C^=INWF8L5AZyo=xqn_VbbgXIM06UQ9rN|xzSa+;RrFQX&)T+(q6ps)n|8QV
z^qLV-9RRT42YumMCL3fs5|H!_XzSKnbpx9KrCI}`h)y>Ue<aYn(x|z=U$Hel^=Ow2
z)0NEB(MMfwHPC-Fq~Ewe$9>DzlR-s4*+AyzngyyWI)VkNuPSgB$j&9>2Ucs8maDdb
zk&pNcnkHR3IPke|V*ar}fNY~4Q@$Sc=EjjD*Ffg+kW8bwXXYn^!%99P)8J>ktKQB0
zY#k=mE`7E+R6_u|oXxsuKMy{f>WW$=Wr2`z_}OpyGByvUHEp)E2HBU9GPZ9$+D`Og
zsTi>c-S%*xDurg<k_DkzzhpROl_D~H3nZPyVZ)lT3d26Fh5aKVWBH(V(4vrV(Fe?0
zk+4<U5iNf!sZEVX10B(sLuxDolajHZH~4ddPh9UGcsM!&!7#|n^JYjK^W;f*J>~Oi
zO6yWVodolED3#tKoIon~^rXU}aw_80=s4~5j<eo3DDK7JSb%Cb+Tf>2j#l2T>!_KC
zWTR1^48)(&;#cT37<HE3fKj6}WObLD*P1x!9*&qa%H1))-1$Jt4xEeIq-{I6qJt|=
z@<x)PnJxFPH;s;sjP4v8-@S96^e~Z>HxVb+8WuuI-V6Y1p+lyUx9BllRZ#K>ja$Pc
zsN}8m+^#CPd{D&QD17r!@;1OM);>Hkurt-aV>~rJwsWVv9Y9asfnP&g%#%lH%+}In
zn_PyD6*-xvk}Eo2B<aRcFj;r>NV4-ArW#+z>A^qRfl^4I5v%@KlVlxe6XRADWYQWX
zNnyyLaJ)#eMgIPhWUC^qfOdeqx{P}n^J%k?<4BOCq!Vf!is$kzp1f1r12<Q2fycs6
z$w}g7i{8v|i9;o;ham{0d1)}NK-C`qW4OjccYi#2m!=0yx)_0b4aq#!#7U~TalWf7
zGm>m|#<pU?-l<GFb;YRHmt-eD#wOXi8i_*!p(DXcLjyaa6^%CKBwGM@@<lroNgN--
zl0H@?x{Qd1fe9WYy0%Dcj^yi<E2W)9=Ok8yCl_Kk?@1d?PC%0E!nw!u6UZ4<WpzbG
zlDZ~A+hE$tWjXA$&My#7PN&}NE^8m_-w6X1%eZ<)%XUmJTibO*dt*a%$4@4C87{e-
zVk<T(?I{F{ga`BoXHAUT`bT&4?~9Gwb^#Cc=3d*>SmyyN+~B|@Y&_MPlF&yh0V|hv
zgmq0!-|h3{abF(tT^|HtBHc9(g~Hs<K!~_3Fk67OGKv^~u>vrbDG0aPKniFekF}(f
bn@-ESAqaoIdJ_}0>uzGoHxtStccSMvFz;dV

diff --git a/kadmos/vistoms/examples/SellarCMDAOIDF_03_mpg.kdms b/kadmos/vistoms/examples/SellarCMDAOIDF_03_mpg.kdms
deleted file mode 100644
index 87ae064bf7ce08067ee342acad7b70927aa74012..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4412
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

diff --git a/kadmos/vistoms/examples/SellarDFPGMDFGS_04.kdms b/kadmos/vistoms/examples/SellarDFPGMDFGS_04.kdms
deleted file mode 100644
index 21bb8a1ccc0db3ee8a37b992d91911e3e6819763..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5452
zcmbVQS703F5k|stIjbN`azO?!5MV8%JMS3;2wPZ4vXGH1A?Z&@!m?T2{knf)Z}(>Z
zT}gM&CXfUtPVb~QLP#^kDTJ1gg!JBfPoDCgmpqV}EvJ)g=fQe7?as{q&o_PU?rkpI
zV;0M<%$7W}BH~Y@X!>U6NZ=IBGIxB_p7GoTo0rE)Bm+%*?}O$LE>v09`0Vh^t;WQh
zF*1E@es*|deryyroMac9#k*}w`iA8=+%t++!8aDog711&Xek)RLSWgx<rqeWSQ*&J
zGM?-DMuY)2iDtH)7fakQeSh8Q&0-^KF)AJ}!j=#+Dr*`JVJq97Bgk_F!OLb&avv`*
z$(#wTA+)h}4uR=gu4CBd0=J=^HJMVf<|7((gm96{b~K(YaktEUubNxYpfiMRqMbFb
zX!0CFwLEl%&`m<M{5m1iG3~14GFQz*PYBydsCsT84R(aEGZNBdz?#SNuq%X%1s?59
zjw0xB4R(ici9p#)6WMdAEorbP1Vy0yWo%381PPaiaD~b?&QyKjI`AU4rK;r)WVL~Q
z4X$J@ljc0X1FjNRvW-)wFQz8pYIgEq86TCEvhB!2mkZyo4CZpn%gfp216kKA<+K}b
zydg)@(Z|%}<wFO{)=>3e4nGf;ogodM9DH(za`@y%v;%cowocOq>csw4Vob{sgrNWf
zw<cV5CztY|hOk$l&-w(KxK9;mn$};<=knKP_ro>fDshcCKU*3tNP#ulm#@QKwJ(2d
zow#b?{&lv9u5fMc*3DUj{t&VP6EsKG>?dowSG2yq{JvU#Usc=3S1KwRw^v-nwykJ)
z)ya1qM{0<M{`<Uwwt@&LXfmj*37s>P7@130?$ACIrC3@+wd7D;2<fZbv*kg`jn!B~
zJh{Phm+?k-=>K>*SB``d9QCvit?OJ_ZvzF;LdZv*;sE*bTJmL+iH^gMtJy8*<tH-+
zys91x@;cT$s=+`A*OQtXNX^a~g)FP=Q&u$msO6P@C7bW7=283Z8is8hN4c|5bbST+
zSF`8N16b@oYiNZ^j^eoL$~2<;vuV0w3ezKsof*_LFtzj|j4kCcmhqXwm;v>RlHer8
zO5N*5bW0uvL%50Da**88V=hRws_pIT%U(xriG71U>AF*b=O3?XVFUU6iZ*ryT^HqO
zH8BLy$E3y-ty{T<cn+J^HlX^vsA+I06lms<ie(KqQ+LLhAP$9aIC|Ekz(gFz=ca<B
z27XJ@zyr}43QU_3m4ruC*1BZcR?+ZGr^F?Ug>Xb=TWzas`7sT~L%3CCo644Bm4h-&
z9R2SLFT8;7=1TN_bo_Al1<_x?GSMK8uF~N)m36GX8<x+@Fgbqs(pdNeOo_?cHlKiF
zJctn!GMJ`k9Dx+enFumkg_hio&twT2I~$4TWe~6p1`dCi3t>JU&P-_HfTTwDV$m;h
zk{a|&gev+Z4W>K99&wozdqSaxbkR#y(IL9UptxBKh}l5&hgjF}GAv%v7AbwXip*hT
z-X4$(?<D!1NV-Mr7MBJDQ76)Nu}k!#)J#Awy^9VV#@Eq+0%V9Dag!v|UO}?kkTD%l
z08Ft%T#vK2C0;}pLMUJ`aKf36Rf|@LLcz6dUZ8D4W~RL&$4z83+F^=1a8-vzm2ED#
zxHJ`f2_+rSQsh|3xf^FLEi~2w+!KP$E(|6{q0Ba0OB80u2S;)pT$OEbaP5K$Ynvz+
zTm`wxII#h_p2}Kq#j$LVtlP>aClC8Uk=u)Y*0I4ysQ^=>;Fc?<Q-vkAd7dew#D-<$
zt*9(h<Q3ENX|;puF{ITH^J3scR>5(iyb^CPi$#x12_X?)rLrwPw|NCu1`e+#(!G(E
zz`<P!?mNc${j=~Ivh}rS>+4j3Hr_AFY?ECM&|@B)AnRVQiVAC;4DK<dG8NO`faH^^
zkgV6v#-fKM+2i=x2D9FXQg2elk{}!2tcnQtTT~IDeXA-WkZ)5(gzW9ANC3Tqqxd_~
z<T!>H)-t>+gm+^(S&q-~9d}Zx!+Sz_FUurxV;GkQgd<IsF};GoBEeYd@IG8G-Y*^y
zCu9g8!2cMoAhP;{Y-^Frf@f7IE!cd+;;dBS%~^>ON?CM0MY{G9Zl{VbxH89W+w|%}
zflL|FM`XNI9aN@9kMxhvWzlWxrTdXLT|bL*@FCWf=rd3gIx|Yy5I(H3UemVSWdnok
zI!oLu@uE?1gNjXi@=4a7M&EELrFHlS)h^b|09Ms5(ZSh8={cvs4Zm99taaSPWvqXW
zTbO&Svs^S?qwcQ2<Lp9&#CAqnP+O`&;*yVw(Vrj1Jo%UyFm?F27&JNSOhsZ4h%AIp
z#5q>6ao>MXhfh)+51?-R0??o0hlh0d6v8!GTg8?BD*a&{KCLDO1lXBc496{U_)G|&
zja$>_s8-3(^u6Ts;yBwXgM~Wb6cutARr?$sVJ-1@heuHnYpWwAPrzerlgCTwZ4VwN
zXwi2i!*gv8r^Q1Uxu)TO`rj8+fl9<F@rZa7+s<R+adBEaEGnWSpr-i6M)s}-_O5_B
z<(C@SyBpZM18kr0Wn{C>OQvU;_*D&_U>zP`#O_4#!f6t4_{w<P<uABEoMIc@z^?>8
zJSiS!%_U8oj<TQ94(kG*VqF;T<jrs^JgO6Tnl%p{f@fGq12gi#vn*p_TL^G!`BnHT
znzSdth7MmN%uk3$%_7#AN7J7YPm5>7vx4N+fV%&4vHU64gX;$-Cod{enAl<!%OSL1
zN69WiT+0ibir)}82fwL`iB-#v-j)d@TGN3QX_Xx8o{2-AXKjv)^U|~vcYLdUh^7pD
zJ63&~ZE+XwrUt*nF;Y*W!hTfPv>4DF`c8_ky^b#i_Fa@~B{?&o$@slgt|Nh8&(-gv
zphkj)Xng%35fnt<L6%juXo&r=k<k+|^3f>!QOY1+93n<dBVYWOeDM?X#nJ!ZDj*U+
zi04J4ojCh`O6Sug98A*aLA+})n)N?xyuOpJUx}{&IbHvYv$=Ym3Y?<9Y*aDOpke@v
zu#;+V?Jokq!teAK#lIxX%udgY&CXAZ&B3pA_ze!7wA3X0mbK7X3BSV`h`$a<_&wW_
zI#$9TSevX$Txjq|2h0@-f8?y~*!1X_F)}=F%+HRE!Jk6-vnrkl;V&w?m<BnvuA)+~
zyaE-klHR3L*Gib{;-|CA&S0H+9Q#JxT6MNQ0r2kh$}`VxuVCLi8=iIPrjy+WP~y1J
z&rvISTH-p}Ag~qbth0{14lfYLL-=bn3~?vm4ozJhhh@|oY#jdjY7a!Ekz*rrz`7fI
zy@HzotrH>q4MT=Ysc+F>#Un1x#IjYxnZmjYZl$WMt4p12FS=ZbH7e4ieyh-is<TVt
zdu*i?Ad)i=?x8M(lGx&^7`wDx)k_{dGc`I~k7@%QC)2RbdM&g!F**g1W}D8o)sZW!
z#8$d6{)%p)Z+ZxN<dn6@du8BxZV4xgQpSw66|;g<0atUR=<JHMcAW!b&m#4z6j$2D
zFrm`mDa+g{3G`EMEcyTMS?~6Mwat!<p>xU=T<9orf5$E9j;Tpyinap^-Slec+9#-_
zlo`)m!jd88NU}!Yb7o{_cw|nQcU>D_=!!|#jHLFU)Y&4`;7}5usU|uD)}9)Q3lr8*
z2>(D-l)mx1&f4qdM*@`n@qk!QZ%tAv5$j&tu+!@>QfHYn2{&39WKbx;KgIm&Z<=`V
O`rkDFB{l{N+5Z8tt)@%>

diff --git a/kadmos/vistoms/examples/SellarEMDAOMDFGS_05.kdms b/kadmos/vistoms/examples/SellarEMDAOMDFGS_05.kdms
deleted file mode 100644
index dc4db0f33e23c0bc9d771bfffb4a91b4eb9591e1..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 9438
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
ZDG0*9v-HPCpk4RJM)DM)tnz01ehi+;+ByIL

diff --git a/kadmos/vistoms/examples/SellarEMDAOMDFGS_05_mpg.kdms b/kadmos/vistoms/examples/SellarEMDAOMDFGS_05_mpg.kdms
deleted file mode 100644
index 071f2fc4ab8647905027b7db35f0474c5fe79d6b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4251
zcma)A+j|{V6({$5)3i;}CZ(MKm8qE2Rz*aGh9pfxnhQyGt>Q55%<P;!?VOpjX3wNO
z)e%rpN-5wCR8SG`cf8<TAN@mo^85UJ_SN5>%gK%UnTO=;z1Cjqx9;oYsb=R2cdMbA
zs6@Ob^WSzY3LT+T_kzpA<^1!kCU;ZQ$)~9~r52MNoL!k*K5x&h+EYu5Yb%peYctc-
zdV`H{_p<M)*!F@zM7HZWvAw~aIE?Dl=GgXn;`y-`*mk!jbyGX*j>0guGyT*do7s?X
zE5hb+yz6zRY-er2CS2-DsoP{tlPUGEo~ba5Trc2ILA@#UvEBl|tzuE5ee+F9vF3B9
zsXwLttZOO^Hbqns5e=ktK<=CG0J&?a7JF6iI&Kf9bSRfS2x7C6cs7Jjoe(m6hK5r*
zT%JzTk(5TVQzAhal@NIpXNZ&_-Ko#ViZebQHzlMSxM+c}>C-fp(p@;Ut3(3%-I{t2
z&RrVt^cgyl(mS+>dvVtakzh9^E>Ggzrc}aOZFrmBnbLhZ;&;h|axg<Yj!#2M3!E@z
zue?VNNF&2|3WUQMx_9H#h|=;;o3dXXkSFB5a#$XfN93^#&lz}F_9?CLJ#tK*%mBO>
zlJ0`)wme|(OX+@-4U`_2o``tl$ht-EhhB>w(7-JE04%rYLDQlSnsUIR55W#OCIs{z
zk;4K%tj86~i9Ez14A|PaByf3E1Tpsw2w(R_)yOm&8)0Oq(BJfeiV;g;tP0=fQG+Q_
zB|*gzk42^aps_H0ZhUrif*mX**^p69e6Cfc^kI{Ya^DZH+DYIP$>G{gnACiTQa9MX
z4G=W1jYJcXMGtACv;i8t>=$f*`7UsT9oK7u_0IA{sqt0exx!}yRaBC#9plBqiIYgM
z7Jy=hGcCfkOAQKj0L99phvBQUa*SI9O<b^nk|hTLWb{Z%Qzq-Hg(@B|;nK84GiHek
zl_0iA=Pa59aLzgkwRGO1xjYg{!VXm{4IB+6DLrb+^Ky>$Xi*5!CXaw_Udxfwat6hw
z)t7{X^@dS}2j2C}xsDV1J`9HMRQHm0o^YqLvcF)_0xVoKStooKqd_QIvS`_qpgac3
zipkn_5AfD$HKjGylFUsLW1Ze64=TtDx~POjA2C^LfIOi~tZ%OBga)X_tR{aH)Q_30
zO;ow()8p)rH&MJi8z+d#Mm!Pt^l@-mrgliR#)CRN!8+HNF|EmDgZ2rNb-SX*qgdx6
z@kQLN19KS+a`cT03EXuf^h^@^V#8!zvG7GrhJm1pzLJ@iB#6-my+t9OS)t3?)+?~p
zHzjPWO2#^T<fV@;6lm*0Q(j`d7m_Pn84LM+4cBM_kF!yKB4<6Tv^_yQvCXUqT*{PB
zNNq!G$_#g6$_(wMDKn5)O_?FPX37FkU4Z>MOwMD7daKeWQ~H$2db|Logn9~f^wX3+
z&AN-YF~sFbc~NoJ-AHioJY}Zzw0u$qDy7fhFT#~%R)1DLA|HiaW4j7>9A&y>ltrs+
zmOh6zV+Wxt=$Vv0pSQR#=#0^Itq01p(m^Y1Vm&HZZ(QEcDOIicA{O)<YxDWK@aZNJ
zmJPTbuY>{jZ6vLyvyz_2>%KCYS?SU())9#c+CxMyWV1v!A3F+tK`+X4Y@lH!$~eD%
zi4E%NKy7CpGB{M!m8W23(`2Ft$QMnSW9^VP<a6>S`rh;No${7^LB5DGdWj9~sN#kM
z`jWgP`xD*Azg&uF&O}_22U({QF=lB+(N|LXs>u#i`8BVaRP7vzt~z>o;h!z6i~I1G
z7t1OendVo*m>Z8JTzTV*;%XcQMpeWzbXgy-)%?1x9IiXxv+QUoui+rE$^9fNZKdTN
zLJsJNAv^3C4vIJ$;OxUA_y6NxN2kWw;EuMqhn}!~B}0_Y>Q~^Co2+GNc@6GqW^GFH
znxL<-rU%%5v>2}v*yukVM?{cTUpLwCDVN85)sZOkQxy@ykf?s@+Ub<Ofuu!G#|p9@
zVwTXWi>xQ9)f(s57Fk~qR<Squkm)CazBzkG@sr#}?sdrhmMLFdl&>wy|AYNZO5c7P
z_Jkb>*Dvd~xG5U;SoAs@+HOsrL_(d~pzm;GNLSccQQp|$_-!8f?k<lsWK@9sdj*tT
z)@|_s?)OWcBwH4KQ082jw!?@^$5z@(ou0#q-gSPsoAn4-+jp@ZN%Xq$qms2H%Vgy4
zk1>LMu9wEFgmmH}pD=?1h4~rHH_4ahU3RR@mTbzF>10PjPx4JM`_P+z|Ih1h{rlGK
z82LK(h9ur%Oynzoc$2kag}n&4EmEhN_I0T#f_($oGW3%Y^c@;B+KSi|{vrf)<pP#g
zAmENtK##MvltM&rqL-+jmLgh<CU62zS_>DQhgz%=SUQBeRsKK2;}eNq{C-|OZYv&-
z;c?s6W2srkFvbUT!`!)d{{oxy{(N6wURhe6Sy`K#S*2fE^d{z1S=)+!#oF{+MZd<_
z#15|LH`)`$9z?%oeX5R?8to;hC79Q53D&o`G(BTaO|IE%D>F0nyOe&9{#<5cN`Elf
zh~5DZMb~h=$kA=pC}moD0V;?nbu0(lNMn0Qd!M7x=jb4*6tI`8za%x7_bIdj--Eu)
z6ib^4914kNvGy>DVV}hY8(f8ef_bQh&i{7Sv`QqU#ReM48}Jh8r1ZyZj$)k<fgacv
z=4_@3%}iNaLknm!McFmhvhDN6z*3<%k(B;~(0Kudn4Za&e8bW`p;kBYHi<nbZ<7`q
zazkO{iVVf|Tr~9eGmG7sKlhDF0swm-j(UJuU@Zld$pYsrOiwnVwM`xN+DVHY&q^1`
z5;%2ml|y11-+@LuGq!~GYN6%ygboco^Tkf&qbiA_u!1eXs3Ku~19K}1G5T<0vAcKL
zbsL<68@lzEc5S(<zl@o2Rd^K%KaJ*`|69&(w<oM`WoibdS8G@Sb-@0Nz3S4!1!E!m
z@@e7w5ZgDW3&~iH!cE=gEPOL!-BZhxQ>(^W82UKq2Ny!FiR}24Zijn)y3Ku>eYsv}
zz<4dq!dEBceoB7<2A!k%82}o_W(+#zca~wv*jpq}!FH%o8F_SyYs94}tL+6-$Utjq
bvsL0a^jCS`*1riLc=x{v{wCX#^@;xif^HLx

diff --git a/kadmos/vistoms/examples/SsbjARCG_06.kdms b/kadmos/vistoms/examples/SsbjARCG_06.kdms
deleted file mode 100644
index 92aa2441ef6c88a497ddfd3cc9b5719b17fb93d1..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 16612
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
F{{o-x4)g#3

diff --git a/kadmos/vistoms/examples/SsbjBFPG_07.kdms b/kadmos/vistoms/examples/SsbjBFPG_07.kdms
deleted file mode 100644
index a5f6ff5e6c49867e06b37fe0dfbf0f711778cfeb..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 18581
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
XLg)ude;EjH2mUe;k0MAN6l(q-nj$)$

diff --git a/kadmos/vistoms/examples/SsbjCBLISS_08.kdms b/kadmos/vistoms/examples/SsbjCBLISS_08.kdms
deleted file mode 100644
index 3d3e391cc0df99b892b9617dcedb4601fbcdae92..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 77715
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

diff --git a/kadmos/vistoms/examples/SsbjCBLISS_08_mpg.kdms b/kadmos/vistoms/examples/SsbjCBLISS_08_mpg.kdms
deleted file mode 100644
index 504dd2dded4d06b0b230532b3b0c15dda24d2c11..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 29370
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

diff --git a/kadmos/vistoms/examples/SsbjDCO_09.kdms b/kadmos/vistoms/examples/SsbjDCO_09.kdms
deleted file mode 100644
index d148010d98e644d7218bae776571f18ec29d70ff..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 51690
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
F_<sO4boT%N

diff --git a/kadmos/vistoms/examples/SsbjDCO_09_mpg.kdms b/kadmos/vistoms/examples/SsbjDCO_09_mpg.kdms
deleted file mode 100644
index 7184db6746746f0bff352a3134bbaf16c3701480..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 17112
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

diff --git a/kadmos/vistoms/examples/scriptfornamechange.py b/kadmos/vistoms/examples/scriptfornamechange.py
deleted file mode 100644
index 9c4b26507..000000000
--- a/kadmos/vistoms/examples/scriptfornamechange.py
+++ /dev/null
@@ -1,22 +0,0 @@
-from kadmos.graph import load
-
-name_list = [('SellarARCG_01.kdms', 'Sellar problem - tool database'),
-             ('SellarBFPGIDF_02.kdms', 'Sellar problem - MDO problem IDF'),
-             ('SellarCMDAOIDF_03.kdms', 'Sellar problem - MDO strategy IDF'),
-             ('SellarCMDAOIDF_03_mpg.kdms', 'Sellar problem - MDO strategy IDF'),
-             ('SellarDFPGMDFGS_04.kdms', 'Sellar problem - MDO problem MDF'),
-             ('SellarEMDAOMDFGS_05.kdms', 'Sellar problem - MDO strategy MDF'),
-             ('SellarEMDAOMDFGS_05_mpg.kdms', 'Sellar problem - MDO strategy MDF'),
-             ('SsbjARCG_06.kdms', 'SSBJ problem - tool database'),
-             ('SsbjBFPG_07.kdms', 'SSBJ problem - MDO problem'),
-             ('SsbjCBLISS_08.kdms', 'SSBJ problem - MDO strategy BLISS-2000'),
-             ('SsbjCBLISS_08_mpg.kdms', 'SSBJ problem - MDO strategy BLISS-2000'),
-             ('SsbjDCO_09.kdms', 'SSBJ problem - MDO strategy Collaborative Optimization'),
-             ('SsbjDCO_09_mpg.kdms', 'SSBJ problem - MDO strategy Collaborative Optimization'),
-             ('TudelftRCG_10.kdms', 'TU Delft wing design - tool database')]
-
-for name in name_list:
-
-    graph = load(name[0])
-    graph.name = name[1]
-    graph.save(name[0])
\ No newline at end of file
diff --git a/kadmos/vistoms/interface_start.py b/kadmos/vistoms/interface_start.py
index c2bd6f011..d332b3dfd 100644
--- a/kadmos/vistoms/interface_start.py
+++ b/kadmos/vistoms/interface_start.py
@@ -1,16 +1,14 @@
 # Imports
 import logging
-import kadmos.vistoms.interface_vistoms as interface
+import kadmos.vistoms.vistoms as vistoms_interface
 
 
 # Settings for the logger
 logger = logging.getLogger(__name__)
 # logging.basicConfig(format='%(levelname)s: %(asctime)s %(message)s', filename='interface.log', level=logging.INFO)
 
-
 # Settings for the interface
-app = interface.interface()
-
+app = vistoms_interface.interface()
 
 if __name__ == '__main__':
     # Run the interface
diff --git a/kadmos/vistoms/interface_vistoms.py b/kadmos/vistoms/interface_vistoms.py
deleted file mode 100644
index f062754eb..000000000
--- a/kadmos/vistoms/interface_vistoms.py
+++ /dev/null
@@ -1,2064 +0,0 @@
-import ast
-import fnmatch
-import json
-import logging
-import os
-import shutil
-import sys
-import tempfile
-import time
-import uuid
-import zipfile
-from copy import deepcopy
-from shutil import copyfile
-
-import networkx as nx
-from flask import Flask, request, render_template, jsonify
-from kadmos.cmdows.cmdows import find_cmdows_file
-from kadmos.graph import load, FundamentalProblemGraph
-
-# Folder and file settings
-UPLOAD_FOLDERS = dict()
-TEMP_FILE = 'tmp'
-
-
-def interface(debug=True, tempdir=None):
-
-    # Initial settings
-    app = Flask(__name__)
-    if debug:
-        app.debug = True
-    if tempdir:
-        tempfile.tempdir = tempdir
-
-    # Index
-    @app.route("/")
-    def index(error=None, message=None, selection=False):
-        # Check if error or message is send
-        if request.values.get('error', False) and error is None:
-            error = request.values['error']
-        if request.values.get('message', False) and message is None:
-            message = request.values['message']
-        # Render index
-        return render_template('index.html', error=error, message=message, selection=selection, page='start')
-
-    # Start the empty vistoms app
-    @app.route('/startnewvistoms')
-    def start_new_vistoms(error=None, message=None):
-
-        # Check if error or message is send
-        if request.values.get('error', False) and error is None:
-            error = request.values['error']
-        if request.values.get('message', False) and message is None:
-            message = request.values['message']
-        logging.basicConfig(format='%(levelname)s: %(message)s', level=logging.DEBUG)
-
-        # Get random uuid for session
-        session_id = str(uuid.uuid4())
-
-        # Create temporary directory and its mapping with the session ID in the global variable
-        UPLOAD_FOLDERS[session_id] = tempfile.mkdtemp()
-
-        # Wait for directory to exist
-        attempts = 0
-        while True:
-            if os.path.isdir(UPLOAD_FOLDERS[session_id]):
-                break
-            time.sleep(1)
-            attempts += 1
-            if attempts > 20:
-                raise ReferenceError('Could not create new temporary directory.')
-
-        return render_template('VISTOMS_sessions.html', new=0, error=error, message=message, sessionID=session_id)
-
-    # Start the populated vistoms app
-    @app.route('/startpopulatedvistoms')
-    def start_populated_vistoms(error=None, message=None):
-
-        # Check if error or message is send
-        if request.values.get('error', False) and error is None:
-            error = request.values['error']
-        if request.values.get('message', False) and message is None:
-            message = request.values['message']
-        logging.basicConfig(format='%(levelname)s: %(message)s', level=logging.DEBUG)
-
-        # Get random uuid for session
-        session_id = str(uuid.uuid4())
-
-        # Create temporary directory and its mapping with the session ID in the global variable
-        UPLOAD_FOLDERS[session_id] = tempfile.mkdtemp()
-
-        # Wait for directory to exist
-        attempts = 0
-        while True:
-            if os.path.isdir(UPLOAD_FOLDERS[session_id]):
-                break
-            time.sleep(1)
-            attempts += 1
-            if attempts > 20:
-                raise ReferenceError('Could not create new temporary directory.')
-
-        # Copy all files from folder to another folder
-        folder = os.path.join(os.path.dirname(os.path.abspath(__file__)), 'examples')
-        src_files = os.listdir(folder)
-        for file_name in src_files:
-            full_file_name = os.path.join(folder, file_name)
-            if (os.path.isfile(full_file_name)):
-                shutil.copy(full_file_name, UPLOAD_FOLDERS[session_id])
-
-        return render_template('VISTOMS_sessions.html', new=0, error=error, message=message, sessionID=session_id)
-
-    # Info
-    @app.route('/info')
-    def info():
-        return render_template('info.html', page='info')
-
-    # Acknowledgements
-    @app.route('/acknowledgements')
-    def acknowledgements():
-        return render_template('acknowledgements.html', page='acknowledgements')
-
-    @app.route('/kadmos_upload_file', methods=['GET', 'POST'])
-    def kadmos_upload_file():
-        """
-            Function uploads a file to the temp folder and returns the graph information to VISTOMS
-
-            :return: VISTOMS json data with graph information
-        """
-        try:
-            if request.method == 'POST':
-                # get request form
-                fileType = request.form['fileType']
-                newGraphID = request.form['newGraphID']
-                sessionID = request.form['sessionID']
-                uploaded_files = request.files.getlist("file[]")
-
-                number_of_files = len(uploaded_files)
-                if number_of_files > 2:
-                    return ("ERROR: Max. number of files that can be uploaded is 2!")
-
-                mpgFile = []
-                dgFile = []
-                for file in uploaded_files:
-                    if "_mpg" in file.filename:
-                        mpgFile = file
-                    else:
-                        dgFile = file
-
-                # check if the post request has the file part
-                if 'file[]' not in request.files:
-                    return ("ERROR: No file part!")
-
-                # if user does not select file, browser also
-                # submit a empty part without filename
-                if dgFile.filename == '':
-                    return ("ERROR: No file part!")
-                if dgFile:
-                    # Check if the right filetypes were chosen
-                    if fileType == 'CMDOWS file' and dgFile.filename.rsplit('.', 1)[1].lower() != "xml":
-                        return ("ERROR: Wrong file type! Please use a valid CMDOWS file")
-                    elif fileType == 'KDMS file(s)' and dgFile.filename.rsplit('.', 1)[1].lower() != "kdms":
-                        return ("ERROR: Wrong file type! Please use a valid KDMS file")
-                    elif fileType == 'Database' and dgFile.filename.rsplit('.', 1)[1].lower() != "zip":
-                        return ("ERROR: Wrong file type! Please use a valid zip file")
-
-                    upload_folder = UPLOAD_FOLDERS[sessionID]
-                    if not os.path.exists(upload_folder):
-                        os.makedirs(upload_folder)
-
-                database_dir = ""
-                if fileType == 'Database':
-                    database_dir = os.path.join(upload_folder, 'database_tmp')
-                    zip_ref = zipfile.ZipFile(file, 'r')
-                    zip_ref.extractall(database_dir)
-                    zip_ref.close()
-                    file_list = []
-                    database_listdir = os.listdir(database_dir)
-
-                    # Handle case where the database is stored as a subfolder in de zip archive (as done on MacOS)
-                    actual_database_dir = database_dir
-                    if len(database_listdir) == 1 or '__MACOSX' in database_listdir:
-                        if '__MACOSX' in database_listdir:
-                            database_listdir.remove('__MACOSX')
-                        if os.path.isdir(os.path.join(database_dir, database_listdir[0])):
-                            actual_database_dir = os.path.join(database_dir, database_listdir[0])
-                    for file in os.listdir(actual_database_dir):
-                        file_list.append(os.path.join(actual_database_dir, file))
-                    cmdows_file = find_cmdows_file(file_list)
-                    graphFileName = cmdows_file
-                else:
-                    graphFileName = os.path.join(upload_folder, dgFile.filename)
-                    dgFile.save(os.path.join(upload_folder, dgFile.filename))
-
-                loaded_graph = load(graphFileName, file_check_critical=False)
-                if "name" not in loaded_graph.graph:
-                    loaded_graph.graph["name"] = os.path.splitext(dgFile.filename)[0].replace("_",".")
-                # Remove the uploaded file (and if existing, database directory) from the temp folder
-                os.remove(graphFileName)
-                if os.path.exists(database_dir):
-                    shutil.rmtree(database_dir)
-
-                if isinstance(loaded_graph, tuple):
-                    graph = loaded_graph[0]
-                    mpg = loaded_graph[1]
-                elif mpgFile:
-                    # Check if the right filetype was chosen
-                    if mpgFile.filename.rsplit('.', 1)[1].lower() != "kdms":
-                        return ("ERROR: Wrong file type! Please use a valid KDMS file")
-                    graph = loaded_graph
-                    mpgFileName = mpgFile.filename
-                    mpgFile.save(os.path.join(upload_folder, mpgFileName))
-                    mpg = load(os.path.join(upload_folder, mpgFileName), file_check_critical=True)
-                    # Remove the uploaded file from the temp folder
-                    os.remove(os.path.join(upload_folder, mpgFileName))
-                else:
-                    graph = loaded_graph
-                    mpg = None
-
-                # save the graph as kdms file in temp folder
-                graph.save(os.path.join(upload_folder, TEMP_FILE + '_' + newGraphID + '.kdms'), file_type='kdms',
-                           graph_check_critical=False, mpg=mpg)
-
-                # Use function order for VISTOMS if it is available in the graph information
-                function_order = None
-                if graph.graph_has_nested_attributes('problem_formulation', 'function_order') and mpg == None:
-                    function_order = graph.graph['problem_formulation']['function_order']
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = graph.vistoms_add_json(graph_id=newGraphID, function_order=function_order, mpg=mpg)
-
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-
-    @app.route('/kadmos_create_new_graph', methods=['POST'])
-    def kadmos_create_new_graph():
-        try:
-            # Get request form
-            graph_name = request.form['graph_name']
-            graph_description = request.form['graph_description']
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Open cmdows template file and load it as graph
-            cmdows_template = os.path.join('templates', 'cmdows_template.xml')
-            graph_template = load(cmdows_template, check_list=['consistent_root', 'invalid_leaf_elements'])
-
-            # Determine graph_id
-            graph_ids = []
-            for aFile in os.listdir(upload_folder):
-                if aFile.endswith('.kdms'):
-                    filename = aFile.split('.kdms')[0]
-                    graph_ids.append(int(filename.split('_')[1]))
-            graph_id_int = max(graph_ids)+1
-            graph_id = format(graph_id_int, "02")
-
-            # Allocate graph name, description and id
-            graph_template.graph['name'] = graph_name
-            graph_template.graph['description'] = graph_description
-            graph_template.graph['id'] = graph_id
-
-            # Delete dummy design competence
-            graph_template.remove_node('dummy')
-
-            # Save empty graph as kdms file
-            graph_template.save(os.path.join(upload_folder, 'tmp_'+graph_id+'.kdms'), file_type='kdms', graph_check_critical=False, mpg=None)
-
-            # Add graph to vistoms data
-            newVistomsData = graph_template.vistoms_add_json(mpg=None, graph_id=graph_id)
-
-            return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-
-    @app.route('/kadmos_export_all_graphs', methods=['POST'])
-    def kadmos_export_all_graphs():
-        """
-           Function exports all graphs to a folder as CMDOWS or KDMS files
-
-           :param path: the path of the folder, the files are exported to
-           :return: path
-        """
-        try:
-            # Get request form
-            path = os.path.join(request.form['path'], '')
-            fileType = request.form['fileType']
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            if not os.path.isdir(path):
-                os.makedirs(os.path.dirname(path))
-
-            for aFile in os.listdir(upload_folder):
-                if aFile.endswith(".kdms"):
-                    fileName = aFile.split('.')[0]
-                    fileName_split = fileName.split('_')
-                    if "mpg" not in fileName_split and "backup" not in fileName_split:  # Do not loop through mpg files
-                        graphFileName = fileName + ".kdms"
-                        mpgFileName = fileName + "_mpg.kdms"
-                        if os.path.exists(os.path.join(upload_folder, mpgFileName)):
-                            graph = load(os.path.join(upload_folder, graphFileName), file_check_critical=False)
-                            mpg = load(os.path.join(upload_folder, mpgFileName), file_check_critical=False)
-                        else:
-                            graph = load(os.path.join(upload_folder, graphFileName), file_check_critical=False)
-                            mpg = None
-
-                        # Add problem function roles if they are not already existing
-                        if not hasattr(graph, 'name'):
-                            graph_name = fileName
-                        else:
-                            graph_name = graph.name
-                        # Add problem function roles if they are not already existing
-                        if isinstance(graph, FundamentalProblemGraph):
-                            if 'function_order' not in graph.graph['problem_formulation']:
-                                graph.assert_or_add_nested_attribute(['problem_formulation', 'function_order'],
-                                                                     None)
-                            if 'mdao_architecture' not in graph.graph['problem_formulation']:
-                                graph.assert_or_add_nested_attribute(['problem_formulation', 'mdao_architecture'],
-                                                                     'undefined')
-                            if 'allow_unconverged_couplings' not in graph.graph['problem_formulation']:
-                                graph.assert_or_add_nested_attribute(
-                                    ['problem_formulation', 'allow_unconverged_couplings'],
-                                    False)
-                            graph.add_function_problem_roles()
-
-                        if fileType == "CMDOWS files":
-                            file_type = "cmdows"
-                            file = graph_name + ".xml"
-                            # Save as CMDOWS file
-                            graph.save(os.path.join(upload_folder, graph_name), file_type=file_type,
-                                       graph_check_critical=False, mpg=mpg)
-                            # Copy CMDOWS file from temporary folder to user's download folder
-                            copyfile(os.path.join(upload_folder, file), os.path.join(path, file))
-                            # remove temporary CMDOWS file
-                            os.remove(os.path.join(upload_folder, file))
-                        elif fileType == "KDMS files":
-                            file_type = "kdms"
-                            # Save as kdms file
-                            graph.save(os.path.join(upload_folder, graph_name), file_type=file_type,
-                                       graph_check_critical=False, mpg=mpg)
-                            file = graph_name + ".kdms"
-                            mpgfile = graph_name + "_mpg.kdms"
-                            # Copy kdms file from temporary folder to user's download folder
-                            copyfile(os.path.join(upload_folder, file), os.path.join(path, file))
-                            # remove temporary kdms file
-                            os.remove(os.path.join(upload_folder, file))
-                            if os.path.exists(os.path.join(upload_folder, mpgfile)):
-                                copyfile(os.path.join(upload_folder, mpgfile), os.path.join(path, mpgfile))
-                                os.remove(os.path.join(upload_folder, mpgfile))
-            return path
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_export_graph', methods=['POST'])
-    def kadmos_export_graph():
-        """
-           Function exports the current graph to a CMDOWS or kdms file
-
-           :param file: a CMDOWS or kdms file that goes into the user's download folder
-           :return: file
-        """
-        try:
-            # Get request form
-            path = os.path.join(request.form['path'], '')
-            fileName = request.form['fileName']
-            graphID = request.form['graphID']
-            fileType = request.form['fileType']
-            functionOrder = request.form['currentOrder'].split(',')
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(upload_folder, mpgFileName)):
-                graph = load(os.path.join(upload_folder, graphFileName), file_check_critical=False)
-                mpg = load(os.path.join(upload_folder, mpgFileName), file_check_critical=False)
-            else:
-                graph = load(os.path.join(upload_folder, graphFileName), file_check_critical=False)
-                mpg = None
-
-            # Add problem function roles if they are not already existing
-            if isinstance(graph, FundamentalProblemGraph):
-                if 'function_order' not in graph.graph['problem_formulation']:
-                    graph.assert_or_add_nested_attribute(['problem_formulation', 'function_order'], None)
-                if 'mdao_architecture' not in graph.graph['problem_formulation']:
-                    graph.assert_or_add_nested_attribute(['problem_formulation', 'mdao_architecture'], 'undefined')
-                if 'allow_unconverged_couplings' not in graph.graph['problem_formulation']:
-                    graph.assert_or_add_nested_attribute(['problem_formulation', 'allow_unconverged_couplings'], False)
-                graph.add_function_problem_roles()
-
-            if not os.path.isdir(path):
-                os.makedirs(os.path.dirname(path))
-
-            if fileType == "kdms":
-                copyfile(os.path.join(upload_folder, graphFileName), os.path.join(path, fileName + ".kdms"))
-                if os.path.exists(os.path.join(upload_folder, mpgFileName)):
-                    copyfile(os.path.join(upload_folder, mpgFileName), os.path.join(path, fileName + '_mpg' + ".kdms"))
-            elif fileType == "cmdows":
-                file = fileName + ".xml"
-                # Save as CMDOWS file
-                graph.save(os.path.join(upload_folder, fileName), file_type=fileType, graph_check_critical=False,
-                           mpg=mpg)
-                # Copy CMDOWS file from temporary folder to user's download folder
-                copyfile(os.path.join(upload_folder, file), os.path.join(path, file))
-                # remove temporary CMDOWS file
-                os.remove(os.path.join(upload_folder, file))
-            else:
-                return ("ERROR: Wrong file type!!!")
-
-            return (path)
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_save_vistoms_graph', methods=['POST'])
-    def kadmos_save_vistoms_graph():
-        """
-           Function saves current graph as new VISTOMS graph and returns it to the VISTOMS package in the browser
-
-           :return: the graph compressed as VISTOMS data
-        """
-        try:
-            # get request form
-            graphID = request.form['graphID']
-            newGraphName = request.form['newGraphName']
-            newGraphID = request.form['newGraphID']
-            function_order = request.form['currentOrder'].split(',')
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            tmpDir = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(tmpDir, mpgFileName)):
-                graph = load(os.path.join(tmpDir, graphFileName), file_check_critical=False)
-                mpg = load(os.path.join(tmpDir, mpgFileName), file_check_critical=False)
-            else:
-                graph = load(os.path.join(tmpDir, graphFileName), file_check_critical=False)
-                mpg = None
-
-            newFileName = TEMP_FILE + '_' + newGraphID + '.kdms'
-            graph.graph['name'] = newGraphName
-            graph.save(os.path.join(upload_folder, newFileName), file_type="kdms", graph_check_critical=False, mpg=mpg)
-
-            newVistomsData = graph.vistoms_add_json(function_order=function_order, mpg=mpg, graph_id=newGraphID)
-
-            return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_delete_graph', methods=['POST'])
-    def kadmos_delete_graph():
-        """
-           Function finds all graphs that have been temporarily stored in the temp folder and returns them
-           to the VISTOMS package in the browser. This function is always called when the browser is refreshed by the user.
-
-           :return: the graphs compressed as VISTOMS data
-        """
-        try:
-            # get request form
-            graphID = request.form['graphID']
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            tmpDir = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            backupGraphFileName = TEMP_FILE + '_' + graphID + '_backup.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            backupMpgFileName = TEMP_FILE + '_' + graphID + '_mpg_backup.kdms'
-            if os.path.exists(os.path.join(tmpDir, graphFileName)):
-                os.remove(os.path.join(tmpDir, graphFileName))
-            if os.path.exists(os.path.join(tmpDir, backupGraphFileName)):
-                os.remove(os.path.join(tmpDir, backupGraphFileName))
-            if os.path.exists(os.path.join(tmpDir, mpgFileName)):
-                os.remove(os.path.join(tmpDir, mpgFileName))
-            if os.path.exists(os.path.join(tmpDir, backupMpgFileName)):
-                os.remove(os.path.join(tmpDir, backupMpgFileName))
-
-            return kadmos_find_temp_graphs()
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_find_temp_graphs', methods=['POST'])
-    def kadmos_find_temp_graphs():
-        """
-           Function finds all graphs that have been temporarily stored in the temp folder and returns them
-           to the VISTOMS package in the browser. This function is always called when the browser is refreshed by the user.
-
-           :return: the graphs compressed as VISTOMS data
-        """
-        try:
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # First of all, delete all graphs, that end with a _backup
-            delete_backup_graphs(upload_folder)
-
-            tmpDir = upload_folder
-            newVIstomsDataArray = []
-            file_list = os.listdir(tmpDir)
-            if file_list:
-                file_list.sort()
-            for file in file_list:
-                if file.endswith(".kdms"):
-                    fileName = file.split('.')[0].split('_')
-                    graphID = fileName[1]
-                    if "mpg" not in fileName:  # Do not loop through mpg files
-                        graphFileName = fileName[0] + "_" + graphID + ".kdms"
-                        mpgFileName = fileName[0] + "_" + graphID + "_mpg.kdms"
-                        if os.path.exists(os.path.join(tmpDir, mpgFileName)):
-                            graph = load(os.path.join(tmpDir, graphFileName), file_check_critical=False)
-                            mpg = load(os.path.join(tmpDir, mpgFileName), file_check_critical=False)
-                        else:
-                            graph = load(os.path.join(tmpDir, graphFileName), file_check_critical=False)
-                            mpg = None
-
-                        # Use function order for VISTOMS if it is available in the graph information
-                        function_order = None
-                        if graph.graph_has_nested_attributes('problem_formulation', 'function_order') and mpg == None:
-                            function_order = graph.graph['problem_formulation']['function_order']
-
-                        graph.save(os.path.join(upload_folder, graphFileName), file_type="kdms",
-                                   graph_check_critical=False, mpg=mpg)
-
-                        newVIstomsDataArray.append(
-                            graph.vistoms_add_json(graph_id=graphID, function_order=function_order,
-                                                   mpg=mpg))
-
-            return jsonify(newVIstomsDataArray)
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_revert_step', methods=['POST'])
-    def kadmos_revert_step():
-        """
-           Function to revert the last graph manipulation step by returning the _backup file from the tepm folder
-           :return: the graph compressed as VISTOMS data
-        """
-        try:
-            # get request form
-            graphID = request.form['graphID']
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            tmpDir = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            backupGraphFileName = TEMP_FILE + '_' + graphID + '_backup.kdms'
-            backupMpgFileName = TEMP_FILE + '_' + graphID + '_backup_mpg.kdms'
-
-            graph = load(os.path.join(tmpDir, graphFileName), file_check_critical=False)
-            backupGraph = load(os.path.join(tmpDir, backupGraphFileName), file_check_critical=False)
-            if os.path.exists(os.path.join(tmpDir, mpgFileName)):
-                mpg = load(os.path.join(tmpDir, mpgFileName), file_check_critical=False)
-                os.remove(os.path.join(tmpDir, mpgFileName))
-            else:
-                mpg = None
-
-            if os.path.exists(os.path.join(tmpDir, backupMpgFileName)):
-                backupMpg = load(os.path.join(tmpDir, backupMpgFileName), file_check_critical=False)
-                os.remove(os.path.join(tmpDir, backupMpgFileName))
-            else:
-                backupMpg = None
-
-            # Switch graph and backup graph (What used to be the backup graph is now the new graph and vice versa)
-            graph.save(os.path.join(upload_folder, backupGraphFileName), file_type="kdms", graph_check_critical=False,
-                       mpg=mpg)
-            backupGraph.save(os.path.join(upload_folder, graphFileName), file_type="kdms", graph_check_critical=False,
-                             mpg=backupMpg)
-
-            # Get function_oder of the backup graph
-            function_order = None
-            if backupGraph.graph_has_nested_attributes('problem_formulation', 'function_order'):
-                function_order = backupGraph.graph['problem_formulation']['function_order']
-
-            newVistomsData = backupGraph.vistoms_add_json(function_order=function_order,  mpg=backupMpg, graph_id=graphID)
-
-            return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    def savePreviousGraph(graph_id, upload_folder):
-        """
-            Function saves the last graph, so you can revert a graph change within VISTOMS
-
-            :param graph: Initial fundamental problem graph (FPG) to start working on the MDAO architecture definition
-            :return: New VISTOMS json data with initial FPG
-        """
-        path = upload_folder
-        # current graph and mpg name
-        graphFileName = TEMP_FILE + '_' + graph_id + '.kdms'
-        mpgFileName = TEMP_FILE + '_' + graph_id + '_mpg.kdms'
-
-        # Save graph as backup file
-        backupGraphFileName = TEMP_FILE + '_' + graph_id + '_backup.kdms'
-        copyfile(os.path.join(path, graphFileName), os.path.join(path, backupGraphFileName))
-        if os.path.exists(os.path.join(path, mpgFileName)):
-            # If mpg exists, save it as well
-            backupMpgFileName = TEMP_FILE + '_' + graph_id + '_mpg_backup.kdms'
-            copyfile(os.path.join(path, mpgFileName), os.path.join(path, backupMpgFileName))
-
-    def delete_backup_graphs(upload_folder):
-        """
-        Function deletes all graphs that end with a _backup
-        """
-        for file in os.listdir(upload_folder):
-            if fnmatch.fnmatch(file, '*_backup*'):
-                os.remove(os.path.join(upload_folder, file))
-########################################################################################################################
-
-
-    # Graph inspection functions
-    ########################################################################################################################
-    @app.route('/kadmos_find_all_nodes', methods=['POST'])
-    def kadmos_find_all_nodes():
-        """
-            Function to get all nodes from certain categories and return them
-
-            :param method: The method for sorting the nodes. Specified by the user from VISTOMS
-            :return: New VISTOMS json data with updated design competences
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            category = str(request.form['category'])
-            sub_category = str(request.form['sub_category'])
-            attr_cond = ast.literal_eval(request.form['attr_cond'])
-            attr_include = ast.literal_eval(request.form['attr_include'])
-            attr_exclude = ast.literal_eval(request.form['attr_exclude'])
-            xPath_include = str(request.form['xPath_include']).split(', ')
-            xPath_exclude = str(request.form['xPath_exclude']).split(', ')
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = load(os.path.join(path, mpgFileName), file_check_critical=False)
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-            if attr_cond == []:
-                attr_cond = None
-            if attr_include == []:
-                attr_include = None
-            if attr_exclude == []:
-                attr_exclude = None
-            if xPath_include == [""]:
-                xPath_include = None
-            if xPath_exclude == [""]:
-                xPath_exclude = None
-
-            allNodes = graph.find_all_nodes(category=category, subcategory=sub_category, attr_cond=attr_cond,
-                                            attr_include=attr_include, attr_exclude=attr_exclude,
-                                            xpath_include=xPath_include, xpath_exclude=xPath_exclude)
-
-            # allNodes_str = ', '.join(str(e) for e in allNodes)
-            allNodes_str = json.dumps(allNodes)
-
-            return allNodes_str
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_L1_check', methods=['POST'])
-    def kadmos_L1_check():
-        """
-            Function to perform category a checks on the graph
-
-            :return: Message, whether the check was successful or not
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = load(os.path.join(path, mpgFileName), file_check_critical=False)
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-            check_result = graph._check_category_a()
-
-            if check_result[0] == True:
-                return ("Check successful!")
-            else:
-                return "ERROR: Check was not successful. For further information, please consult the python log"
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_L2_check', methods=['POST'])
-    def kadmos_L2_check():
-        """
-            Function to perform category b checks on the graph
-
-            :return: Message, whether the check was successful or not
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = load(os.path.join(path, mpgFileName), file_check_critical=False)
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-            check_result = graph._check_category_b()
-
-            if check_result[0] == True:
-                return ("Check successful!")
-            else:
-                return "ERROR: Check was not successful. For further information, please consult the python log"
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_L3_check', methods=['POST'])
-    def kadmos_L3_check():
-        """
-            Function to perform category c checks on the graph
-
-            :return: Message, whether the check was successful or not
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = load(os.path.join(path, mpgFileName), file_check_critical=False)
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-            check_result = graph._check_category_c()
-
-            if check_result[0] == True:
-                return ("Check successful!")
-            else:
-                return "ERROR: Check was not successful. For further information, please consult the python log"
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    ########################################################################################################################
-
-
-    # Upload custom kadmos script
-    ########################################################################################################################
-    @app.route('/kadmos_run_custom_script', methods=['POST'])
-    def kadmos_run_custom_script():
-        """
-            Generic function to import and execute a custom kadmos script
-
-            :param script_file: the custom kadmos script
-            :param graph: the kadmos graph, on which the changes are performed
-            :return: newVistomsData: Merged string of the vistoms data and the script string value
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            uploaded_files = request.files.getlist("file[]")
-
-            script_file = []
-            for aFile in uploaded_files:
-                file_type = aFile.filename.rsplit('.', 1)[1].lower()
-                if not file_type == "py":
-                    return "ERROR: wrong file type \"" + file_type + "\""
-                script_file = aFile
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID)
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = load(os.path.join(path, mpgFileName), file_check_critical=False)
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-            # save kadmos script in temp folder
-            script_file.save(os.path.join(upload_folder, script_file.filename))
-            kadmos_file_path = os.path.join(upload_folder, script_file.filename)
-
-            # execute script and return graph data (graph, mpg)
-            import imp
-            script_module = imp.load_source('kadmos_custom_fun_{}', kadmos_file_path)
-            graph, mpg = script_module.script(graph, mpg)
-
-            # Get function order for VISTOMS in case of FPG
-            function_order = None
-            if mpg == None:
-                # Get function_oder of the graph after the script has done the manipulations
-                if graph.graph_has_nested_attributes('problem_formulation', 'function_order'):
-                    function_order = graph.graph['problem_formulation']['function_order']
-
-            # Add modified graph to VISTOMS
-            newVistomsData = graph.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-            # Save the graph in temp/tmp.kdms
-            graph.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'), file_type='kdms',
-                       graph_check_critical=False, mpg=mpg)
-            return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    ########################################################################################################################
-
-
-    # FPG manipulation functions
-    ########################################################################################################################
-    @app.route('/kadmos_start_defining_MDO_problem', methods=['POST'])
-    def kadmos_start_defining_MDO_problem():
-        """
-            Function to start an MDO problem
-
-            :param fpg_initial: Initial fundamental problem graph (FPG) to start working on the MDO problem definition
-            :return: New VISTOMS json data with initial FPG
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            functionOrder = request.form['currentOrder'].split(',')
-            newGraphID = request.form['newGraphID']
-            newGraphName = request.form['newGraphName']
-
-            newFileName = TEMP_FILE + '_' + newGraphID + '.kdms'
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return ("ERROR: Graph is already an MDPG! FPG Cannot be initialized again!")
-            else:
-                mpg = None
-
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-
-                if isinstance(graph, FundamentalProblemGraph):
-                    return ("ERROR: Graph is already an FPG and cannot be initialized again!")
-                fpg_initial = graph.deepcopy_as(FundamentalProblemGraph)
-
-                fpg_initial.graph['name'] = newGraphName
-                fpg_initial.graph['description'] = 'Fundamental problem graph to solve the "' + graph.graph[
-                    'name'] + '".'
-                fpg_initial.graph['problem_formulation'] = dict()
-                fpg_initial.graph['problem_formulation']['function_order'] = functionOrder
-                fpg_initial.graph['problem_formulation']['mdao_architecture'] = "None"
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = fpg_initial.vistoms_add_json(graph_id=newGraphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                fpg_initial.save(os.path.join(upload_folder, newFileName), file_type="kdms", graph_check_critical=False,
-                                 mpg=mpg)
-
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-
-    @app.route('/kadmos_add_DC_metadata', methods=['POST'])
-    def kadmos_add_DC_metadata():
-        """
-            Function adds metadata to a dc in the graph
-            :param graphID: ID of the current graph
-            :return: VISTOMS json data with graph information
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            function_order = request.form['currentOrder'].split(',')
-            nodeName = request.form['nodeName']
-            metadata_str = request.form['metadata_str']
-
-            # read json data
-            metadata_py = json.loads(metadata_str)
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID)
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return "ERROR: You cannot add metadata to a design competence in an MPG! Please go back to the RCG to do so."
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                graph.add_dc_general_info(nodeName,
-                                          description=metadata_py['description'],
-                                          status=metadata_py['status'],
-                                          owner_uid=metadata_py['owner_uid'],
-                                          creator_uid=metadata_py['creator_uid'],
-                                          operator_uid=metadata_py['operator_uid'])
-
-                ### Functions do not exist yet ###
-                ###################################
-                # graph.add_dc_licensing(nodeName,
-                #                         license_type=metadata_py['license_type'],
-                #                         license_specification=metadata_py['license_specification'],
-                #                         license_info=metadata_py['license_info'])
-                # graph.add_dc_sources(nodeName,
-                #                       repository_link=metadata_py['repository_link'],
-                #                       download_link=metadata_py['download_link'],
-                #                       references=[metadata_py['references']])
-                # graph.add_dc_execution_details(nodeName,
-                #                                 operating_system=metadata_py['operating_system'],
-                #                                 integration_platform=metadata_py['integration_platform'],
-                #                                 command=metadata_py['command'],
-                #                                 description=metadata_py['description_cmd'],
-                #                                 software_requirements=[metadata_py['software_requirements']],
-                #                                 hardware_requirements=metadata_py['hardware_requirements'],)
-                ###################################
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = graph.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-                # Use function order for VISTOMS if it is available in the graph information
-                if graph.graph_has_nested_attributes('problem_formulation', 'function_order') and mpg == None:
-                    graph.graph['problem_formulation']['function_order'] = function_order
-                # Save the graph in temp/tmp.kdms
-                graph.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'), file_type='kdms',
-                           graph_check_critical=False, mpg=mpg)
-
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-
-    @app.route('/kadmos_add_mathematical_function', methods=['POST'])
-    def kadmos_add_mathematical_function():
-        """
-            Function adds a mathematical function to the graph
-            :param graphID: ID of the current graph
-            :return: VISTOMS json data with graph information
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            function_order = []
-            if request.form['currentOrder'] != '':
-                function_order = request.form['currentOrder'].split(',')
-            form_data_str = request.form['form_data']
-
-            # convert stringified data into python objects/arrays/.. with json.loads function
-            form_data_py = json.loads(form_data_str)
-
-            # Get information from form_data_py
-            function_node = form_data_py['function_node']
-            input_nodes_xPath = form_data_py['input_nodes_xPath'].split(',')
-            input_nodes_name = form_data_py['input_nodes_name'].split(',')
-            output_node_xPath = form_data_py['output_node_xPath']
-            equation = form_data_py['equation']
-            language = form_data_py['language']
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes to the graph
-            savePreviousGraph(graphID)
-
-            # Load the current graph from the temporary folder
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return "ERROR: You cannot add a design competence to an MPG! Please go back to the RCG to do so."
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                # Get input_nodes and output_nodes from request form data
-                input_nodes = []
-                for idx, xPath in enumerate(input_nodes_xPath):
-                    input_node = [xPath, input_nodes_name[idx]]
-                    input_nodes.append(input_node)
-                output_nodes = [[output_node_xPath, equation, language]]
-
-                # Add the new mathematical function to the graph as a new competence block
-                graph.add_mathematical_function(input_nodes=input_nodes, function_node=function_node,
-                                                output_nodes=output_nodes)
-
-                # Add the new mathematical function to the function list (function_order)
-                function_order.append(function_node)
-
-                # The graph with the added mathematical function is now saved as json data for vistoms
-                newVistomsData = graph.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-                # Use function order for VISTOMS if it is available in the graph information
-                if graph.graph_has_nested_attributes('problem_formulation', 'function_order') and mpg == None:
-                    graph.graph['problem_formulation']['function_order'] = function_order
-                # Save the graph in temp/tmp.kdms
-                graph.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'), file_type='kdms',
-                           graph_check_critical=False, mpg=mpg)
-
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-
-    @app.route('/kadmos_add_design_competence', methods=['POST'])
-    def kadmos_add_design_competence():
-        """
-            Function adds a dc to the graph
-            :param graphID: ID of the current graph
-            :return: VISTOMS json data with graph information
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            input_file = request.form['input']
-            output_file = request.form['output']
-            cmdows_file = request.form['cmdows']
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID)
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return ("ERROR: You cannot add a design competence to an MPG! Please go back to the RCG to do so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                # Here the dc cmdows file and database is created
-                check_list = ['consistent_root', 'invalid_leaf_elements']
-                graph_dc = load(check_list=check_list)
-
-                # Here the two graphs are merged
-                new_graph = nx.compose(graph, graph_dc)
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = new_graph.vistoms_add_json(graph_id=graphID, mpg=mpg)
-
-                # Save the graph in temp/tmp.kdms
-                new_graph.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'), file_type='kdms',
-                               graph_check_critical=False, mpg=mpg)
-
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-
-    @app.route('/kadmos_change_node_pos', methods=['POST'])
-    def kadmos_change_node_pos():
-        """
-            Function to change the position of a node (competence) within the graph
-
-            :param newPos: Initial fundamental problem graph (FPG) to start working on the MDO problem definition
-            :return: New VISTOMS json data with initial FPG
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            nodeName = str(request.form['nodeName'])
-            function_order = request.form['currentOrder'].split(',')
-            newPos = int(request.form['newPos'])
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return (
-                    "ERROR: You cannot change a competence's position on an existing MPG! Please go back to the FPG or "
-                    "RCG to do so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                # Change position of a node in th XDSM
-
-                # Get tool list and put the coordinator in the top left corner
-                function_order.remove(nodeName)
-                function_order.insert(newPos, nodeName)
-                if isinstance(graph, FundamentalProblemGraph):
-                    graph.graph['problem_formulation']['function_order'] = function_order
-                    if 'problem_role' in graph.nodes[function_order[0]]:
-                        graph.add_function_problem_roles()
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = graph.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                graph.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'), file_type='kdms',
-                           graph_check_critical=False, mpg=mpg)
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_delete_node', methods=['POST'])
-    def kadmos_delete_node():
-        """
-            Function deletes a node from the graph and returns the updated graph data to VISTOMS
-            :param nodeName: name of the node to be deleted
-            :return: VISTOMS json data with graph information
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            nodeName = str(request.form['nodeName'])
-            function_order = request.form['currentOrder'].split(',')
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return (
-                    "ERROR: You cannot remove a competence from an existing MPG! Please go back to the FPG or RCG to "
-                    "do so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                # remove the node from the graph
-                graph.remove_function_nodes(nodeName)
-                # update function order
-                function_order.remove(nodeName)
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = graph.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                graph.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'), file_type='kdms',
-                           graph_check_critical=False, mpg=mpg)
-
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_delete_edge', methods=['POST'])
-    def kadmos_delete_edge():
-        """
-            Function deletes an edge from the graph and returns the updated graph data to VISTOMS
-            :param nodeName: name of the node that is the input provider of the edge
-            :param edgeName: name of the edge to be deleted
-            :return: VISTOMS json data with graph information
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            nodeName = str(request.form['nodeName'])
-            edgeName = str(request.form['edgeName'])
-            function_order = request.form['currentOrder'].split(',')
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = load(os.path.join(path, mpgFileName), file_check_critical=False)
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-            # remove the edge
-            graph.remove_edge(nodeName, edgeName)
-            # Add the graph with the updated function order to VISTOMS
-            newVistomsData = graph.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-            # Save the graph in temp/tmp.kdms
-            graph.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'), file_type='kdms',
-                       graph_check_critical=False, mpg=mpg)
-
-            return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_exclude_DCs', methods=['POST'])
-    def kadmos_exclude_DCs():
-        """
-            Function to exclude design competences as requested by the user from VISTOMS
-
-            :param nodeList: List of competences that shall be excluded
-            :return: New VISTOMS json data with excluded design competences deleted
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            nodeList = request.form['nodeList'].split(',')
-            function_order = request.form['currentOrder'].split(',')
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return (
-                    "ERROR: You cannot remove a competence from an existing MPG! Please go back to the FPG or RCG to "
-                    "do so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                fpg = FundamentalProblemGraph(graph)
-
-                # Remove a node from the graph
-                for nodeName in nodeList:
-                    fpg.remove_function_nodes(nodeName)
-                    function_order.remove(nodeName)
-                # Assign new function order to problem formulation
-                fpg.graph['problem_formulation']['function_order'] = function_order
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = fpg.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                fpg.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'),
-                         file_type='kdms', graph_check_critical=False, mpg=mpg)
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_merge_seq_DCs', methods=['POST'])
-    def kadmos_merge_seq_DCs():
-        """
-            Function to merge design competences that run sequentially as requested by the user from VISTOMS
-
-            :param nodeList: List of competences that shall be merged
-            :return: New VISTOMS json data with merged design competences
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            function_order = request.form['currentOrder'].split(',')
-            nodeList = request.form['nodeList'].split(',')
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return (
-                    "ERROR: You cannot merge comeptences on an existing MPG! Please go back to the FPG or RCG to do "
-                    "so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                new_node = '-'.join(nodeList) + '--seq'
-
-                if isinstance(graph, FundamentalProblemGraph):
-                    fpg = graph
-                else:
-                    fpg = FundamentalProblemGraph(graph)
-
-                fpg = fpg.merge_sequential_functions(nodeList, new_label=new_node)
-                # adjust function order
-                function_order = [new_node if func == nodeList[0] else func for func in function_order]
-                for func in nodeList[1:]:
-                    function_order.remove(func)
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = fpg.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                fpg.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'),
-                         file_type='kdms', graph_check_critical=False, mpg=mpg)
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_merge_parallel_DCs', methods=['POST'])
-    def kadmos_merge_parallel_DCs():
-        """
-            Function to merge design competences that run in parallel as requested by the user from VISTOMS
-
-            :param nodeList: List of competences that shall be merged
-            :return: New VISTOMS json data with merged design competences
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            function_order = request.form['currentOrder'].split(',')
-            nodeList = request.form['nodeList'].split(',')
-
-            # Load upload_folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return (
-                    "ERROR: You cannot merge comeptences on an existing MPG! Please go back to the FPG or RCG to do "
-                    "so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                new_node = '-'.join(nodeList) + '--par'
-
-                if isinstance(graph, FundamentalProblemGraph):
-                    fpg = graph
-                else:
-                    fpg = FundamentalProblemGraph(graph)
-
-                fpg = fpg.merge_parallel_functions(nodeList, new_label=new_node)
-                # adjust function order
-                function_order = [new_node if func == nodeList[0] else func for func in function_order]
-                for func in nodeList[1:]:
-                    function_order.remove(func)
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = fpg.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                fpg.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'),
-                         file_type='kdms', graph_check_critical=False, mpg=mpg)
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_merge_func_mod_DCs', methods=['POST'])
-    def kadmos_merge_func_mod_DCs():
-        """
-            Function to merge design competences that run in different modes as requested by the user from VISTOMS
-
-            :param nodeList: List of competences that shall be merged
-            :return: New VISTOMS json data with merged design competences
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            function_order = request.form['currentOrder'].split(',')
-            nodeList = request.form['nodeList'].split(',')
-
-            # Load upload folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return (
-                    "ERROR: You cannot merge comeptences on an existing MPG! Please go back to the FPG or RCG to do "
-                    "so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                if isinstance(graph, FundamentalProblemGraph):
-                    fpg = graph
-                else:
-                    fpg = FundamentalProblemGraph(graph)
-
-                base_function = fpg.node[nodeList[0]]['name']
-                modes = [str(string[string.find('[') + 1:string.find(']')]) for string in nodeList]
-                suffices = [str(string[string.find('_'):string.find('[')]) for string in nodeList]
-                new_node = base_function + '-merged[' + str(len(nodeList)) + 'modes]'
-
-                fpg = fpg.merge_function_modes(base_function, modes, new_label=new_node, version='1.0', instance=1,
-                                               suffices=suffices)
-                # adjust function order
-                function_order = [new_node if func == nodeList[0] else func for func in function_order]
-                for func in nodeList[1:]:
-                    function_order.remove(func)
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = fpg.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                fpg.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'),
-                         file_type='kdms', graph_check_critical=False, mpg=mpg)
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_remove_collision', methods=['POST'])
-    def kadmos_remove_collision():
-        """
-            Function to remove collisions coming from specific design competences as requested by the user from VISTOMS
-
-            :param nodeList: List of competences for which collisions should be removed
-            :return: New VISTOMS json data with updated design competences
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            nodeList = request.form['nodeList'].split(',')
-            function_order = request.form['currentorder'].split(',')
-
-            # Load upload folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return (
-                    "ERROR: You cannot merge comeptences on an existing MPG! Please go back to the FPG or RCG to do "
-                    "so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                if isinstance(graph, FundamentalProblemGraph):
-                    fpg = graph
-                else:
-                    fpg = FundamentalProblemGraph(graph)
-
-                for collision_source in nodeList:
-                    fpg.disconnect_problematic_variables_from(collision_source)
-
-                    fpg.graph['problem_formulation']['function_order'] = function_order
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = fpg.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                fpg.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'),
-                         file_type='kdms', graph_check_critical=False, mpg=mpg)
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_get_possible_function_order', methods=['POST'])
-    def kadmos_get_possible_function_order():
-        """
-            Function to get a possible function order
-
-            :param method: The method for sorting the nodes. Specified by the user from VISTOMS
-            :return: New VISTOMS json data with updated design competences
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            method = request.form['sortingMethod']
-
-            # Load upload folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return (
-                    "ERROR: You cannot merge comeptences on an existing MPG! Please go back to the FPG or RCG to do "
-                    "so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                if isinstance(graph, FundamentalProblemGraph):
-                    fpg = graph
-                else:
-                    fpg = FundamentalProblemGraph(graph)
-
-                # Getting the possible function order with the method specified by the user
-                function_order = fpg.get_possible_function_order(method)
-                fpg.assert_or_add_nested_attribute(['problem_formulation', 'mdao_architecture'], 'undefined')
-                fpg.graph['problem_formulation']['function_order'] = function_order
-                if 'problem_role' in fpg.nodes[function_order[0]]:
-                    fpg.add_function_problem_roles()
-
-                # Save the graph in temp/tmp.kdms
-                fpg.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'),
-                         file_type='kdms', graph_check_critical=False, mpg=mpg)
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = fpg.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_make_all_variables_valid', methods=['POST'])
-    def kadmos_make_all_variables_valid():
-        """
-            Function to make all variables from the graph valid --> Eliminates colissions
-
-            :return: New VISTOMS json data with updated design competences
-        """
-        try:
-            # get request form
-            graphID = request.form['graphID']
-            function_order = request.form['currentOrder'].split(',')
-
-            # Load upload folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return ("ERROR: You cannot do that on an existing MPG! Please go back to the FPG or RCG to do so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                if isinstance(graph, FundamentalProblemGraph):
-                    fpg = graph
-                else:
-                    fpg = FundamentalProblemGraph(graph)
-
-                fpg.graph['problem_formulation']['function_order'] = function_order
-
-                # Function to check the graph for collisions and holes. Collisions are solved based on the function order
-                # and holes will simply be removed.
-                fpg.make_all_variables_valid()
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = fpg.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                fpg.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'),
-                         file_type='kdms', graph_check_critical=False, mpg=mpg)
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_add_function_problem_roles', methods=['POST'])
-    def kadmos_add_function_problem_roles():
-        """
-            Function to Add the problem function roles to the graph
-
-            :return: New VISTOMS json data with updated design competences
-        """
-        try:
-            # get request form
-            graphID = request.form['graphID']
-            function_order = request.form['currentOrder'].split(',')
-
-            # Load upload folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return ("ERROR: You cannot do that on an existing MPG! Please go back to the FPG or RCG to do so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                if isinstance(graph, FundamentalProblemGraph):
-                    fpg = graph
-                else:
-                    fpg = FundamentalProblemGraph(graph)
-
-                fpg.graph['problem_formulation']['function_order'] = function_order
-
-                # Add the function problem roles (pre-coupling, coupled, post-coupling)
-                fpg.add_function_problem_roles()
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = fpg.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                fpg.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'),
-                         file_type='kdms', graph_check_critical=False, mpg=mpg)
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_mark_variable', methods=['POST'])
-    def kadmos_mark_variable():
-        """
-            Function to mark a variable as "special variable" (constraint, objective, design variable, quantity of interest)
-            :param xPath: xPath of the variable in the XML schema
-            :param variableType: type of the variable it shall be marked as (constraint, objective, design variable,
-                quantity of interest)
-            :return: VISTOMS json data with graph information
-        """
-        try:
-            # get request form
-            graphID = request.form['graphID']
-            function_order = request.form['currentOrder'].split(',')
-            variableType = request.form['variableType']
-            xPath = request.form['xPath']
-            operator = request.form['operator']
-            upperBound = float(request.form['upperBound'])
-            lowerBound = float(request.form['lowerBound'])
-            nominalValue = float(request.form['nominalValue'])
-
-            # Load upload folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return ('ERROR: This function can only be performed on an FPG!')
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-            if isinstance(graph, FundamentalProblemGraph):
-                fpg = graph
-            else:
-                fpg = FundamentalProblemGraph(graph)
-
-            if (variableType == 'designVariable'):
-                fpg.mark_as_design_variable(xPath, nominal_value=nominalValue, upper_bound=upperBound,
-                                            lower_bound=lowerBound)
-            elif (variableType == 'objective'):
-                fpg.mark_as_objective(xPath)
-            elif (variableType == 'constraint'):
-                fpg.mark_as_constraint(xPath, reference_value=nominalValue, operator=operator)
-            elif (variableType == 'quantityOfInterest'):
-                fpg.mark_as_qois([xPath])
-            else:
-                return ("ERROR: Something went wrong in KADMOS!")
-
-            # Add the graph with the updated function order to VISTOMS
-            newVistomsData = fpg.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-            # Save the graph in temp/tmp.kdms
-            fpg.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'), file_type='kdms',
-                     graph_check_critical=False, mpg=mpg)
-
-            return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_unmark_variable', methods=['POST'])
-    def kadmos_unmark_variable():
-        """
-            Function to unmark a previously marked variable
-            :param xPath: xPath of the variable in the XML schema
-            :return: VISTOMS json data with graph information
-        """
-        try:
-            # get request form
-            graphID = request.form['graphID']
-            function_order = request.form['currentOrder'].split(',')
-            xPath = request.form['xPath']
-
-            # Load upload folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return ('ERROR: This function can only be performed on an FPG!')
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-            if isinstance(graph, FundamentalProblemGraph):
-                fpg = graph
-            else:
-                fpg = FundamentalProblemGraph(graph)
-
-            fpg.unmark_variable(xPath)
-
-            # Add the graph with the updated function order to VISTOMS
-            newVistomsData = fpg.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-            # Save the graph in temp/tmp.kdms
-            fpg.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'), file_type='kdms',
-                     graph_check_critical=False, mpg=mpg)
-
-            return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_remove_unused_outputs', methods=['POST'])
-    def kadmos_remove_unused_outputs():
-        """
-            Function to remove all unused variables that are output to the coordinator
-
-            :return: New VISTOMS json data with updated design competences
-        """
-        try:
-            # get request form
-            graphID = request.form['graphID']
-            function_order = request.form['currentOrder'].split(',')
-            cleanUp_str = request.form['cleanUp']
-            if cleanUp_str == 'True':
-                cleanUp = True
-            else:
-                cleanUp = False
-
-            # Load upload folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return ("ERROR: You cannot do that on an existing MPG! Please go back to the FPG or RCG to do so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                if isinstance(graph, FundamentalProblemGraph):
-                    fpg = graph
-                else:
-                    fpg = FundamentalProblemGraph(graph)
-
-                fpg.graph['problem_formulation']['function_order'] = function_order
-
-                # Cleaning of the graph needs to be done in a while loop, to entirely remove all unused elements
-                another_run = True
-                while another_run:
-                    another_run = False
-                    # Delete unused variables
-                    output_nodes = fpg.find_all_nodes(subcategory='all outputs')
-                    for output_node in output_nodes:
-                        if 'problem_role' not in fpg.node[output_node]:
-                            fpg.remove_node(output_node)
-                            another_run = True
-                    # Delete unnecessary functions automatically if the user wants to
-                    if cleanUp:
-                        function_nodes = fpg.find_all_nodes(category='function')
-                        for function_node in function_nodes:
-                            if not fpg.out_edges(function_node):
-                                fpg.remove_function_nodes(function_node)
-                                function_order.remove(function_node)
-                                another_run = True
-
-                # Add the function problem roles (pre-coupling, coupled, post-coupling)
-                fpg.add_function_problem_roles()
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = fpg.vistoms_add_json(function_order=function_order, graph_id=graphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                fpg.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'),
-                         file_type='kdms', graph_check_critical=False, mpg=mpg)
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    ########################################################################################################################
-
-    # MDPG manipulation functions
-    ########################################################################################################################
-    @app.route('/kadmos_start_defining_MDAO_architecture', methods=['POST'])
-    def kadmos_start_defining_MDAO_architecture():
-        """
-            Function to start an MDO problem definition
-
-            :param graph: Initial fundamental problem graph (FPG) to start working on the MDAO architecture definition
-            :return: New VISTOMS json data with initial FPG
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            functionOrder = request.form['currentOrder'].split(',')
-            newGraphID = request.form['newGraphID']
-            newGraphName = request.form['newGraphName']
-
-            # Load upload folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            newFileName = TEMP_FILE + '_' + newGraphID + '.kdms'
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return ("ERROR: Graph is already an MDPG! FPG Cannot be initialized again!")
-            else:
-                mpg = None
-
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-
-                if not isinstance(graph, FundamentalProblemGraph):
-                    return ("ERROR: Graph is not an FPG yet. Please perform the FPG Manipulation steps first!")
-
-                # check if fpg is well defined
-                check_result = graph._check_category_a()
-                if check_result[0] != True:
-                    return (
-                        "ERROR: The FPG is not well defined yet. Please perform FPG manipulation steps first and check "
-                        "the graph again!")
-
-                mdg = deepcopy(graph)
-                mdg.graph['name'] = newGraphName
-                mdg.graph['description'] = 'MDAO data and process graph to solve the "' + graph.graph['name'] + '".'
-                mdg.graph['problem_formulation'] = dict()
-                mdg.graph['problem_formulation']['function_order'] = functionOrder
-                mdg.graph['problem_formulation']['mdao_architecture'] = "None"
-
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = mdg.vistoms_add_json(function_order=functionOrder, graph_id=newGraphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                mdg.save(os.path.join(upload_folder, newFileName), file_type="kdms", graph_check_critical=False,
-                         mpg=mpg)
-
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    @app.route('/kadmos_impose_MDAO_architecture', methods=['POST'])
-    def kadmos_impose_MDAO_architecture():
-        """
-            Function to wrap an MDAO architecture around the MDAO problem
-
-            :param allowUnconvergedCouplings: Bool variable whether unconverged couplings are allowed or not
-            :return: New VISTOMS json data with updated MDAO data and process graphs
-        """
-        try:
-            # Get request form
-            graphID = request.form['graphID']
-            function_order = request.form['currentOrder'].split(',')
-            mdao_architecture = request.form['mdao_architecture']
-            doe_method = request.form['doe_method']
-            coupling_decomposition = request.form['coupling_decomposition']
-            allow_unconverged_couplings_str = request.form['allow_unconverged_couplings']
-            if allow_unconverged_couplings_str == 'True':
-                allow_unconverged_couplings = True
-            else:
-                allow_unconverged_couplings = False
-
-            # Load upload folder based on session
-            sessionID = request.form['sessionID']
-            upload_folder = UPLOAD_FOLDERS[sessionID]
-
-            # Save previous graph as backup before making the changes
-            savePreviousGraph(graphID, upload_folder)
-
-            path = upload_folder
-            graphFileName = TEMP_FILE + '_' + graphID + '.kdms'
-            mpgFileName = TEMP_FILE + '_' + graphID + '_mpg.kdms'
-            if os.path.exists(os.path.join(path, mpgFileName)):
-                return ("ERROR: You cannot perform this on an existing MPG! Please go back to the FPG to do so.")
-            else:
-                graph = load(os.path.join(path, graphFileName), file_check_critical=False)
-                mpg = None
-
-                mdao_definition = mdao_architecture
-                if coupling_decomposition == 'Gauss-Seidel':
-                    mdao_definition += '-GS'
-                elif coupling_decomposition == 'Jacobi':
-                    mdao_definition += '-J'
-                elif coupling_decomposition == '-':
-                    coupling_decomposition = None
-
-                if not isinstance(graph, FundamentalProblemGraph):
-                    return "ERROR: Your graph is not an FPG yet. Please perform FPG manipulation steps before imposing an" \
-                           " MDAO architecture!"
-
-                fpg = graph
-
-                mdao_definition = mdao_architecture
-                if coupling_decomposition == 'Gauss-Seidel':
-                    mdao_definition += '-GS'
-                elif coupling_decomposition == 'Jacobi':
-                    mdao_definition += '-J'
-                elif coupling_decomposition == '-':
-                    coupling_decomposition = None
-
-                # Define settings of the problem formulation
-                fpg.graph['problem_formulation'] = dict()
-                fpg.graph['problem_formulation']['function_order'] = function_order
-                fpg.graph['problem_formulation']['mdao_architecture'] = mdao_architecture
-                fpg.graph['problem_formulation']['convergence_type'] = coupling_decomposition
-                fpg.graph['problem_formulation']['allow_unconverged_couplings'] = allow_unconverged_couplings
-
-                if mdao_architecture in ['converged-DOE', 'unconverged-DOE']:
-                    if doe_method not in fpg.OPTIONS_DOE_METHODS:
-                        return "ERROR: Invalid DOE method selected, please select a DOE method from the dropdown list"
-
-                    fpg.graph['problem_formulation']['doe_settings'] = {'doe_method': doe_method}
-                    if fpg.graph['problem_formulation']['doe_settings']['doe_method'] in ['Latin hypercube design',
-                                                                                          'Monte Carlo design']:
-                        fpg.graph['problem_formulation']['doe_settings']['doe_seed'] = 6
-                        fpg.graph['problem_formulation']['doe_settings']['doe_runs'] = 5
-                    elif fpg.graph['problem_formulation']['doe_settings']['doe_method'] in ['Full factorial design']:
-                        fpg.graph['problem_formulation']['doe_settings']['doe_runs'] = 5
-
-                fpg.add_function_problem_roles()
-
-                mdg, mpg = fpg.impose_mdao_architecture()
-
-                mpg.graph['name'] = 'XDSM - {}'.format(mdao_definition)
-                mpg.graph['description'] = 'Solution strategy to solve the super-sonic business jet test case ' \
-                                           'optimization problem using the strategy: {}.'.format(mdao_definition)
-                # Add the graph with the updated function order to VISTOMS
-                newVistomsData = mdg.vistoms_add_json(graph_id=graphID, mpg=mpg)
-                # Save the graph in temp/tmp.kdms
-                mdg.save(os.path.join(upload_folder, TEMP_FILE + '_' + graphID + '.kdms'),
-                         file_type='kdms', graph_check_critical=False, mpg=mpg)
-                return newVistomsData
-
-        except Exception as e:
-            return "ERROR: " + e.message
-            # Logs the error appropriately.
-
-    ########################################################################################################################
-
-    # Return the interface
-    return app
diff --git a/kadmos/vistoms/templates/VISTOMS_sessions.html b/kadmos/vistoms/templates/VISTOMS_sessions.html
deleted file mode 100644
index c2b4f9885..000000000
--- a/kadmos/vistoms/templates/VISTOMS_sessions.html
+++ /dev/null
@@ -1,28573 +0,0 @@
-<!DOCTYPE html>
-<meta charset="utf-8">
-<meta name="viewport" content="width=device-width, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no">
-<meta name="format-detection" content="telephone=no">
-<meta name="apple-mobile-web-app-capable" content="yes">
-<meta name="apple-mobile-web-app-status-bar-style" content="default">
-<head">
-    <meta charset="utf-8">
-    <title>VISTOMS (Visualization Tool for MDO Systems)</title>
-    <!--Include this css file in the <head> tag -->
-    <link rel="stylesheet" href="static/lib/jquery/jquery-ui.min.css"/>
-    <link rel="stylesheet" href="static/lib/bootstrap/bootstrap.min.css"/>
-    <link rel="stylesheet" href="static/lib/lobipanel/github.css"/>
-    <link rel="stylesheet" href="static/lib/lobipanel/lobipanel.min.css"/>
-    <link rel="stylesheet" href="static/lib/vistoms.css"/>
-</head>
-<body>
-    <!--Include these script files in the <head> or <body> tag-->
-    <script src="static/lib/jquery/jquery.3.20.min.js"></script>
-    <script src="static/lib/jquery/jquery-ui.min.js"></script>
-    <script src="static/lib/jquery/jquery.ui.touch-punch.min.js"></script>
-    <script src="static/lib/bootstrap/bootstrap.min.js"></script>
-    <script src="static/lib/bootstrap/bootbox.min.js"></script>
-    <script src="static/lib/lobipanel/highlight.pack.js"></script>
-    <script src="static/lib/lobipanel/lobipanel.js"></script>
-    <script src="static/lib/vkbeautify/vkbeautify.js"></script>
-    <script src="static/lib/bowser/bowser.js"></script>
-    <script>           
-			var sessionID = {{ sessionID|tojson }};
-            if (bowser.name=="Internet Explorer")
-			{
-                alert("OOPS! VISTOMS unfortunately does not work properly on " + bowser.name + ". Please use a different browser to see its awesome visualization features!")
-			}
-
-			/* see docs: https://developer.mozilla.org/en-US/docs/Web/API/Window/localStorage */
-			if (window && window.localStorage)
-			{
-				var storage = window.localStorage;
-				var existingSessionId = storage.getItem('sessionId');
-				if (existingSessionId)
-				{
-					sessionID = existingSessionId;
-				}
-				else {
-					storage.setItem('sessionId', sessionID);
-				}
-			}
-
-
-            
-            //aigner: Include function
-			function include(arr,obj) {
-					return (arr.indexOf(obj) != -1);
-			}
-            
-            //aigner: Move to front function
-			d3.selection.prototype.moveToFront = function() {  
-			  return this.each(function(){
-				this.parentNode.appendChild(this);
-			  });
-			};
-			//aigner: Move to back function
-			d3.selection.prototype.moveToBack = function() {  
-				return this.each(function() { 
-					var firstChild = this.parentNode.firstChild; 
-					if (firstChild) { 
-						this.parentNode.insertBefore(this, firstChild); 
-					} 
-				});
-			};
-            
-            /**
-             * Returns a random integer between min (inclusive) and max (inclusive)
-             * Using Math.round() will give you a non-uniform distribution!
-             */
-            function getRandomInt(min, max) {
-                return Math.floor(Math.random() * (max - min + 1)) + min;
-            }
-
-            
-            //aigner: General functions communicating with the user via bootbox after kadmos requests
-            //##############################################################
-            function kadmosErrorMessage(content)
-            {
-                var message="";
-                if (content.message.responseText){message = content.message.responseText}
-                else if (content.message == ""){message = "ERROR: Something went wrong in KADMOS!"}
-                else {message = content.message}
-                bootbox.hideAll();
-                bootbox.dialog({
-                title: content.title,
-                message: message,
-                buttons : { cancel:
-                            {
-                                label: "OK",
-                                className: 'btn-default',
-                                callback: function(){}
-                            }
-                          }
-                });
-            }
-            
-            function kadmosSuccessMessage(content)
-            {
-                bootbox.hideAll();
-                bootbox.dialog(
-                {
-                    title: content.title,
-                    message: content.message,
-                    buttons : { cancel:
-                                {
-                                    label: "OK",
-                                    callback: function(){}
-                                }
-                              }
-                });
-            }
-            
-            function kadmosHavePatience(anXhr, content)
-            {
-                bootbox.hideAll();
-                bootbox.dialog({
-                    title: content.title,
-                    message: content.message,
-                    buttons : { cancel:
-                            {
-                                label: "Cancel request",
-                                className: 'btn-danger',
-                                callback: function () {
-                                    anXhr.abort()
-                                    bootbox.hideAll();
-                                    bootbox.dialog(
-                                    {
-                                        title: content.title,
-                                        message: "<b>KADMOS request aborted!</b> <p>CAUTION: Python functions could still be running in the background!</p>",
-                                        buttons : { cancel:
-                                                    {
-                                                        label: "OK",
-                                                        className: 'btn-danger',
-                                                        callback: function(){}
-                                                    }
-                                                  }
-                                    });
-                                }
-                            }
-                        }
-                });
-            }
-            //##############################################################
-             
-            //aigner: Function to filter a list with a search
-            //##############################################################
-            function filterSearch() 
-            {
-                var input, filter, table, tr, td, i;
-                input = document.getElementById("myInput");
-                filter = input.value.toUpperCase();
-                table = document.getElementById("myTable");
-                tr = table.getElementsByTagName("tr");
-                for (i = 0; i < tr.length; i++) 
-                {
-                    td = tr[i].getElementsByTagName("td")[0];
-                    if (td) 
-                    {
-                            if (td.innerHTML.toUpperCase().indexOf(filter) > -1) 
-                            {
-                                tr[i].style.display = "";
-                            } 
-                            else 
-                            {
-                                tr[i].style.display = "none";
-                            }
-                    }          
-                }
-            }
-            //##############################################################
-            
-            //aigner: General functions for tree layout
-            //##############################################################
-            //Function to prune the tree according to list of xPaths that are actually there
-            function prune_tree(aPipeData,aTreeData,direction="none")
-            {
-                //First, clean up pipeData if necessary
-                var cleanPipeData = aPipeData.split(",")
-                var index = cleanPipeData.indexOf("");
-                if (index > -1) {cleanPipeData.splice(index, 1);}
-                var firstEl = cleanPipeData[0].split("/")[1]                             
-                
-                for (var i=0; i < aTreeData.length; ++i) 
-                {
-                    var treeElement = aTreeData[i];
-                    var relevant_xPath = "/"+firstEl+"/"+treeElement.xPath.split("/"+firstEl+"/")[1]
-                    if(cleanPipeData.indexOf(relevant_xPath)<=-1)
-                    {
-                        aTreeData.splice(i,1);
-                        i--;
-                    }
-                    else
-                    {
-                        if (direction=="in")
-                        {
-                            aTreeData[i].pipeLineIn = true;
-                        }
-                        else if (direction=="out")
-                        {
-                            aTreeData[i].pipeLineOut = true;
-                        }
-                    }
-                }
-            }
-            
-            function childExists(name, children)
-            {
-                var exists = false
-                children.forEach(function(child)
-                {
-                    if (child.name == name)
-                    {
-                        exists = true;
-                    }
-                })
-                return exists;
-            }
-            
-            //Function to create the tree layout by appending children to the layout
-            function appendChildren(anElement, aParent, xPath_list)
-            {
-                if (xPath_list.length > 0)
-                {
-                    //If element has no children yet, initialize children array
-                    if (!aParent.children){aParent.children = [];}
-                    //Create a new child element, if it does not exist yet
-                    if (!childExists(xPath_list[0], aParent.children))
-                    {
-                        //Create a new child object
-                        var newChild = {level: aParent.level+1, name: xPath_list[0], type: "variable", xPath: aParent.xPath+"/"+xPath_list[0]};
-                        if (anElement.pipeLineIn){newChild.pipeLineIn=true}
-                        if (anElement.pipeLineOut){newChild.pipeLineOut=true}
-                        aParent.children.push(newChild);
-                    }
-                    aParent.children.forEach(function(aChild)
-                    {
-                        if (xPath_list[0] == aChild.name)
-                        {
-                            let newXPath_list = JSON.parse(JSON.stringify(xPath_list));
-                            newXPath_list.shift();
-                            appendChildren(anElement, aChild, newXPath_list)
-                        }
-                    })
-                }
-                else
-                {
-                    aParent.value = anElement.value;
-                }
-            }
-            
-            //function builds tree layout from xPaths of the elements
-            function buildTree(root, aTreeData)
-            {
-                aTreeData.forEach(function(treeElement)
-                {
-                    var xPath_split = treeElement.xPath.split("/");
-                    var index = xPath_split.indexOf("");
-                    if (index > -1) {xPath_split.splice(index, 1);}
-                    root.level = 0
-                    root.name = xPath_split[0]
-                    root.xPath = "/"+xPath_split[0]
-                    <!-- console.log("####################") -->
-                    <!-- console.log(treeElement.xPath) -->
-                    let newXPath_split = JSON.parse(JSON.stringify(xPath_split));
-                    newXPath_split.shift();
-                    appendChildren(treeElement, root, newXPath_split)
-                    <!-- console.log("DONE!") -->
-                    <!-- console.log("####################") -->
-                })
-            }
-            //##############################################################
-             
-             
-             
-            function createNewGraph(theData, theCurrentGraph=null)
-            {               
-                bootbox.hideAll();
-                
-                var html = d3.select("html")
-                var form_content = html.append("div").attr("class","form-content").attr("style","display:none")
-                var form = form_content.append("form").attr("class","form").attr("role","form")
-                var form_group, input;
-                    
-                //Tool information
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Name")
-                input = form_group.append("input")
-                    .attr("id","graph_name")
-                    .attr("class","form-control")
-                    .attr("name","graph_name")
-                    .attr("placeholder","Add a graph name here...")
-                //Tool information
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Description")
-                input = form_group.append("input")
-                    .attr("id","graph_description")
-                    .attr("class","form-control")
-                    .attr("name","graph_description")
-                    .attr("placeholder","Add a graph description here...")
-                
-                var modal = bootbox.dialog({
-                    message: $(".form-content").html(),
-                    title: "Create new graph",
-                    size: "large",
-                    buttons: [
-                      {
-                        label: "Cancel",
-                        className: "btn btn-default pull-left",
-                        callback: function() {
-                          modal.modal("hide");
-                          d3.selectAll(".form-content").remove();
-                        }
-                      },
-                      {
-                        label: "OK",
-                        className: "btn btn-primary pull-left",
-                        callback: function() {
-                            
-                            //get form data
-                            var graph_name = $('form #graph_name').val();
-                            var graph_description = $('form #graph_description').val();
-                            
-                            
-                            var bootboxContent = {title: "Create new graph", message: '<p>Please be patient...</p>'};
-                            var xhr = $.ajax({
-                                type: 'POST',
-                                url: '/kadmos_create_new_graph',
-                                data: {'graph_name':graph_name, 'graph_description':graph_description, 'sessionID':sessionID},
-                                success: function(result)
-                                {
-                                    if (result.includes("ERROR:"))
-                                    {
-                                        bootboxContent.message = result
-                                        kadmosErrorMessage(bootboxContent);
-                                    }
-                                    else
-                                    {
-                                        var updatedData = {};
-                                        if (theData != "REP__GRAPH_DATA__REP")
-                                        {
-                                            updatedData = theData;
-                                            var graphData = JSON.parse(result);                                        
-                                            updatedData.graphs.push(graphData.graphs[0]);                                        
-                                        }
-                                        else
-                                        {
-                                            updatedData = JSON.parse(result);
-                                        }
-                                        
-                                        clearView();
-                                        makeKadmosMenu(updatedData);
-                                        mainPage();
-                                        
-                                        bootboxContent.message = "Success!"
-                                        kadmosSuccessMessage(bootboxContent)
-                                    }
-                                },
-                                error: function(result)
-                                {
-                                    bootboxContent.message = result
-                                    kadmosErrorMessage(bootboxContent);
-                                }
-                            });
-                            kadmosHavePatience(xhr, bootboxContent)
-                            modal.modal("hide");
-                            d3.selectAll(".form-content").remove();
-                        }
-                      }
-                    ],
-                    onEscape: function() {
-                      modal.modal("hide");
-                      d3.selectAll(".form-content").remove();
-                    }
-                });
-                    
-            }
-            
-             
-            //aigner: HIER WEITER!!!
-            function addDesignCompetence(theData, theCurrentGraph=null)
-            {               
-                console.log(data)
-                bootbox.hideAll();
-                
-                var html = d3.select("html")
-                var form_content = html.append("div").attr("class","form-content").attr("style","display:none")
-                var form = form_content.append("form").attr("class","form").attr("role","form")
-                var form_group, input;
-                    
-                //Tool information
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Name")
-                input = form_group.append("input")
-                    .attr("id","function_node")
-                    .attr("class","form-control")
-                    .attr("name","function_node")
-                    .attr("placeholder","Add a tool name here...")
-                //Tool input xml
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Tool input XML")
-                input = form_group.append("input")
-                    .attr("type","file")
-                    .attr("id","input_xml")
-                    .attr("name","input_xml")
-                //Tool output xml
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Tool output XML")
-                input = form_group.append("input")
-                    .attr("type","file")
-                    .attr("id","output_xml")
-                    .attr("name","output_xml")
-                    
-                
-                var modal = bootbox.dialog({
-                    message: $(".form-content").html(),
-                    title: "Add design competence",
-                    size: "large",
-                    buttons: [
-                      {
-                        label: "Cancel",
-                        className: "btn btn-default pull-left",
-                        callback: function() {
-                          modal.modal("hide");
-                          d3.selectAll(".form-content").remove();
-                        }
-                      },
-                      {
-                        label: "OK",
-                        className: "btn btn-primary pull-left",
-                        callback: function() {
-                            
-                            //get form data
-                            var form_data = {
-                                function_node: $('form #function_node').val(),
-                                input_nodes_xPath: $('form #input_nodes_xPath').val(),
-                                input_nodes_name: $('form #input_nodes_name').val(),
-                                output_node_xPath: $('form #output_node_xPath').val(),
-                                equation: $('form #equation').val(),
-                                language: $('form #language').val()
-                            }
-                            
-                            
-                            var bootboxContent = {title: "Add design competence", message: '<p>Please be patient...</p>'};
-                            var xhr = $.ajax({
-                                type: 'POST',
-                                url: '/kadmos_add_design_competence',
-                                data: {'graphID':graphID, 'currentOrder':nodeOrder, 'form_data':JSON.stringify(form_data), 'sessionID':sessionID},
-                                success: function(result)
-                                {
-                                    if (result.includes("ERROR:"))
-                                    {
-                                        bootboxContent.message = result
-                                        kadmosErrorMessage(bootboxContent);
-                                    }
-                                    else
-                                    {
-                                        var updatedData = {};
-                                        updatedData = theData;
-                                        var graphData = JSON.parse(result);             
-                                        for (var i = 0; i < updatedData.graphs.length; i++)
-                                        {
-                                            if (graphID == updatedData.graphs[i].id)
-                                            {
-                                                updatedData.graphs[i] = graphData.graphs[0];   
-                                            }
-                                        }
-                                        
-                                        clearView();
-                                        makeKadmosMenu(updatedData);
-                                        xdsm_script(updatedData,graphID);
-                                        
-                                        bootboxContent.message = "Success!"
-                                        kadmosSuccessMessage(bootboxContent)
-                                    }
-                                },
-                                error: function(result)
-                                {
-                                    bootboxContent.message = result
-                                    kadmosErrorMessage(bootboxContent);
-                                }
-                            });
-                            kadmosHavePatience(xhr, bootboxContent)
-                            kadmosHavePatience(xhr, bootboxContent)
-                            modal.modal("hide");
-                            d3.selectAll(".form-content").remove();
-                            
-                            //aigner: After the competence has been added, add metadata for the competence
-                            addDCMetadata(data,theCurrentGraph)
-                        }
-                      }
-                    ],
-                    onEscape: function() {
-                      modal.modal("hide");
-                      d3.selectAll(".form-content").remove();
-                    }
-                });
-                    
-            }
-            
-            //aigner: HIER WEITER!!! --> Add contacts if not already existing
-            function addDCMetadata(theData, theCurrentGraph, aNode=null)
-            {               
-                bootbox.hideAll();
-                
-                var metadata;
-                if (aNode != null)
-                {
-                    metadata = aNode.metadata;
-                }
-                                    
-                var html = d3.select("html")
-                var form_content = html.append("div").attr("class","form-content").attr("style","display:none")
-                var form = form_content.append("form").attr("class","form").attr("role","form")
-                var form_group, input;
-                    
-                //General information
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("label").text("General information")
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Description")
-                input = form_group.append("textarea")
-                    .attr("id","description")
-                    .attr("class","form-control")
-                    .attr("name","description")
-                    .attr("placeholder","Add a description for the DC here")
-                
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Status")
-                input = form_group.append("select").attr("id","status").style("margin-left","5px")
-                input.append("option").attr("type","select").attr("value","-").text("Please select...")
-                input.append("option").attr("type","select").attr("value","Available").text("Available")
-                input.append("option").attr("type","select").attr("value","N/A").text("N/A")
-                var contacts = []
-                if (theCurrentGraph.organization.contacts){contacts=theCurrentGraph.organization.contacts};
-                console.log(theCurrentGraph)
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Owner")
-                input = form_group.append("select").attr("id","owner_uid").style("margin-left","5px")
-                input.append("option").attr("type","select").attr("value","-").text("Please select...")
-                contacts.forEach(function(contact){
-                    input.append("option").attr("type","select").attr("value",contact.attrib.uID).text(contact.name + " (" + contact.company + ")")
-                })
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Creator")
-                input = form_group.append("select").attr("id","creator_uid").style("margin-left","5px")
-                input.append("option").attr("type","select").attr("value","-").text("Please select...")
-                contacts.forEach(function(contact){
-                    input.append("option").attr("type","select").attr("value",contact.attrib.uID).text(contact.name + " (" + contact.company + ")")
-                })
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Operator")
-                input = form_group.append("select").attr("id","operator_uid").style("margin-left","5px")
-                input.append("option").attr("type","select").attr("value","-").text("Please select...")
-                contacts.forEach(function(contact){
-                    input.append("option").attr("type","select").attr("value",contact.attrib.uID).text(contact.name + " (" + contact.company + ")")
-                })
-                
-                
-                //Information on tool execution
-                form_group = form.append("div").attr("class","form-group").style("margin-top","40px")
-                form_group.append("label").text("Execution information")
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Operating System")
-                input = form_group.append("select").attr("id","operating_system").style("margin-left","5px")
-                input.append("option").attr("type","select").attr("value","-").text("Please select...")
-                input.append("option").attr("type","select").attr("value","windows").text("Windows")
-                input.append("option").attr("type","select").attr("value","linux").text("Linux")
-                input.append("option").attr("type","select").attr("value","mac").text("Mac OS")
-                input.append("option").attr("type","select").attr("value","other").text("Other")
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Integration platform")
-                input = form_group.append("input")
-                    .attr("id","integration_platform")
-                    .attr("class","form-control")
-                    .attr("name","integration_platform")
-                    .attr("placeholder","Integration platform (e.g. RCE, Optimus)")
-                form_group = form.append("div").attr("class","form-group")
-                form_group.append("text").text("Execution command")
-                input = form_group.append("textarea")
-                    .attr("id","command")
-                    .attr("class","form-control")
-                    .attr("cols","40")
-                    .attr("rows","5")
-                    .attr("name","command")
-                    .attr("placeholder","Execution command")
-                form_group = form.append("div").attr("class","form-group")
-                input = form_group.append("input")
-                    .attr("id","description_cmd")
-                    .attr("class","form-control")
-                    .attr("name","description_cmd")
-                    .attr("placeholder","Details on the exectuion command (optional)")
-                form_group = form.append("div").attr("class","form-group")
-                input = form_group.append("input")
-                    .attr("id","software_requirements")
-                    .attr("class","form-control")
-                    .attr("name","software_requirements")
-                    .attr("placeholder","Software requirements")
-                form_group = form.append("div").attr("class","form-group")
-                input = form_group.append("input")
-                    .attr("id","hardware_requirements")
-                    .attr("class","form-control")
-                    .attr("name","hardware_requirements")
-                    .attr("placeholder","Hardware requirements")
-                
-                //Information on tool licensing
-                form_group = form.append("div").attr("class","form-group").style("margin-top","40px")
-                form_group.append("label").text("License information (optional)")
-                input = form_group.append("input")
-                    .attr("id","license_type")
-                    .attr("class","form-control")
-                    .attr("name","license_type")
-                    .attr("placeholder","License type (e.g. open-source, commercial)")
-                form_group = form.append("div").attr("class","form-group")
-                input = form_group.append("input")
-                    .attr("id","license_specification")
-                    .attr("class","form-control")
-                    .attr("name","license_specification")
-                    .attr("placeholder","License specification (e.g. Apache License 2.0)")
-                form_group = form.append("div").attr("class","form-group")
-                input = form_group.append("input")
-                    .attr("id","license_info")
-                    .attr("class","form-control")
-                    .attr("name","license_info")
-                    .attr("placeholder","License information (e.g. https://www.apache.org/licenses/LICENSE-2.0)")
-                    
-                //Information on tool sources
-                form_group = form.append("div").attr("class","form-group").style("margin-top","40px")
-                form_group.append("label").text("Source information (optional)")
-                input = form_group.append("input")
-                    .attr("id","repository_link")
-                    .attr("class","form-control")
-                    .attr("name","repository_link")
-                    .attr("placeholder","Repository link")
-                form_group = form.append("div").attr("class","form-group")
-                input = form_group.append("input")
-                    .attr("id","download_link")
-                    .attr("class","form-control")
-                    .attr("name","download_link")
-                    .attr("placeholder","Download link")
-                form_group = form.append("div").attr("class","form-group")
-                input = form_group.append("input")
-                    .attr("id","references")
-                    .attr("class","form-control")
-                    .attr("name","references")
-                    .attr("placeholder","References")
-
-                
-                var modal = bootbox.dialog({
-                    message: $(".form-content").html(),
-                    title: "Add Competence Metadata",
-                    size: "large",
-                    buttons: [
-                      {
-                        label: "Cancel",
-                        className: "btn btn-default pull-left",
-                        callback: function() {
-                          modal.modal("hide");
-                          d3.selectAll(".form-content").remove();
-                        }
-                      },
-                      {
-                        label: "OK",
-                        className: "btn btn-primary pull-left",
-                        callback: function() {
-                            var metadata = {
-                                uID: aNode.uID,
-                                description: $('form #description').val(),
-                                status: $('form #status').val(),
-                                owner_uid: $('form #owner_uid').val(),
-                                creator_uid: $('form #creator_uid').val(),
-                                operator_uid: $('form #operator_uid').val()
-                            }
-                            var metadata_str = JSON.stringify(metadata)
-                            var bootboxContent = {title: "Get graph elements", message: '<p>Please be patient...</p>'};
-                            var xhr = $.ajax(
-                            {
-                                type: 'POST',
-                                url: '/kadmos_add_DC_metadata',
-                                data: {'graphID':graphID, 'sessionID':sessionID, 'currentOrder':nodeOrder, 'nodeName':metadata.uID, 'metadata_str':metadata_str},
-                                success: function(result)
-                                {
-                                    if (result.includes("ERROR:"))
-                                    {
-                                        bootboxContent.message = result
-                                        kadmosErrorMessage(bootboxContent);
-                                    }
-                                    else
-                                    {   
-                                        var updatedData = {};
-                                        updatedData = theData;
-                                        var graphData = JSON.parse(result);             
-                                        for (var i = 0; i < updatedData.graphs.length; i++)
-                                        {
-                                            if (graphID == updatedData.graphs[i].id)
-                                            {
-                                                updatedData.graphs[i] = graphData.graphs[0];   
-                                            }
-                                        }
-                                        
-                                        clearView();
-                                        makeKadmosMenu(updatedData);
-                                        xdsm_script(updatedData,graphID);
-                                        
-                                        bootboxContent.message = "Success!"
-                                        kadmosSuccessMessage(bootboxContent)
-                                    }
-                                },
-                                error: function(result)
-                                {
-                                    bootboxContent.message = result
-                                    kadmosErrorMessage(bootboxContent);
-                                }
-                            });
-                            kadmosHavePatience(xhr, bootboxContent)
-                            modal.modal("hide");
-                            d3.selectAll(".form-content").remove();
-                        }
-                      }
-                    ],
-                    onEscape: function() {
-                      modal.modal("hide");
-                      d3.selectAll(".form-content").remove();
-                    }
-                });
-                
-                
-            }
-            
-            function sendDCMetadata(aMetadata)
-            {
-                
-            }
-            
-            
-            
-             
-			function makeKadmosMenu(data, initial=false)
-			{
-                //First of all, clear everything if it is already there
-                var visPackDiv = d3.select(".visPackDiv");
-                if(visPackDiv){visPackDiv.remove()};
-                var navigationBarDiv = d3.select(".navigationBarDiv");
-                if(navigationBarDiv){navigationBarDiv.remove()};
-                var lobiPanels = d3.selectAll(".lobipanel");
-                if (lobiPanels)
-                {
-                    lobiPanels.each(function()
-                    {
-                        this.remove();
-                    })
-                }
-                                
-				var imageWidth = 200;
-				var imageHeight = 150;
-				var padding = 10;
-				var rectHeight = 70;
-				var imgSize = 40;
-				visPackDiv = d3.select("body").append("div").attr("class","visPackDiv");
-				var visPackSvg = visPackDiv.append("svg")
-					.attr("class","visPackSvg")
-					.attr("width",imageWidth*5+40)
-					.attr("height",imageHeight+40)
-					.attr("transform", "translate("
-					  + String(10) + "," + String(10) + ")")			  
-				
-				var visPackFrame = visPackSvg.append("rect")
-					.attr("width",imageWidth*5+12)
-					.attr("height",imageHeight)
-					.attr("fill", "none")
-				
-				var imgs = visPackSvg.selectAll("image1").data([0]);
-					imgs.enter()
-					.append("svg:image")
-					.attr("x",5)
-					.attr("xlink:href", fileReference.AGILE_Logo)
-					.attr("width", imageWidth)
-					.attr("height", imageHeight)
-					.attr("position", "relative")
-					
-				var imgs = visPackSvg.selectAll("image2").data([0]);
-					imgs.enter()
-					.append("svg:image")
-					.attr("x",210)
-					.attr("y",-5)
-					.attr("xlink:href", fileReference.VISTOMS_Label)
-					.attr("width", "180pt")
-					.attr("height", "70pt")
-					
-					
-					
-				//Set general offset for Buttons, acknowledgements and so on
-				var offset_tmp = 645;	
-				
-				
-				//aigner: Make Acknowledgments, Help and Home buttons
-				//##########################################################
-				visPackSvg.append("rect")
-				.attr("transform", "translate("+ String(offset_tmp+17) + "," + String(0) + ")")
-				.attr("fill", "#555555")
-				.attr("width", 186)
-				.attr("height", 40)
-				
-				function makeButton(anId, aText,aPicFile, anOffset, aScale, picX, picY)
-				{
-					var buttonGroup = visPackSvg.append("a").classed("buttonGroup",true)
-					buttonGroup
-						.attr("class",anId)
-						.append("svg:title").text(aText)
-					var polygon = buttonGroup.append("polygon").classed("button",true)
-						.attr("points", "30,15 22.5,28.0 7.5,28 0,15 7.5,2 22.5,2")
-						.attr("transform", "translate("+ String(anOffset) + "," + String(2) + ") scale(1.2)")
-					buttonGroup.append("image")
-						.attr("xlink:href",aPicFile)
-						.attr("height",50)
-						.attr("width",50)
-						.attr("transform", "translate("+ String(anOffset+picX) + "," + String(picY) + ") scale("+aScale+")")
-					buttonGroup
-						.on("mouseover", function()
-						{
-							polygon.style("fill","#3399FF")
-							d3.select(this).style("cursor", "pointer")
-						})
-						.on("mouseleave", function()
-						{
-							polygon.style("fill","#555555")
-						})
-				}
-				///Home button
-				var distance = 45;
-				var currentOffset = offset_tmp+25;
-				makeButton("id_mainPage","Main Page",fileReference.Home, currentOffset, 0.45, 6.9,7.2);
-				d3.select(".id_mainPage").on("click",function()
-				{		
-					mainPage();
-				})
-				//help button
-				currentOffset+=distance;
-				makeButton("id_turorial","Tutorial",fileReference.Tutorial, currentOffset, 0.45, 6.8, 7.5);
-				d3.select(".id_turorial").on("click",function()
-				{			
-					tutorial();
-				})
-				//Contact button
-				currentOffset+=distance;
-				makeButton("id_contact","Contact the support team",fileReference.Contact, currentOffset, 0.45, 6.9, 9);
-				d3.select(".id_contact").on("click",function()
-				{				
-					sendMail("VISTOMS support");
-				})
-					
-				//Acknowledgements button
-				currentOffset+=distance;
-				makeButton("id_acknowledgements","Acknowledgements",fileReference.Acknowledgements, currentOffset, 0.45, 7, 8);
-				d3.select(".id_acknowledgements").on("click",function()
-				{
-					acknowledgements();
-				})
-				//##########################################################
-				
-                var navigationBarDiv = d3.select("body").append("div").attr("class","navigationBarDiv")
-                var ul = navigationBarDiv.append("ul")
-                navigationBarDiv.on("mouseover", function()
-                {
-                    d3.select(this).style("z-index","1300");
-                })
-                .on("mouseout", function()
-                {
-                    d3.select(this).style("z-index","");
-                })
-                var addButton_div = d3.select(".addButtonDiv")
-                if (addButton_div)
-                    addButton_div.remove();
-                    
-                
-                
-                
-                var tmpGraphsAvailable = false;
-				if (initial)
-                {
-                    var bootboxContent = {title: "VISTOMS start", message: '<p>Please be patient...</p>'};
-                    var xhr = $.ajax({
-                        type: 'POST',
-                        data: {'sessionID': sessionID},
-                        url: '/kadmos_find_temp_graphs',
-                        success: function(result)
-                        {
-                            if (result.includes("ERROR:"))
-                            {
-                                bootboxContent.message = result
-                                kadmosErrorMessage(bootboxContent);
-                            }
-                            else
-                            {
-                                var dataArray = result;          
-                                for (var i = 0; i < dataArray.length; i++)
-                                {
-                                    if (data=="REP__GRAPH_DATA__REP")
-                                    {
-                                        data = {"graphs":[], "categories":""};
-                                    }
-                                    var data_tmp = JSON.parse(dataArray[i])
-                                    data.graphs.push(data_tmp.graphs[0]);
-                                    if (data.categories == [])
-                                    {
-                                        data.categories = data_tmp.categories;                                        
-                                    }
-                                    tmpGraphsAvailable = true;
-                                }
-                                
-                                
-                                if (tmpGraphsAvailable)
-                                {
-                                    bootboxContent.title = "VISTOMS ready"
-                                    bootboxContent.message = "KADMOS found already existing VISTOMS graphs. You can select them from the drop-down menu."
-                                    kadmosSuccessMessage(bootboxContent)
-                                }
-                                else {bootbox.hideAll();}
-                                
-                                //aigner: make dropwdown section for the multiple MDO graphs tzhat can be visualized
-                                makeViewButtons(data,"XDSM","xdsm");
-                                makeViewButtons(data,"Edge Bundles","edgeBundles");
-                                makeViewButtons(data,"Sankey Diagram","sankeyDiagram");
-                                //aigner: Add special button to open graphs from kdms or cmdows files
-                                addButton(data.graphs);
-                            }
-                        },
-                        error: function(result)
-                        {
-                            bootboxContent.message = result
-                            kadmosErrorMessage(bootboxContent);
-                        }
-                    });
-                    kadmosHavePatience(xhr, bootboxContent)
-                }
-                else
-                {
-                    //aigner: make dropwdown section for the multiple MDO graphs tzhat can be visualized
-                    makeViewButtons(data,"XDSM","xdsm");
-                    makeViewButtons(data,"Edge Bundles","edgeBundles");
-                    makeViewButtons(data,"Sankey Diagram","sankeyDiagram");
-                    //aigner: Add special button to open graphs from kdms or cmdows files
-                    addButton(data.graphs);
-                }
-                
-                
-                
-                
-				//aigner: make dropwdown section for the multiple MDO graphs tzhat can be visualized
-				//##########################################################           
-				function makeViewButtons(data,name, aView)
-				{
-                    var numberOfGraphs = 0;
-					var dropdown1 = ul.append("li")
-                        .on("mouseover", function()
-                        {
-                            d3.select(this).style("cursor", "default")
-                        })
-                       
-					dropdown1.append("a").text(name)
-					dropdown1.append("img").attr("src",fileReference.AGILE_Icon)
-						.attr("align","left")
-						.style("margin-left","6px")
-						.style("margin-right","0px")
-						.style("margin-top","10px")
-						.style("margin-bottom","6px")
-						.attr("height","42")
-						.attr("width","42")
-					var links = dropdown1.append("ul");             
-                    if (data=="REP__GRAPH_DATA__REP" && !tmpGraphsAvailable)
-                    {                  
-                        var linkLi = links.append("li");
-                        var link = linkLi.append("a")
-                            .style("font-style","Italic")
-                            .text("No graphs to inspect ...")
-                            .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                            .on("click", function(){
-                                    
-                                bootbox.hideAll();
-                                bootbox.dialog({
-                                    message: "No graph to inspect in VISTOMS yet! \nYou can add a graph by uploading a KDMS or CMDOWS file.",
-                                    buttons : { cancel:
-                                                {
-                                                    label: "OK",
-                                                    className: 'btn-danger',
-                                                    callback: function(){}
-                                                }
-                                              }
-                                });
-                            })
-                    }
-                    else
-                    {
-                        var graphs_tmp = data.graphs;
-                        for (var i=0; i < graphs_tmp.length; i++)
-                        {
-                            makeDropDown(data,graphs_tmp[i],aView,links)
-                            numberOfGraphs ++;
-                        }
-                    }
-                    
-                    
-				}
-                
-				function makeDropDown(theData,theGraph,theView,theLinks)
-				{
-					var linkLi = theLinks.append("li");
-					var name_tmp="";
-					if (theGraph.name){name_tmp=theGraph.name}
-					else{name_tmp="Graph " + theGraph.id}
-					var link = linkLi.append("a").text(name_tmp)
-						.text(name_tmp)
-						.on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-						.on("click", function()
-                        {
-							clearView();					
-							if (theView == "xdsm")
-                            {
-                                xdsm_script(theData,theGraph.id)
-                            }
-							else if (theView == "edgeBundles")
-                            {
-                                edgeBundles_script(theData,theGraph.id)
-                            }
-							else if (theView == "sankeyDiagram")
-                            {
-                                sankeyDiagram_script(theData,theGraph.id)
-                            }
-                        })
-				}
-				//##########################################################
-                
-                
-                //aigner: Add special button to open graphs from kdms or cmdows files
-                //##########################################################
-                function addButton(theGraphs)
-                {
-                    var newGraphID = '01';
-                    if (theGraphs)
-                    {
-                        theGraphs.forEach(function(graph) 
-                        {
-                            id_int = parseInt(graph.id)
-                            if (theGraphs.length < 100){newGraphID = "0" + String(id_int+1);}
-                            else{newGraphID = String(id_int+1);}
-                        })
-                    }
-                    
-                    var addButton_div = d3.select("body").append("div").attr("class","addButtonDiv")
-                    var addButtonPanel = addButton_div.append("div")
-                        .attr("class","panel panel-default")
-                        .attr("id","addButton")
-                        .style("display","inline-block")
-                        .style("min-width","200px")
-                        .style("margin-left","10px")
-                    addButtonPanel.append("div").attr("class","panel-heading text-center align-top")
-                        .style("background-color","#555555")
-                        .append("h3")
-                        .attr("class","panel-title")
-                        .style("font-family","Arial")
-                        .style("font-size","14pt")
-                        .style("color","white")
-                        .style("display","inline-block")
-                        .text("Add graph")
-                    var panelBody = addButtonPanel.append("div").attr("class","panel-body")
-                        .style("font-family","Arial")
-                        .style("font-size","8pt")
-                        .style("display","inline-block")
-                    
-                    
-                    var options = ["Choose...", "Create graph from scratch", "Upload KDMS file(s)", "Upload CMDOWS file", "Upload Database"];
-
-                    var select = panelBody.append('select')
-                        .attr('id','addselect')
-                        .attr('class','select')
-                        .on('change',onchange)
-
-                    var options = select.selectAll('option')
-                        .data(options).enter()
-                        .append('option')
-                            .text(function (d) { return d; });
-                    
-                    
-                    var form = panelBody.append("form").attr("id","addForm")
-                        .attr("method","post")
-                        .attr("enctype","multipart/form-data")
-                    var label = form.append("label")
-                    var fileText;
-                    var file;
-                    var submit;
-                    var selectValue;
-                    
-                    function onchange() {
-                        selectValue = d3.select('#addselect').property('value')
-                        if (include(selectValue,"Create"))
-                        {
-                            if (file){
-                                fileText.remove();
-                                file.remove();
-                            }
-                            if (submit){submit.remove();}
-                            submit = label.append("button")
-                                .style("margin-top","10pt")
-                                .attr("type","button")
-                                .attr("class","btn btn-primary")
-                                .text("Go!")
-                            submit.on("mousedown", function()
-                            {
-                                createNewGraph(data);
-                            })
-                        }
-                        else if (include(selectValue,"KDMS"))
-                        {
-                            if (file){
-                                fileText.remove();
-                                file.remove();
-                            }
-                            if (submit){submit.remove();}
-                            fileText = label.append("text")
-                                .style("font-family","Arial")
-                                .style("font-size","12pt")
-                                .text("Choose KDMS files (max. 2: 1 data graph & 1 process graph)")
-                            file = label.append("input").attr("type","file").attr("name","file[]").attr("multiple","")
-                            submit = label.append("input").attr("type","submit").attr("value","Submit");
-                        }
-                        else if (include(selectValue,"CMDOWS"))
-                        {             
-                            if (file){
-                                fileText.remove();
-                                file.remove();
-                            }
-                            if (submit){submit.remove();}
-                            fileText = label.append("text")
-                                .style("font-family","Arial")
-                                .style("font-size","12pt")
-                                .text("Choose any CMDOWS file")
-                            file = label.append("input").attr("type","file").attr("name","file[]")
-                            submit = label.append("input").attr("type","submit").attr("value","Submit");
-                        }
-                        else if (include(selectValue,"Database"))
-                        {             
-                            if (file){
-                                fileText.remove();
-                                file.remove();
-                            }
-                            if (submit){submit.remove();}
-                            fileText = label.append("text")
-                                .style("font-family","Arial")
-                                .style("font-size","12pt")
-                                .text("Choose any zip file containing a database")
-                            file = label.append("input").attr("type","file").attr("name","file[]")
-                            submit = label.append("input").attr("type","submit").attr("value","Submit");
-                        }
-                        else{}
-                    };
-                    
-                    $('#addForm').on('submit',function(event){
-                        event.preventDefault();
-                        //aigner: Uploading files for KADMOS
-                        var formData = new FormData($('#addForm')[0]);
-                        formData.append('newGraphID', newGraphID);
-                        formData.append('fileType',selectValue)
-                        formData.append('sessionID',sessionID)
-                       
-                     
-                        
-                        //aigner: Upload file to VISTOMS and inspect it
-                        //##########################################################
-                        var bootboxContent = {title: "Upload file to VISTOMS", message: '<p>Please be patient...</p>'};
-                        var xhr = $.ajax({
-                            type: 'POST',
-                            url: '/kadmos_upload_file',
-                            data: formData,
-                            processData: false,
-                            contentType: false,
-                            success: function(result)
-                            {
-                                if (result.includes("ERROR:"))
-                                {
-                                    
-                                    
-                                    bootboxContent.message = result
-                                    kadmosErrorMessage(bootboxContent);
-                                    
-                                    clearView();
-                                    makeKadmosMenu(data);
-                                    mainPage();
-                                }
-                                else
-                                {
-                                    var updatedData = {};
-                                    if (data != "REP__GRAPH_DATA__REP")
-                                    {
-                                        updatedData = data;
-                                        var graphData = JSON.parse(result);                                        
-                                        updatedData.graphs.push(graphData.graphs[0]);                                        
-                                    }
-                                    else
-                                    {
-                                        updatedData = JSON.parse(result);
-                                    }
-                                    
-                                    clearView();
-                                    makeKadmosMenu(updatedData);
-                                    mainPage();
-                                    
-                                    bootboxContent.message = "Success!"
-                                    kadmosSuccessMessage(bootboxContent)
-                                    
-                                }
-                            },
-                            error: function(result)
-                            {
-                                bootboxContent.message = result
-                                kadmosErrorMessage(bootboxContent);
-                            }
-                        });
-                        kadmosHavePatience(xhr, bootboxContent)
-                        //##########################################################
-                    });
-                    
-                    if (theGraphs)
-                    {
-                        var saveButtonPanel = addButton_div.append("div")
-                            .attr("class","panel panel-default")
-                            .attr("id","saveButton")
-                            .style("display","inline-block")
-                            .style("min-width","200px")
-                            .style("margin-left","10px")
-                        saveButtonPanel.append("div").attr("class","panel-heading text-center align-top")
-                            .style("background-color","#555555")
-                            .append("h3")
-                            .attr("class","panel-title")
-                            .style("font-family","Arial")
-                            .style("font-size","14pt")
-                            .style("color","white")
-                            .style("display","inline-block")
-                            .text("Save all graphs")
-                        var savepanelBody = saveButtonPanel.append("div").attr("class","panel-body")
-                            .style("font-family","Arial")
-                            .style("font-size","8pt")
-                            .style("display","inline-block")
-                        
-                        
-                        var options = ["Choose...","KDMS files", "CMDOWS files"];
-
-                        var saveselect = savepanelBody.append('select')
-                            .attr('id','saveselect')
-                            .attr('class','select')
-                            .on('change',onchange)
-
-                        var options = saveselect.selectAll('option')
-                            .data(options).enter()
-                            .append('option')
-                                .text(function (d) { return d; });
-                        
-                        
-                        var saveform = savepanelBody.append("form").attr("id","saveForm")
-                            .attr("method","post")
-                            .attr("enctype","multipart/form-data")
-                        var savelabel = saveform.append("label")
-                        var saveSubmit;
-                        var selectValue;
-                        
-                        function onchange() {
-                            selectValue = d3.select('#saveselect').property('value')
-                            if (saveSubmit){saveSubmit.remove();}
-                            if (selectValue!="Choose...")
-                            {
-                                saveSubmit = savelabel.append("input").attr("type","submit").attr("value","Save");
-                            }
-                        };
-                        
-                        $('#saveForm').on('submit',function(event){
-                            event.preventDefault();
-                            //aigner: Uploading files for KADMOS
-                             bootbox.prompt(
-                            {
-                                title: "<p>The graphs will be downloaded to your computer</p>"
-                                      +"<p>Please type in the path of the directory</p>",
-                                value: "",
-                                placeholder: "path...",
-                                callback: function(path)
-                                {
-                                    if (path)
-                                    {
-                                        //##########################################################
-                                        var bootboxContent = {title: "Save all graphs", message: '<p>Please be patient...</p>'};
-                                        var xhr = $.ajax({
-                                            type: 'POST',
-                                            data: {'path': path, 'fileType': selectValue, 'sessionID': sessionID},
-                                            url: '/kadmos_export_all_graphs',
-                                            success: function(result)
-                                            {                            
-                                                if (result.includes("ERROR:"))
-                                                {
-                                                    bootboxContent.message = result
-                                                    kadmosErrorMessage(bootboxContent);
-                                                }
-                                                else
-                                                {
-                                                    bootboxContent.message = "Successfully downloaded the file(s) to <b>"+result+"</b>"
-                                                    kadmosSuccessMessage(bootboxContent);
-                                                }
-                                            },
-                                            error: function(result)
-                                            {
-                                                bootboxContent.message = result
-                                                kadmosErrorMessage(bootboxContent);
-                                            }
-                                            });
-                                        kadmosHavePatience(xhr, bootboxContent)
-                                        //##########################################################
-                                    }
-                                    
-                                }
-                            })
-                        });
-                    }
-                    d3.select("#mainPage").moveToFront()
-                }
-			}
-			//##########################################################
-
-
-			function getTextWidth(text, font) 
-			{
-				// re-use canvas object for better performance
-				var canvas = getTextWidth.canvas || (getTextWidth.canvas = document.createElement("canvas"));
-				var context = canvas.getContext("2d");
-				context.font = font;
-				var metrics = context.measureText(text);
-				return metrics.width;
-			}					
-
-
-			//#####################################################################//
-			function mainPage()
-			{	
-				clearView();
-				var introDiv = d3.select("body").append("div")
-					.attr("id","mainPage")
-					.classed("wordWrap",true)
-				
-				var theHeading = "Welcome to <b>VISTOMS</b>, the <b>VIS</b>ualization <b>TO</b>ol for <b>M</b>DO <b>S</b>ystems!\n";
-				introDiv.append("text")
-				.style("font-size","16pt")
-				.html(theHeading)
-				
-				var theText = "\nTo inspect an MDO system, go to one of the visualizations in the navigation bar (XDSM, Edge Bundles, or Sankey Diagram). Then select a graph from the dropdown menu.\n\nIf you need help with how to use the visualization package, there is a tutorial video available. Just click on the \"Tutorial\" symbol in the top right corner.";
-				introDiv.append("text").text(theText)
-				introDiv.append("text")
-					.style("font-size","8pt")
-					.html("\n\n\nCopyright 2016-2017 by Benedikt Aigner (RWTH Aachen) & Imco van Gent (TU Delft)")
-				
-				var introSvg = introDiv.append("svg")
-					.attr("width",500)
-					.attr("height",100)
-				var imgs = introSvg.selectAll("img").data([0]);
-					imgs.enter()
-					.append("svg:image")
-					.attr("xlink:href", fileReference.RWTH_Logo)
-					.attr("width", "150")
-					.attr("height", "70")
-					.on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-					.on("click",function(){window.open("https://www.rwth-aachen.de/", '_blank');} )
-				var imgs = introSvg.selectAll("img").data([0]);
-					imgs.enter()
-					.append("svg:image")
-					.attr("xlink:href", fileReference.TUDelft_Logo)
-					.attr("x", 175)
-					.attr("y", 5)
-					.attr("width", "105")
-					.attr("height", "50")
-					.on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-					.on("click",function(){window.open("https://www.tudelft.nl/en/", '_blank');} )
-
-			}
-			//#####################################################################//
-
-			//#####################################################################//
-			function acknowledgements()
-			{				
-				clearView();
-				var acknDiv = d3.select("body").append("div")
-					.attr("id","acknowledgements")
-					.classed("acknText", true)
-					.classed("wordWrap",true)
-				
-				var theHeading = "Acknowledgements";
-				acknDiv.append("text")
-				.style("font-size","16pt")
-				.html(theHeading)
-				
-				acknDiv.append("text")
-					.style("font-size","10pt")
-					.style("margin", "20px 10px")
-					.html("<br><br>Created by Benedikt Aigner and Imco van Gent for the "
-						+"<a href=\"http://www.agile-project.eu/\">AGILE Project</a> in 2016. This project has received funding from the European Union's Horizon 2020 research and innovation framework programme under grant agreement No 636202."
-						+"<br>"
-						+"<br>"
-						+"<b>VISTOMS was created using the following open source packages:</b>"
-						+"<br>"
-						+"<a href=\"https://d3js.org/\">D3.js</a> package &copy 2015 by Mike Bostock released under the <a href=\"https://opensource.org/licenses/BSD-3-Clause\">BSD license</a>"
-						+"<br>"
-						+"<a href=\"https://github.com/OneraHub/XDSMjs\">XDSM.js </a> package &copy 2016 by R&eacutemi Lafage released under the <a href=\"http://www.apache.org/licenses/LICENSE-2.0\">Apache License, Version 2.0</a>"
-						+"<br>"
-						+"<a href=\"https://github.com/Neilos/bihisankey\">BiHiSankey.js</a> package &copy 2015 by Neil Atkinson released under the <a href=\"https://opensource.org/licenses/MIT\">MIT License</a>"
-						+"<br>"
-						+"<br>"
-						+"<br>"
-						+"<font size=\"-2\">Rev. 07/31/2017</font>")
-			}
-			//#####################################################################//
-
-			//#####################################################################//
-			function tutorial()
-			{
-				var theButtons = 
-				{
-					cancel: {
-						label: "OK, got it!",
-						className: 'btn-danger',
-						callback: function(){}
-					},
-					Feedback: {
-						label: "Feedback",
-						className: 'btn-warning',
-						callback: function(){sendMail("VISTOMS feedback")}
-					},
-					Tutorial: {
-						label: "Tutorial",
-						className: 'btn-info',
-						callback: function(){showTutorialPage();}
-					}
-				}
-				
-				
-				function showTutorialPage()
-				{
-					clearView();
-					var tutorialDiv = d3.select("body").append("div")
-						.attr("id","tutorial")
-						.style("margin-top", "16px")
-						.style("font-size","16pt")
-						.style("margin", "20px 10px")
-						.style("color","#555555")
-					
-					var theHeading = "<b>VISTOMS Tutorial</b><br/><br/>";
-					tutorialDiv.append("text")
-					.style("font-size","16pt")
-					.html(theHeading)
-					
-					tutorialDiv.append("div")
-						.style("-webkit-overflow-scrolling", "touch")
-						.style("-webkit-text-size-adjust", "none")
-						.html("<video width=\"1000\" height=\"563\" controls>"
-							+"<source src=\"http://www.agile-project.eu/files/VISTOMS_Tutorial.mp4 \" type=\"video/mp4\">"
-							+"Your browser does not support the video tag."
-							+"</video>"
-							+"</div>")
-				}
-				
-				
-				if (!d3.select(".xdsmDiv").empty())
-				{
-                    bootbox.hideAll();
-					var dialog = bootbox.dialog(
-					{
-						title: 'XDSM View',
-						message: "<p><b>To interactively inspect the MDO system there are several options.</b></p>"
-								 +"<ol><li>With a right-click on an edge (rhomboids on the off-diagonal) you can take a closer look at the data processed between competences.</li>"
-								 +"<li>Click right on a competence (boxes on the diagonal) for more information, such as input/output data or a detailed tool description.</li>"
-								 +"<li>To view the full data model, go to the \"Data model\" box and select a variable categorization. </li></ol><br />"
-								 +"<p>To switch to another visualization (<i>Edge Bundles</i> or <i>Sankey Diagram</i>), go to the navigation bar and select a graph from the drop down menu.</p>"
-								 +"<p>If you need more information on how to use the visualization package, click on the \"Tutorial\" button below.</p>"
-								 +"<p><br/>Any questions or feedback? Contact the support team with the \"Feedback\" button below!</p>"
-						,
-						buttons : theButtons
-					});
-				}
-				else if(!d3.select(".edgeBundlesDiv").empty())
-				{
-                    bootbox.hideAll();
-					var dialog = bootbox.dialog({
-						title: 'Edge Bundles View',
-						message: "<p><b>To interactively inspect the MDO system there are several options.</b></p>"
-								 +"<ol><li>With a right-click on an edge (connecting lines between the competences) you can take a closer look at the data processed between those competences.</li>"
-								 +"<li>When you hover over one of the competences with the mouse, the respective input and output connections are highlighted. Input connections are highlighted in red, output connections in green.</li>"
-								 +"<li>Click right on a competence for more information, such as input/output data or a detailed tool description.</li>"
-								 +"<li>To view the full data model, go to the \"Data model\" box and select a variable categorization.</li></ol><br />"
-								 +"<p>To switch to another visualization (<i>Edge Bundles</i> or <i>Sankey Diagram</i>), go to the navigation bar and select a graph from the drop down menu.</p>"
-								 +"<p>If you need more information on how to use the visualization package, click on the \"Tutorial\" button below.</p>"
-								 +"<p><br/>Any questions or feedback? Contact the support team with the \"Feedback\" button below!</p>"
-						,
-						buttons: theButtons
-					})
-				}
-				else if(!d3.select(".sankeyDiagramDiv").empty())
-				{
-                    bootbox.hideAll();
-					var dialog = bootbox.dialog({
-						title: 'Sankey Diagram',
-						message: "<p><b>To interactively inspect the MDO system there are several options.</b></p>"
-								 +"<ol><li>When you hover over one of the competences with the mouse, the respective input and output connections are highlighted. Input connections are highlighted in red, output connections in green.</li>"
-								 +"<li> With a right-click on an edge (connecting arrows between the competences) you can take a closer look at the data processed between those competences.</li>"
-								 +"<li>Click right on a competence for more information, such as input/output data or a detailed tool description. You can also rearrange the layout by dragging the competences with the computer mouse.</li>"
-								 +"<li>To view the full data model, go to the \"Data model\" box and select a variable categorization.</li></ol><br />"
-								 +"<p>To switch to another visualization (<i>XDSM</i> or <i>Edge Bundles</i>), go to the navigation bar and select a graph from the drop down menu.</p>"
-								 +"<p>If you need more information on how to use the visualization package, click on the \"Tutorial\" button below.</p>"
-								 +"<p><br/>Any questions or feedback? Contact the support team with the \"Feedback\" button below!</p>"
-						,
-						buttons: theButtons
-					})
-				}
-				else
-				{
-					showTutorialPage();
-				}
-			}
-			//#####################################################################//
-			
-			//aigner: Send mail function
-			//#####################################################################//
-			function sendMail(mailText) 
-			{
-				var link = "mailto:support@agile-project.eu"
-				window.location.href = link;
-			}
-			//#####################################################################//
-			
-			//aigner: Load entire MDO data
-			//###############################################################################################################################################################################################################//
-			//#####################################################################//
-			//#####################################################################//
-			//@Imco: here the references to all files are done
-			var fileReference = {
-				Acknowledgements : "static/pictures/Acknowledgements.png",
-				AGILE_Icon : "static/pictures/AGILE_Icon.png",
-				AGILE_Logo : "static/pictures/AGILE_Logo.png",
-				Contact : "static/pictures/Contact.png",
-				Home: "static/pictures/Home.png",
-				RWTH_Logo : "static/pictures/RWTH_Logo.png",
-				TUDelft_Logo : "static/pictures/TUDelft_Logo.png",
-				Tutorial : "static/pictures/Tutorial.png",
-				VISTOMS_Label : "static/pictures/VISTOMS_Label.png",
-			}
-			
-			//@Imco: Here is the sellar problem example data
-			theData = "REP__GRAPH_DATA__REP"
-			function loadAllData(data)
-			{
-				makeKadmosMenu(data,true);
-				mainPage();
-			}
-			loadAllData(theData);
-			//#####################################################################//
-			//#####################################################################//
-			//###############################################################################################################################################################################################################//
-			
-			//aigner: Clear view function
-			//#####################################################################//
-			function clearView()
-			{
-				var visualizationScript = d3.select(".visualizationScript");
-				if (visualizationScript){visualizationScript.remove();}
-				var mainPage = document.getElementById("mainPage");
-				if (mainPage){mainPage.remove();}
-				var tutorial = document.getElementById("tutorial");
-				if (tutorial){tutorial.remove();}
-				var ackn = document.getElementById("acknowledgements");
-				if (ackn){ackn.remove();}
-				var xdsm = d3.select(".xdsmDiv");							
-				if (xdsm){xdsm.remove();}
-				var edgeBundles = d3.select(".edgeBundlesDiv");							
-				if (edgeBundles){edgeBundles.remove();}
-				var sankeyDiagram = d3.select(".sankeyDiagramDiv");
-				if (sankeyDiagram){sankeyDiagram.remove();}
-			}
-			//#####################################################################//
-		
-		function xdsm_script(data,graphID)
-		{
-			(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
-			// https://d3js.org Version 4.3.0. Copyright 2016 Mike Bostock.
-			(function (global, factory) {
-			  typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :
-			  typeof define === 'function' && define.amd ? define(['exports'], factory) :
-			  (factory((global.d3 = global.d3 || {})));
-			}(this, (function (exports) { 'use strict';
-
-			var version = "4.3.0";
-
-			var ascending = function(a, b) {
-			  return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
-			};
-
-			var bisector = function(compare) {
-			  if (compare.length === 1) compare = ascendingComparator(compare);
-			  return {
-				left: function(a, x, lo, hi) {
-				  if (lo == null) lo = 0;
-				  if (hi == null) hi = a.length;
-				  while (lo < hi) {
-					var mid = lo + hi >>> 1;
-					if (compare(a[mid], x) < 0) lo = mid + 1;
-					else hi = mid;
-				  }
-				  return lo;
-				},
-				right: function(a, x, lo, hi) {
-				  if (lo == null) lo = 0;
-				  if (hi == null) hi = a.length;
-				  while (lo < hi) {
-					var mid = lo + hi >>> 1;
-					if (compare(a[mid], x) > 0) hi = mid;
-					else lo = mid + 1;
-				  }
-				  return lo;
-				}
-			  };
-			};
-
-			function ascendingComparator(f) {
-			  return function(d, x) {
-				return ascending(f(d), x);
-			  };
-			}
-
-			var ascendingBisect = bisector(ascending);
-			var bisectRight = ascendingBisect.right;
-			var bisectLeft = ascendingBisect.left;
-
-			var descending = function(a, b) {
-			  return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;
-			};
-
-			var number = function(x) {
-			  return x === null ? NaN : +x;
-			};
-
-			var variance = function(array, f) {
-			  var n = array.length,
-				  m = 0,
-				  a,
-				  d,
-				  s = 0,
-				  i = -1,
-				  j = 0;
-
-			  if (f == null) {
-				while (++i < n) {
-				  if (!isNaN(a = number(array[i]))) {
-					d = a - m;
-					m += d / ++j;
-					s += d * (a - m);
-				  }
-				}
-			  }
-
-			  else {
-				while (++i < n) {
-				  if (!isNaN(a = number(f(array[i], i, array)))) {
-					d = a - m;
-					m += d / ++j;
-					s += d * (a - m);
-				  }
-				}
-			  }
-
-			  if (j > 1) return s / (j - 1);
-			};
-
-			var deviation = function(array, f) {
-			  var v = variance(array, f);
-			  return v ? Math.sqrt(v) : v;
-			};
-
-			var extent = function(array, f) {
-			  var i = -1,
-				  n = array.length,
-				  a,
-				  b,
-				  c;
-
-			  if (f == null) {
-				while (++i < n) if ((b = array[i]) != null && b >= b) { a = c = b; break; }
-				while (++i < n) if ((b = array[i]) != null) {
-				  if (a > b) a = b;
-				  if (c < b) c = b;
-				}
-			  }
-
-			  else {
-				while (++i < n) if ((b = f(array[i], i, array)) != null && b >= b) { a = c = b; break; }
-				while (++i < n) if ((b = f(array[i], i, array)) != null) {
-				  if (a > b) a = b;
-				  if (c < b) c = b;
-				}
-			  }
-
-			  return [a, c];
-			};
-
-			var array = Array.prototype;
-
-			var slice = array.slice;
-			var map = array.map;
-
-			var constant$1 = function(x) {
-			  return function() {
-				return x;
-			  };
-			};
-
-			var identity = function(x) {
-			  return x;
-			};
-
-			var range = function(start, stop, step) {
-			  start = +start, stop = +stop, step = (n = arguments.length) < 2 ? (stop = start, start = 0, 1) : n < 3 ? 1 : +step;
-
-			  var i = -1,
-				  n = Math.max(0, Math.ceil((stop - start) / step)) | 0,
-				  range = new Array(n);
-
-			  while (++i < n) {
-				range[i] = start + i * step;
-			  }
-
-			  return range;
-			};
-
-			var e10 = Math.sqrt(50);
-			var e5 = Math.sqrt(10);
-			var e2 = Math.sqrt(2);
-
-			var ticks = function(start, stop, count) {
-			  var step = tickStep(start, stop, count);
-			  return range(
-				Math.ceil(start / step) * step,
-				Math.floor(stop / step) * step + step / 2, // inclusive
-				step
-			  );
-			};
-
-			function tickStep(start, stop, count) {
-			  var step0 = Math.abs(stop - start) / Math.max(0, count),
-				  step1 = Math.pow(10, Math.floor(Math.log(step0) / Math.LN10)),
-				  error = step0 / step1;
-			  if (error >= e10) step1 *= 10;
-			  else if (error >= e5) step1 *= 5;
-			  else if (error >= e2) step1 *= 2;
-			  return stop < start ? -step1 : step1;
-			}
-
-			var sturges = function(values) {
-			  return Math.ceil(Math.log(values.length) / Math.LN2) + 1;
-			};
-
-			var histogram = function() {
-			  var value = identity,
-				  domain = extent,
-				  threshold = sturges;
-
-			  function histogram(data) {
-				var i,
-					n = data.length,
-					x,
-					values = new Array(n);
-
-				for (i = 0; i < n; ++i) {
-				  values[i] = value(data[i], i, data);
-				}
-
-				var xz = domain(values),
-					x0 = xz[0],
-					x1 = xz[1],
-					tz = threshold(values, x0, x1);
-
-				// Convert number of thresholds into uniform thresholds.
-				if (!Array.isArray(tz)) tz = ticks(x0, x1, tz);
-
-				// Remove any thresholds outside the domain.
-				var m = tz.length;
-				while (tz[0] <= x0) tz.shift(), --m;
-				while (tz[m - 1] >= x1) tz.pop(), --m;
-
-				var bins = new Array(m + 1),
-					bin;
-
-				// Initialize bins.
-				for (i = 0; i <= m; ++i) {
-				  bin = bins[i] = [];
-				  bin.x0 = i > 0 ? tz[i - 1] : x0;
-				  bin.x1 = i < m ? tz[i] : x1;
-				}
-
-				// Assign data to bins by value, ignoring any outside the domain.
-				for (i = 0; i < n; ++i) {
-				  x = values[i];
-				  if (x0 <= x && x <= x1) {
-					bins[bisectRight(tz, x, 0, m)].push(data[i]);
-				  }
-				}
-
-				return bins;
-			  }
-
-			  histogram.value = function(_) {
-				return arguments.length ? (value = typeof _ === "function" ? _ : constant$1(_), histogram) : value;
-			  };
-
-			  histogram.domain = function(_) {
-				return arguments.length ? (domain = typeof _ === "function" ? _ : constant$1([_[0], _[1]]), histogram) : domain;
-			  };
-
-			  histogram.thresholds = function(_) {
-				return arguments.length ? (threshold = typeof _ === "function" ? _ : Array.isArray(_) ? constant$1(slice.call(_)) : constant$1(_), histogram) : threshold;
-			  };
-
-			  return histogram;
-			};
-
-			var threshold = function(array, p, f) {
-			  if (f == null) f = number;
-			  if (!(n = array.length)) return;
-			  if ((p = +p) <= 0 || n < 2) return +f(array[0], 0, array);
-			  if (p >= 1) return +f(array[n - 1], n - 1, array);
-			  var n,
-				  h = (n - 1) * p,
-				  i = Math.floor(h),
-				  a = +f(array[i], i, array),
-				  b = +f(array[i + 1], i + 1, array);
-			  return a + (b - a) * (h - i);
-			};
-
-			var freedmanDiaconis = function(values, min, max) {
-			  values = map.call(values, number).sort(ascending);
-			  return Math.ceil((max - min) / (2 * (threshold(values, 0.75) - threshold(values, 0.25)) * Math.pow(values.length, -1 / 3)));
-			};
-
-			var scott = function(values, min, max) {
-			  return Math.ceil((max - min) / (3.5 * deviation(values) * Math.pow(values.length, -1 / 3)));
-			};
-
-			var max = function(array, f) {
-			  var i = -1,
-				  n = array.length,
-				  a,
-				  b;
-
-			  if (f == null) {
-				while (++i < n) if ((b = array[i]) != null && b >= b) { a = b; break; }
-				while (++i < n) if ((b = array[i]) != null && b > a) a = b;
-			  }
-
-			  else {
-				while (++i < n) if ((b = f(array[i], i, array)) != null && b >= b) { a = b; break; }
-				while (++i < n) if ((b = f(array[i], i, array)) != null && b > a) a = b;
-			  }
-
-			  return a;
-			};
-
-			var mean = function(array, f) {
-			  var s = 0,
-				  n = array.length,
-				  a,
-				  i = -1,
-				  j = n;
-
-			  if (f == null) {
-				while (++i < n) if (!isNaN(a = number(array[i]))) s += a; else --j;
-			  }
-
-			  else {
-				while (++i < n) if (!isNaN(a = number(f(array[i], i, array)))) s += a; else --j;
-			  }
-
-			  if (j) return s / j;
-			};
-
-			var median = function(array, f) {
-			  var numbers = [],
-				  n = array.length,
-				  a,
-				  i = -1;
-
-			  if (f == null) {
-				while (++i < n) if (!isNaN(a = number(array[i]))) numbers.push(a);
-			  }
-
-			  else {
-				while (++i < n) if (!isNaN(a = number(f(array[i], i, array)))) numbers.push(a);
-			  }
-
-			  return threshold(numbers.sort(ascending), 0.5);
-			};
-
-			var merge = function(arrays) {
-			  var n = arrays.length,
-				  m,
-				  i = -1,
-				  j = 0,
-				  merged,
-				  array;
-
-			  while (++i < n) j += arrays[i].length;
-			  merged = new Array(j);
-
-			  while (--n >= 0) {
-				array = arrays[n];
-				m = array.length;
-				while (--m >= 0) {
-				  merged[--j] = array[m];
-				}
-			  }
-
-			  return merged;
-			};
-
-			var min = function(array, f) {
-			  var i = -1,
-				  n = array.length,
-				  a,
-				  b;
-
-			  if (f == null) {
-				while (++i < n) if ((b = array[i]) != null && b >= b) { a = b; break; }
-				while (++i < n) if ((b = array[i]) != null && a > b) a = b;
-			  }
-
-			  else {
-				while (++i < n) if ((b = f(array[i], i, array)) != null && b >= b) { a = b; break; }
-				while (++i < n) if ((b = f(array[i], i, array)) != null && a > b) a = b;
-			  }
-
-			  return a;
-			};
-
-			var pairs = function(array) {
-			  var i = 0, n = array.length - 1, p = array[0], pairs = new Array(n < 0 ? 0 : n);
-			  while (i < n) pairs[i] = [p, p = array[++i]];
-			  return pairs;
-			};
-
-			var permute = function(array, indexes) {
-			  var i = indexes.length, permutes = new Array(i);
-			  while (i--) permutes[i] = array[indexes[i]];
-			  return permutes;
-			};
-
-			var scan = function(array, compare) {
-			  if (!(n = array.length)) return;
-			  var i = 0,
-				  n,
-				  j = 0,
-				  xi,
-				  xj = array[j];
-
-			  if (!compare) compare = ascending;
-
-			  while (++i < n) if (compare(xi = array[i], xj) < 0 || compare(xj, xj) !== 0) xj = xi, j = i;
-
-			  if (compare(xj, xj) === 0) return j;
-			};
-
-			var shuffle = function(array, i0, i1) {
-			  var m = (i1 == null ? array.length : i1) - (i0 = i0 == null ? 0 : +i0),
-				  t,
-				  i;
-
-			  while (m) {
-				i = Math.random() * m-- | 0;
-				t = array[m + i0];
-				array[m + i0] = array[i + i0];
-				array[i + i0] = t;
-			  }
-
-			  return array;
-			};
-
-			var sum = function(array, f) {
-			  var s = 0,
-				  n = array.length,
-				  a,
-				  i = -1;
-
-			  if (f == null) {
-				while (++i < n) if (a = +array[i]) s += a; // Note: zero and null are equivalent.
-			  }
-
-			  else {
-				while (++i < n) if (a = +f(array[i], i, array)) s += a;
-			  }
-
-			  return s;
-			};
-
-			var transpose = function(matrix) {
-			  if (!(n = matrix.length)) return [];
-			  for (var i = -1, m = min(matrix, length), transpose = new Array(m); ++i < m;) {
-				for (var j = -1, n, row = transpose[i] = new Array(n); ++j < n;) {
-				  row[j] = matrix[j][i];
-				}
-			  }
-			  return transpose;
-			};
-
-			function length(d) {
-			  return d.length;
-			}
-
-			var zip = function() {
-			  return transpose(arguments);
-			};
-
-			var prefix = "$";
-
-			function Map() {}
-
-			Map.prototype = map$1.prototype = {
-			  constructor: Map,
-			  has: function(key) {
-				return (prefix + key) in this;
-			  },
-			  get: function(key) {
-				return this[prefix + key];
-			  },
-			  set: function(key, value) {
-				this[prefix + key] = value;
-				return this;
-			  },
-			  remove: function(key) {
-				var property = prefix + key;
-				return property in this && delete this[property];
-			  },
-			  clear: function() {
-				for (var property in this) if (property[0] === prefix) delete this[property];
-			  },
-			  keys: function() {
-				var keys = [];
-				for (var property in this) if (property[0] === prefix) keys.push(property.slice(1));
-				return keys;
-			  },
-			  values: function() {
-				var values = [];
-				for (var property in this) if (property[0] === prefix) values.push(this[property]);
-				return values;
-			  },
-			  entries: function() {
-				var entries = [];
-				for (var property in this) if (property[0] === prefix) entries.push({key: property.slice(1), value: this[property]});
-				return entries;
-			  },
-			  size: function() {
-				var size = 0;
-				for (var property in this) if (property[0] === prefix) ++size;
-				return size;
-			  },
-			  empty: function() {
-				for (var property in this) if (property[0] === prefix) return false;
-				return true;
-			  },
-			  each: function(f) {
-				for (var property in this) if (property[0] === prefix) f(this[property], property.slice(1), this);
-			  }
-			};
-
-			function map$1(object, f) {
-			  var map = new Map;
-
-			  // Copy constructor.
-			  if (object instanceof Map) object.each(function(value, key) { map.set(key, value); });
-
-			  // Index array by numeric index or specified key function.
-			  else if (Array.isArray(object)) {
-				var i = -1,
-					n = object.length,
-					o;
-
-				if (f == null) while (++i < n) map.set(i, object[i]);
-				else while (++i < n) map.set(f(o = object[i], i, object), o);
-			  }
-
-			  // Convert object to map.
-			  else if (object) for (var key in object) map.set(key, object[key]);
-
-			  return map;
-			}
-
-			var nest = function() {
-			  var keys = [],
-				  sortKeys = [],
-				  sortValues,
-				  rollup,
-				  nest;
-
-			  function apply(array, depth, createResult, setResult) {
-				if (depth >= keys.length) return rollup != null
-					? rollup(array) : (sortValues != null
-					? array.sort(sortValues)
-					: array);
-
-				var i = -1,
-					n = array.length,
-					key = keys[depth++],
-					keyValue,
-					value,
-					valuesByKey = map$1(),
-					values,
-					result = createResult();
-
-				while (++i < n) {
-				  if (values = valuesByKey.get(keyValue = key(value = array[i]) + "")) {
-					values.push(value);
-				  } else {
-					valuesByKey.set(keyValue, [value]);
-				  }
-				}
-
-				valuesByKey.each(function(values, key) {
-				  setResult(result, key, apply(values, depth, createResult, setResult));
-				});
-
-				return result;
-			  }
-
-			  function entries(map, depth) {
-				if (++depth > keys.length) return map;
-				var array, sortKey = sortKeys[depth - 1];
-				if (rollup != null && depth >= keys.length) array = map.entries();
-				else array = [], map.each(function(v, k) { array.push({key: k, values: entries(v, depth)}); });
-				return sortKey != null ? array.sort(function(a, b) { return sortKey(a.key, b.key); }) : array;
-			  }
-
-			  return nest = {
-				object: function(array) { return apply(array, 0, createObject, setObject); },
-				map: function(array) { return apply(array, 0, createMap, setMap); },
-				entries: function(array) { return entries(apply(array, 0, createMap, setMap), 0); },
-				key: function(d) { keys.push(d); return nest; },
-				sortKeys: function(order) { sortKeys[keys.length - 1] = order; return nest; },
-				sortValues: function(order) { sortValues = order; return nest; },
-				rollup: function(f) { rollup = f; return nest; }
-			  };
-			};
-
-			function createObject() {
-			  return {};
-			}
-
-			function setObject(object, key, value) {
-			  object[key] = value;
-			}
-
-			function createMap() {
-			  return map$1();
-			}
-
-			function setMap(map, key, value) {
-			  map.set(key, value);
-			}
-
-			function Set() {}
-
-			var proto = map$1.prototype;
-
-			Set.prototype = set.prototype = {
-			  constructor: Set,
-			  has: proto.has,
-			  add: function(value) {
-				value += "";
-				this[prefix + value] = value;
-				return this;
-			  },
-			  remove: proto.remove,
-			  clear: proto.clear,
-			  values: proto.keys,
-			  size: proto.size,
-			  empty: proto.empty,
-			  each: proto.each
-			};
-
-			function set(object, f) {
-			  var set = new Set;
-
-			  // Copy constructor.
-			  if (object instanceof Set) object.each(function(value) { set.add(value); });
-
-			  // Otherwise, assume it’s an array.
-			  else if (object) {
-				var i = -1, n = object.length;
-				if (f == null) while (++i < n) set.add(object[i]);
-				else while (++i < n) set.add(f(object[i], i, object));
-			  }
-
-			  return set;
-			}
-
-			var keys = function(map) {
-			  var keys = [];
-			  for (var key in map) keys.push(key);
-			  return keys;
-			};
-
-			var values = function(map) {
-			  var values = [];
-			  for (var key in map) values.push(map[key]);
-			  return values;
-			};
-
-			var entries = function(map) {
-			  var entries = [];
-			  for (var key in map) entries.push({key: key, value: map[key]});
-			  return entries;
-			};
-
-			var uniform = function(min, max) {
-			  min = min == null ? 0 : +min;
-			  max = max == null ? 1 : +max;
-			  if (arguments.length === 1) max = min, min = 0;
-			  else max -= min;
-			  return function() {
-				return Math.random() * max + min;
-			  };
-			};
-
-			var normal = function(mu, sigma) {
-			  var x, r;
-			  mu = mu == null ? 0 : +mu;
-			  sigma = sigma == null ? 1 : +sigma;
-			  return function() {
-				var y;
-
-				// If available, use the second previously-generated uniform random.
-				if (x != null) y = x, x = null;
-
-				// Otherwise, generate a new x and y.
-				else do {
-				  x = Math.random() * 2 - 1;
-				  y = Math.random() * 2 - 1;
-				  r = x * x + y * y;
-				} while (!r || r > 1);
-
-				return mu + sigma * y * Math.sqrt(-2 * Math.log(r) / r);
-			  };
-			};
-
-			var logNormal = function() {
-			  var randomNormal = normal.apply(this, arguments);
-			  return function() {
-				return Math.exp(randomNormal());
-			  };
-			};
-
-			var irwinHall = function(n) {
-			  return function() {
-				for (var sum = 0, i = 0; i < n; ++i) sum += Math.random();
-				return sum;
-			  };
-			};
-
-			var bates = function(n) {
-			  var randomIrwinHall = irwinHall(n);
-			  return function() {
-				return randomIrwinHall() / n;
-			  };
-			};
-
-			var exponential = function(lambda) {
-			  return function() {
-				return -Math.log(1 - Math.random()) / lambda;
-			  };
-			};
-
-			function linear(t) {
-			  return +t;
-			}
-
-			function quadIn(t) {
-			  return t * t;
-			}
-
-			function quadOut(t) {
-			  return t * (2 - t);
-			}
-
-			function quadInOut(t) {
-			  return ((t *= 2) <= 1 ? t * t : --t * (2 - t) + 1) / 2;
-			}
-
-			function cubicIn(t) {
-			  return t * t * t;
-			}
-
-			function cubicOut(t) {
-			  return --t * t * t + 1;
-			}
-
-			function cubicInOut(t) {
-			  return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;
-			}
-
-			var exponent = 3;
-
-			var polyIn = (function custom(e) {
-			  e = +e;
-
-			  function polyIn(t) {
-				return Math.pow(t, e);
-			  }
-
-			  polyIn.exponent = custom;
-
-			  return polyIn;
-			})(exponent);
-
-			var polyOut = (function custom(e) {
-			  e = +e;
-
-			  function polyOut(t) {
-				return 1 - Math.pow(1 - t, e);
-			  }
-
-			  polyOut.exponent = custom;
-
-			  return polyOut;
-			})(exponent);
-
-			var polyInOut = (function custom(e) {
-			  e = +e;
-
-			  function polyInOut(t) {
-				return ((t *= 2) <= 1 ? Math.pow(t, e) : 2 - Math.pow(2 - t, e)) / 2;
-			  }
-
-			  polyInOut.exponent = custom;
-
-			  return polyInOut;
-			})(exponent);
-
-			var pi = Math.PI;
-			var halfPi = pi / 2;
-
-			function sinIn(t) {
-			  return 1 - Math.cos(t * halfPi);
-			}
-
-			function sinOut(t) {
-			  return Math.sin(t * halfPi);
-			}
-
-			function sinInOut(t) {
-			  return (1 - Math.cos(pi * t)) / 2;
-			}
-
-			function expIn(t) {
-			  return Math.pow(2, 10 * t - 10);
-			}
-
-			function expOut(t) {
-			  return 1 - Math.pow(2, -10 * t);
-			}
-
-			function expInOut(t) {
-			  return ((t *= 2) <= 1 ? Math.pow(2, 10 * t - 10) : 2 - Math.pow(2, 10 - 10 * t)) / 2;
-			}
-
-			function circleIn(t) {
-			  return 1 - Math.sqrt(1 - t * t);
-			}
-
-			function circleOut(t) {
-			  return Math.sqrt(1 - --t * t);
-			}
-
-			function circleInOut(t) {
-			  return ((t *= 2) <= 1 ? 1 - Math.sqrt(1 - t * t) : Math.sqrt(1 - (t -= 2) * t) + 1) / 2;
-			}
-
-			var b1 = 4 / 11;
-			var b2 = 6 / 11;
-			var b3 = 8 / 11;
-			var b4 = 3 / 4;
-			var b5 = 9 / 11;
-			var b6 = 10 / 11;
-			var b7 = 15 / 16;
-			var b8 = 21 / 22;
-			var b9 = 63 / 64;
-			var b0 = 1 / b1 / b1;
-
-			function bounceIn(t) {
-			  return 1 - bounceOut(1 - t);
-			}
-
-			function bounceOut(t) {
-			  return (t = +t) < b1 ? b0 * t * t : t < b3 ? b0 * (t -= b2) * t + b4 : t < b6 ? b0 * (t -= b5) * t + b7 : b0 * (t -= b8) * t + b9;
-			}
-
-			function bounceInOut(t) {
-			  return ((t *= 2) <= 1 ? 1 - bounceOut(1 - t) : bounceOut(t - 1) + 1) / 2;
-			}
-
-			var overshoot = 1.70158;
-
-			var backIn = (function custom(s) {
-			  s = +s;
-
-			  function backIn(t) {
-				return t * t * ((s + 1) * t - s);
-			  }
-
-			  backIn.overshoot = custom;
-
-			  return backIn;
-			})(overshoot);
-
-			var backOut = (function custom(s) {
-			  s = +s;
-
-			  function backOut(t) {
-				return --t * t * ((s + 1) * t + s) + 1;
-			  }
-
-			  backOut.overshoot = custom;
-
-			  return backOut;
-			})(overshoot);
-
-			var backInOut = (function custom(s) {
-			  s = +s;
-
-			  function backInOut(t) {
-				return ((t *= 2) < 1 ? t * t * ((s + 1) * t - s) : (t -= 2) * t * ((s + 1) * t + s) + 2) / 2;
-			  }
-
-			  backInOut.overshoot = custom;
-
-			  return backInOut;
-			})(overshoot);
-
-			var tau = 2 * Math.PI;
-			var amplitude = 1;
-			var period = 0.3;
-
-			var elasticIn = (function custom(a, p) {
-			  var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);
-
-			  function elasticIn(t) {
-				return a * Math.pow(2, 10 * --t) * Math.sin((s - t) / p);
-			  }
-
-			  elasticIn.amplitude = function(a) { return custom(a, p * tau); };
-			  elasticIn.period = function(p) { return custom(a, p); };
-
-			  return elasticIn;
-			})(amplitude, period);
-
-			var elasticOut = (function custom(a, p) {
-			  var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);
-
-			  function elasticOut(t) {
-				return 1 - a * Math.pow(2, -10 * (t = +t)) * Math.sin((t + s) / p);
-			  }
-
-			  elasticOut.amplitude = function(a) { return custom(a, p * tau); };
-			  elasticOut.period = function(p) { return custom(a, p); };
-
-			  return elasticOut;
-			})(amplitude, period);
-
-			var elasticInOut = (function custom(a, p) {
-			  var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);
-
-			  function elasticInOut(t) {
-				return ((t = t * 2 - 1) < 0
-					? a * Math.pow(2, 10 * t) * Math.sin((s - t) / p)
-					: 2 - a * Math.pow(2, -10 * t) * Math.sin((s + t) / p)) / 2;
-			  }
-
-			  elasticInOut.amplitude = function(a) { return custom(a, p * tau); };
-			  elasticInOut.period = function(p) { return custom(a, p); };
-
-			  return elasticInOut;
-			})(amplitude, period);
-
-			var area = function(polygon) {
-			  var i = -1,
-				  n = polygon.length,
-				  a,
-				  b = polygon[n - 1],
-				  area = 0;
-
-			  while (++i < n) {
-				a = b;
-				b = polygon[i];
-				area += a[1] * b[0] - a[0] * b[1];
-			  }
-
-			  return area / 2;
-			};
-
-			var centroid = function(polygon) {
-			  var i = -1,
-				  n = polygon.length,
-				  x = 0,
-				  y = 0,
-				  a,
-				  b = polygon[n - 1],
-				  c,
-				  k = 0;
-
-			  while (++i < n) {
-				a = b;
-				b = polygon[i];
-				k += c = a[0] * b[1] - b[0] * a[1];
-				x += (a[0] + b[0]) * c;
-				y += (a[1] + b[1]) * c;
-			  }
-
-			  return k *= 3, [x / k, y / k];
-			};
-
-			// Returns the 2D cross product of AB and AC vectors, i.e., the z-component of
-			// the 3D cross product in a quadrant I Cartesian coordinate system (+x is
-			// right, +y is up). Returns a positive value if ABC is counter-clockwise,
-			// negative if clockwise, and zero if the points are collinear.
-			var cross = function(a, b, c) {
-			  return (b[0] - a[0]) * (c[1] - a[1]) - (b[1] - a[1]) * (c[0] - a[0]);
-			};
-
-			function lexicographicOrder(a, b) {
-			  return a[0] - b[0] || a[1] - b[1];
-			}
-
-			// Computes the upper convex hull per the monotone chain algorithm.
-			// Assumes points.length >= 3, is sorted by x, unique in y.
-			// Returns an array of indices into points in left-to-right order.
-			function computeUpperHullIndexes(points) {
-			  var n = points.length,
-				  indexes = [0, 1],
-				  size = 2;
-
-			  for (var i = 2; i < n; ++i) {
-				while (size > 1 && cross(points[indexes[size - 2]], points[indexes[size - 1]], points[i]) <= 0) --size;
-				indexes[size++] = i;
-			  }
-
-			  return indexes.slice(0, size); // remove popped points
-			}
-
-			var hull = function(points) {
-			  if ((n = points.length) < 3) return null;
-
-			  var i,
-				  n,
-				  sortedPoints = new Array(n),
-				  flippedPoints = new Array(n);
-
-			  for (i = 0; i < n; ++i) sortedPoints[i] = [+points[i][0], +points[i][1], i];
-			  sortedPoints.sort(lexicographicOrder);
-			  for (i = 0; i < n; ++i) flippedPoints[i] = [sortedPoints[i][0], -sortedPoints[i][1]];
-
-			  var upperIndexes = computeUpperHullIndexes(sortedPoints),
-				  lowerIndexes = computeUpperHullIndexes(flippedPoints);
-
-			  // Construct the hull polygon, removing possible duplicate endpoints.
-			  var skipLeft = lowerIndexes[0] === upperIndexes[0],
-				  skipRight = lowerIndexes[lowerIndexes.length - 1] === upperIndexes[upperIndexes.length - 1],
-				  hull = [];
-
-			  // Add upper hull in right-to-l order.
-			  // Then add lower hull in left-to-right order.
-			  for (i = upperIndexes.length - 1; i >= 0; --i) hull.push(points[sortedPoints[upperIndexes[i]][2]]);
-			  for (i = +skipLeft; i < lowerIndexes.length - skipRight; ++i) hull.push(points[sortedPoints[lowerIndexes[i]][2]]);
-
-			  return hull;
-			};
-
-			var contains = function(polygon, point) {
-			  var n = polygon.length,
-				  p = polygon[n - 1],
-				  x = point[0], y = point[1],
-				  x0 = p[0], y0 = p[1],
-				  x1, y1,
-				  inside = false;
-
-			  for (var i = 0; i < n; ++i) {
-				p = polygon[i], x1 = p[0], y1 = p[1];
-				if (((y1 > y) !== (y0 > y)) && (x < (x0 - x1) * (y - y1) / (y0 - y1) + x1)) inside = !inside;
-				x0 = x1, y0 = y1;
-			  }
-
-			  return inside;
-			};
-
-			var length$1 = function(polygon) {
-			  var i = -1,
-				  n = polygon.length,
-				  b = polygon[n - 1],
-				  xa,
-				  ya,
-				  xb = b[0],
-				  yb = b[1],
-				  perimeter = 0;
-
-			  while (++i < n) {
-				xa = xb;
-				ya = yb;
-				b = polygon[i];
-				xb = b[0];
-				yb = b[1];
-				xa -= xb;
-				ya -= yb;
-				perimeter += Math.sqrt(xa * xa + ya * ya);
-			  }
-
-			  return perimeter;
-			};
-
-			var pi$1 = Math.PI;
-			var tau$1 = 2 * pi$1;
-			var epsilon = 1e-6;
-			var tauEpsilon = tau$1 - epsilon;
-
-			function Path() {
-			  this._x0 = this._y0 = // start of current subpath
-			  this._x1 = this._y1 = null; // end of current subpath
-			  this._ = [];
-			}
-
-			function path() {
-			  return new Path;
-			}
-
-			Path.prototype = path.prototype = {
-			  constructor: Path,
-			  moveTo: function(x, y) {
-				this._.push("M", this._x0 = this._x1 = +x, ",", this._y0 = this._y1 = +y);
-			  },
-			  closePath: function() {
-				if (this._x1 !== null) {
-				  this._x1 = this._x0, this._y1 = this._y0;
-				  this._.push("Z");
-				}
-			  },
-			  lineTo: function(x, y) {
-				this._.push("L", this._x1 = +x, ",", this._y1 = +y);
-			  },
-			  quadraticCurveTo: function(x1, y1, x, y) {
-				this._.push("Q", +x1, ",", +y1, ",", this._x1 = +x, ",", this._y1 = +y);
-			  },
-			  bezierCurveTo: function(x1, y1, x2, y2, x, y) {
-				this._.push("C", +x1, ",", +y1, ",", +x2, ",", +y2, ",", this._x1 = +x, ",", this._y1 = +y);
-			  },
-			  arcTo: function(x1, y1, x2, y2, r) {
-				x1 = +x1, y1 = +y1, x2 = +x2, y2 = +y2, r = +r;
-				var x0 = this._x1,
-					y0 = this._y1,
-					x21 = x2 - x1,
-					y21 = y2 - y1,
-					x01 = x0 - x1,
-					y01 = y0 - y1,
-					l01_2 = x01 * x01 + y01 * y01;
-
-				// Is the radius negative? Error.
-				if (r < 0) throw new Error("negative radius: " + r);
-
-				// Is this path empty? Move to (x1,y1).
-				if (this._x1 === null) {
-				  this._.push(
-					"M", this._x1 = x1, ",", this._y1 = y1
-				  );
-				}
-
-				// Or, is (x1,y1) coincident with (x0,y0)? Do nothing.
-				else if (!(l01_2 > epsilon)) {}
-
-				// Or, are (x0,y0), (x1,y1) and (x2,y2) collinear?
-				// Equivalently, is (x1,y1) coincident with (x2,y2)?
-				// Or, is the radius zero? Line to (x1,y1).
-				else if (!(Math.abs(y01 * x21 - y21 * x01) > epsilon) || !r) {
-				  this._.push(
-					"L", this._x1 = x1, ",", this._y1 = y1
-				  );
-				}
-
-				// Otherwise, draw an arc!
-				else {
-				  var x20 = x2 - x0,
-					  y20 = y2 - y0,
-					  l21_2 = x21 * x21 + y21 * y21,
-					  l20_2 = x20 * x20 + y20 * y20,
-					  l21 = Math.sqrt(l21_2),
-					  l01 = Math.sqrt(l01_2),
-					  l = r * Math.tan((pi$1 - Math.acos((l21_2 + l01_2 - l20_2) / (2 * l21 * l01))) / 2),
-					  t01 = l / l01,
-					  t21 = l / l21;
-
-				  // If the start tangent is not coincident with (x0,y0), line to.
-				  if (Math.abs(t01 - 1) > epsilon) {
-					this._.push(
-					  "L", x1 + t01 * x01, ",", y1 + t01 * y01
-					);
-				  }
-
-				  this._.push(
-					"A", r, ",", r, ",0,0,", +(y01 * x20 > x01 * y20), ",", this._x1 = x1 + t21 * x21, ",", this._y1 = y1 + t21 * y21
-				  );
-				}
-			  },
-			  arc: function(x, y, r, a0, a1, ccw) {
-				x = +x, y = +y, r = +r;
-				var dx = r * Math.cos(a0),
-					dy = r * Math.sin(a0),
-					x0 = x + dx,
-					y0 = y + dy,
-					cw = 1 ^ ccw,
-					da = ccw ? a0 - a1 : a1 - a0;
-
-				// Is the radius negative? Error.
-				if (r < 0) throw new Error("negative radius: " + r);
-
-				// Is this path empty? Move to (x0,y0).
-				if (this._x1 === null) {
-				  this._.push(
-					"M", x0, ",", y0
-				  );
-				}
-
-				// Or, is (x0,y0) not coincident with the previous point? Line to (x0,y0).
-				else if (Math.abs(this._x1 - x0) > epsilon || Math.abs(this._y1 - y0) > epsilon) {
-				  this._.push(
-					"L", x0, ",", y0
-				  );
-				}
-
-				// Is this arc empty? We’re done.
-				if (!r) return;
-
-				// Is this a complete circle? Draw two arcs to complete the circle.
-				if (da > tauEpsilon) {
-				  this._.push(
-					"A", r, ",", r, ",0,1,", cw, ",", x - dx, ",", y - dy,
-					"A", r, ",", r, ",0,1,", cw, ",", this._x1 = x0, ",", this._y1 = y0
-				  );
-				}
-
-				// Otherwise, draw an arc!
-				else {
-				  if (da < 0) da = da % tau$1 + tau$1;
-				  this._.push(
-					"A", r, ",", r, ",0,", +(da >= pi$1), ",", cw, ",", this._x1 = x + r * Math.cos(a1), ",", this._y1 = y + r * Math.sin(a1)
-				  );
-				}
-			  },
-			  rect: function(x, y, w, h) {
-				this._.push("M", this._x0 = this._x1 = +x, ",", this._y0 = this._y1 = +y, "h", +w, "v", +h, "h", -w, "Z");
-			  },
-			  toString: function() {
-				return this._.join("");
-			  }
-			};
-
-			var tree_add = function(d) {
-			  var x = +this._x.call(null, d),
-				  y = +this._y.call(null, d);
-			  return add(this.cover(x, y), x, y, d);
-			};
-
-			function add(tree, x, y, d) {
-			  if (isNaN(x) || isNaN(y)) return tree; // ignore invalid points
-
-			  var parent,
-				  node = tree._root,
-				  leaf = {data: d},
-				  x0 = tree._x0,
-				  y0 = tree._y0,
-				  x1 = tree._x1,
-				  y1 = tree._y1,
-				  xm,
-				  ym,
-				  xp,
-				  yp,
-				  right,
-				  bottom,
-				  i,
-				  j;
-
-			  // If the tree is empty, initialize the root as a leaf.
-			  if (!node) return tree._root = leaf, tree;
-
-			  // Find the existing leaf for the new point, or add it.
-			  while (node.length) {
-				if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;
-				if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;
-				if (parent = node, !(node = node[i = bottom << 1 | right])) return parent[i] = leaf, tree;
-			  }
-
-			  // Is the new point is exactly coincident with the existing point?
-			  xp = +tree._x.call(null, node.data);
-			  yp = +tree._y.call(null, node.data);
-			  if (x === xp && y === yp) return leaf.next = node, parent ? parent[i] = leaf : tree._root = leaf, tree;
-
-			  // Otherwise, split the leaf node until the old and new point are separated.
-			  do {
-				parent = parent ? parent[i] = new Array(4) : tree._root = new Array(4);
-				if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;
-				if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;
-			  } while ((i = bottom << 1 | right) === (j = (yp >= ym) << 1 | (xp >= xm)));
-			  return parent[j] = node, parent[i] = leaf, tree;
-			}
-
-			function addAll(data) {
-			  var d, i, n = data.length,
-				  x,
-				  y,
-				  xz = new Array(n),
-				  yz = new Array(n),
-				  x0 = Infinity,
-				  y0 = Infinity,
-				  x1 = -Infinity,
-				  y1 = -Infinity;
-
-			  // Compute the points and their extent.
-			  for (i = 0; i < n; ++i) {
-				if (isNaN(x = +this._x.call(null, d = data[i])) || isNaN(y = +this._y.call(null, d))) continue;
-				xz[i] = x;
-				yz[i] = y;
-				if (x < x0) x0 = x;
-				if (x > x1) x1 = x;
-				if (y < y0) y0 = y;
-				if (y > y1) y1 = y;
-			  }
-
-			  // If there were no (valid) points, inherit the existing extent.
-			  if (x1 < x0) x0 = this._x0, x1 = this._x1;
-			  if (y1 < y0) y0 = this._y0, y1 = this._y1;
-
-			  // Expand the tree to cover the new points.
-			  this.cover(x0, y0).cover(x1, y1);
-
-			  // Add the new points.
-			  for (i = 0; i < n; ++i) {
-				add(this, xz[i], yz[i], data[i]);
-			  }
-
-			  return this;
-			}
-
-			var tree_cover = function(x, y) {
-			  if (isNaN(x = +x) || isNaN(y = +y)) return this; // ignore invalid points
-
-			  var x0 = this._x0,
-				  y0 = this._y0,
-				  x1 = this._x1,
-				  y1 = this._y1;
-
-			  // If the quadtree has no extent, initialize them.
-			  // Integer extent are necessary so that if we later double the extent,
-			  // the existing quadrant boundaries don’t change due to floating point error!
-			  if (isNaN(x0)) {
-				x1 = (x0 = Math.floor(x)) + 1;
-				y1 = (y0 = Math.floor(y)) + 1;
-			  }
-
-			  // Otherwise, double repeatedly to cover.
-			  else if (x0 > x || x > x1 || y0 > y || y > y1) {
-				var z = x1 - x0,
-					node = this._root,
-					parent,
-					i;
-
-				switch (i = (y < (y0 + y1) / 2) << 1 | (x < (x0 + x1) / 2)) {
-				  case 0: {
-					do parent = new Array(4), parent[i] = node, node = parent;
-					while (z *= 2, x1 = x0 + z, y1 = y0 + z, x > x1 || y > y1);
-					break;
-				  }
-				  case 1: {
-					do parent = new Array(4), parent[i] = node, node = parent;
-					while (z *= 2, x0 = x1 - z, y1 = y0 + z, x0 > x || y > y1);
-					break;
-				  }
-				  case 2: {
-					do parent = new Array(4), parent[i] = node, node = parent;
-					while (z *= 2, x1 = x0 + z, y0 = y1 - z, x > x1 || y0 > y);
-					break;
-				  }
-				  case 3: {
-					do parent = new Array(4), parent[i] = node, node = parent;
-					while (z *= 2, x0 = x1 - z, y0 = y1 - z, x0 > x || y0 > y);
-					break;
-				  }
-				}
-
-				if (this._root && this._root.length) this._root = node;
-			  }
-
-			  // If the quadtree covers the point already, just return.
-			  else return this;
-
-			  this._x0 = x0;
-			  this._y0 = y0;
-			  this._x1 = x1;
-			  this._y1 = y1;
-			  return this;
-			};
-
-			var tree_data = function() {
-			  var data = [];
-			  this.visit(function(node) {
-				if (!node.length) do data.push(node.data); while (node = node.next)
-			  });
-			  return data;
-			};
-
-			var tree_extent = function(_) {
-			  return arguments.length
-				  ? this.cover(+_[0][0], +_[0][1]).cover(+_[1][0], +_[1][1])
-				  : isNaN(this._x0) ? undefined : [[this._x0, this._y0], [this._x1, this._y1]];
-			};
-
-			var Quad = function(node, x0, y0, x1, y1) {
-			  this.node = node;
-			  this.x0 = x0;
-			  this.y0 = y0;
-			  this.x1 = x1;
-			  this.y1 = y1;
-			};
-
-			var tree_find = function(x, y, radius) {
-			  var data,
-				  x0 = this._x0,
-				  y0 = this._y0,
-				  x1,
-				  y1,
-				  x2,
-				  y2,
-				  x3 = this._x1,
-				  y3 = this._y1,
-				  quads = [],
-				  node = this._root,
-				  q,
-				  i;
-
-			  if (node) quads.push(new Quad(node, x0, y0, x3, y3));
-			  if (radius == null) radius = Infinity;
-			  else {
-				x0 = x - radius, y0 = y - radius;
-				x3 = x + radius, y3 = y + radius;
-				radius *= radius;
-			  }
-
-			  while (q = quads.pop()) {
-
-				// Stop searching if this quadrant can’t contain a closer node.
-				if (!(node = q.node)
-					|| (x1 = q.x0) > x3
-					|| (y1 = q.y0) > y3
-					|| (x2 = q.x1) < x0
-					|| (y2 = q.y1) < y0) continue;
-
-				// Bisect the current quadrant.
-				if (node.length) {
-				  var xm = (x1 + x2) / 2,
-					  ym = (y1 + y2) / 2;
-
-				  quads.push(
-					new Quad(node[3], xm, ym, x2, y2),
-					new Quad(node[2], x1, ym, xm, y2),
-					new Quad(node[1], xm, y1, x2, ym),
-					new Quad(node[0], x1, y1, xm, ym)
-				  );
-
-				  // Visit the closest quadrant first.
-				  if (i = (y >= ym) << 1 | (x >= xm)) {
-					q = quads[quads.length - 1];
-					quads[quads.length - 1] = quads[quads.length - 1 - i];
-					quads[quads.length - 1 - i] = q;
-				  }
-				}
-
-				// Visit this point. (Visiting coincident points isn’t necessary!)
-				else {
-				  var dx = x - +this._x.call(null, node.data),
-					  dy = y - +this._y.call(null, node.data),
-					  d2 = dx * dx + dy * dy;
-				  if (d2 < radius) {
-					var d = Math.sqrt(radius = d2);
-					x0 = x - d, y0 = y - d;
-					x3 = x + d, y3 = y + d;
-					data = node.data;
-				  }
-				}
-			  }
-
-			  return data;
-			};
-
-			var tree_remove = function(d) {
-			  if (isNaN(x = +this._x.call(null, d)) || isNaN(y = +this._y.call(null, d))) return this; // ignore invalid points
-
-			  var parent,
-				  node = this._root,
-				  retainer,
-				  previous,
-				  next,
-				  x0 = this._x0,
-				  y0 = this._y0,
-				  x1 = this._x1,
-				  y1 = this._y1,
-				  x,
-				  y,
-				  xm,
-				  ym,
-				  right,
-				  bottom,
-				  i,
-				  j;
-
-			  // If the tree is empty, initialize the root as a leaf.
-			  if (!node) return this;
-
-			  // Find the leaf node for the point.
-			  // While descending, also retain the deepest parent with a non-removed sibling.
-			  if (node.length) while (true) {
-				if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;
-				if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;
-				if (!(parent = node, node = node[i = bottom << 1 | right])) return this;
-				if (!node.length) break;
-				if (parent[(i + 1) & 3] || parent[(i + 2) & 3] || parent[(i + 3) & 3]) retainer = parent, j = i;
-			  }
-
-			  // Find the point to remove.
-			  while (node.data !== d) if (!(previous = node, node = node.next)) return this;
-			  if (next = node.next) delete node.next;
-
-			  // If there are multiple coincident points, remove just the point.
-			  if (previous) return (next ? previous.next = next : delete previous.next), this;
-
-			  // If this is the root point, remove it.
-			  if (!parent) return this._root = next, this;
-
-			  // Remove this leaf.
-			  next ? parent[i] = next : delete parent[i];
-
-			  // If the parent now contains exactly one leaf, collapse superfluous parents.
-			  if ((node = parent[0] || parent[1] || parent[2] || parent[3])
-				  && node === (parent[3] || parent[2] || parent[1] || parent[0])
-				  && !node.length) {
-				if (retainer) retainer[j] = node;
-				else this._root = node;
-			  }
-
-			  return this;
-			};
-
-			function removeAll(data) {
-			  for (var i = 0, n = data.length; i < n; ++i) this.remove(data[i]);
-			  return this;
-			}
-
-			var tree_root = function() {
-			  return this._root;
-			};
-
-			var tree_size = function() {
-			  var size = 0;
-			  this.visit(function(node) {
-				if (!node.length) do ++size; while (node = node.next)
-			  });
-			  return size;
-			};
-
-			var tree_visit = function(callback) {
-			  var quads = [], q, node = this._root, child, x0, y0, x1, y1;
-			  if (node) quads.push(new Quad(node, this._x0, this._y0, this._x1, this._y1));
-			  while (q = quads.pop()) {
-				if (!callback(node = q.node, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1) && node.length) {
-				  var xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;
-				  if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));
-				  if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));
-				  if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));
-				  if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));
-				}
-			  }
-			  return this;
-			};
-
-			var tree_visitAfter = function(callback) {
-			  var quads = [], next = [], q;
-			  if (this._root) quads.push(new Quad(this._root, this._x0, this._y0, this._x1, this._y1));
-			  while (q = quads.pop()) {
-				var node = q.node;
-				if (node.length) {
-				  var child, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1, xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;
-				  if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));
-				  if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));
-				  if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));
-				  if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));
-				}
-				next.push(q);
-			  }
-			  while (q = next.pop()) {
-				callback(q.node, q.x0, q.y0, q.x1, q.y1);
-			  }
-			  return this;
-			};
-
-			function defaultX(d) {
-			  return d[0];
-			}
-
-			var tree_x = function(_) {
-			  return arguments.length ? (this._x = _, this) : this._x;
-			};
-
-			function defaultY(d) {
-			  return d[1];
-			}
-
-			var tree_y = function(_) {
-			  return arguments.length ? (this._y = _, this) : this._y;
-			};
-
-			function quadtree(nodes, x, y) {
-			  var tree = new Quadtree(x == null ? defaultX : x, y == null ? defaultY : y, NaN, NaN, NaN, NaN);
-			  return nodes == null ? tree : tree.addAll(nodes);
-			}
-
-			function Quadtree(x, y, x0, y0, x1, y1) {
-			  this._x = x;
-			  this._y = y;
-			  this._x0 = x0;
-			  this._y0 = y0;
-			  this._x1 = x1;
-			  this._y1 = y1;
-			  this._root = undefined;
-			}
-
-			function leaf_copy(leaf) {
-			  var copy = {data: leaf.data}, next = copy;
-			  while (leaf = leaf.next) next = next.next = {data: leaf.data};
-			  return copy;
-			}
-
-			var treeProto = quadtree.prototype = Quadtree.prototype;
-
-			treeProto.copy = function() {
-			  var copy = new Quadtree(this._x, this._y, this._x0, this._y0, this._x1, this._y1),
-				  node = this._root,
-				  nodes,
-				  child;
-
-			  if (!node) return copy;
-
-			  if (!node.length) return copy._root = leaf_copy(node), copy;
-
-			  nodes = [{source: node, target: copy._root = new Array(4)}];
-			  while (node = nodes.pop()) {
-				for (var i = 0; i < 4; ++i) {
-				  if (child = node.source[i]) {
-					if (child.length) nodes.push({source: child, target: node.target[i] = new Array(4)});
-					else node.target[i] = leaf_copy(child);
-				  }
-				}
-			  }
-
-			  return copy;
-			};
-
-			treeProto.add = tree_add;
-			treeProto.addAll = addAll;
-			treeProto.cover = tree_cover;
-			treeProto.data = tree_data;
-			treeProto.extent = tree_extent;
-			treeProto.find = tree_find;
-			treeProto.remove = tree_remove;
-			treeProto.removeAll = removeAll;
-			treeProto.root = tree_root;
-			treeProto.size = tree_size;
-			treeProto.visit = tree_visit;
-			treeProto.visitAfter = tree_visitAfter;
-			treeProto.x = tree_x;
-			treeProto.y = tree_y;
-
-			var slice$1 = [].slice;
-
-			var noabort = {};
-
-			function Queue(size) {
-			  if (!(size >= 1)) throw new Error;
-			  this._size = size;
-			  this._call =
-			  this._error = null;
-			  this._tasks = [];
-			  this._data = [];
-			  this._waiting =
-			  this._active =
-			  this._ended =
-			  this._start = 0; // inside a synchronous task callback?
-			}
-
-			Queue.prototype = queue.prototype = {
-			  constructor: Queue,
-			  defer: function(callback) {
-				if (typeof callback !== "function" || this._call) throw new Error;
-				if (this._error != null) return this;
-				var t = slice$1.call(arguments, 1);
-				t.push(callback);
-				++this._waiting, this._tasks.push(t);
-				poke(this);
-				return this;
-			  },
-			  abort: function() {
-				if (this._error == null) abort(this, new Error("abort"));
-				return this;
-			  },
-			  await: function(callback) {
-				if (typeof callback !== "function" || this._call) throw new Error;
-				this._call = function(error, results) { callback.apply(null, [error].concat(results)); };
-				maybeNotify(this);
-				return this;
-			  },
-			  awaitAll: function(callback) {
-				if (typeof callback !== "function" || this._call) throw new Error;
-				this._call = callback;
-				maybeNotify(this);
-				return this;
-			  }
-			};
-
-			function poke(q) {
-			  if (!q._start) {
-				try { start(q); } // let the current task complete
-				catch (e) {
-				  if (q._tasks[q._ended + q._active - 1]) abort(q, e); // task errored synchronously
-				  else if (!q._data) throw e; // await callback errored synchronously
-				}
-			  }
-			}
-
-			function start(q) {
-			  while (q._start = q._waiting && q._active < q._size) {
-				var i = q._ended + q._active,
-					t = q._tasks[i],
-					j = t.length - 1,
-					c = t[j];
-				t[j] = end(q, i);
-				--q._waiting, ++q._active;
-				t = c.apply(null, t);
-				if (!q._tasks[i]) continue; // task finished synchronously
-				q._tasks[i] = t || noabort;
-			  }
-			}
-
-			function end(q, i) {
-			  return function(e, r) {
-				if (!q._tasks[i]) return; // ignore multiple callbacks
-				--q._active, ++q._ended;
-				q._tasks[i] = null;
-				if (q._error != null) return; // ignore secondary errors
-				if (e != null) {
-				  abort(q, e);
-				} else {
-				  q._data[i] = r;
-				  if (q._waiting) poke(q);
-				  else maybeNotify(q);
-				}
-			  };
-			}
-
-			function abort(q, e) {
-			  var i = q._tasks.length, t;
-			  q._error = e; // ignore active callbacks
-			  q._data = undefined; // allow gc
-			  q._waiting = NaN; // prevent starting
-
-			  while (--i >= 0) {
-				if (t = q._tasks[i]) {
-				  q._tasks[i] = null;
-				  if (t.abort) {
-					try { t.abort(); }
-					catch (e) { /* ignore */ }
-				  }
-				}
-			  }
-
-			  q._active = NaN; // allow notification
-			  maybeNotify(q);
-			}
-
-			function maybeNotify(q) {
-			  if (!q._active && q._call) {
-				var d = q._data;
-				q._data = undefined; // allow gc
-				q._call(q._error, d);
-			  }
-			}
-
-			function queue(concurrency) {
-			  return new Queue(arguments.length ? +concurrency : Infinity);
-			}
-
-			var constant$2 = function(x) {
-			  return function constant() {
-				return x;
-			  };
-			};
-
-			var epsilon$1 = 1e-12;
-			var pi$2 = Math.PI;
-			var halfPi$1 = pi$2 / 2;
-			var tau$2 = 2 * pi$2;
-
-			function arcInnerRadius(d) {
-			  return d.innerRadius;
-			}
-
-			function arcOuterRadius(d) {
-			  return d.outerRadius;
-			}
-
-			function arcStartAngle(d) {
-			  return d.startAngle;
-			}
-
-			function arcEndAngle(d) {
-			  return d.endAngle;
-			}
-
-			function arcPadAngle(d) {
-			  return d && d.padAngle; // Note: optional!
-			}
-
-			function asin(x) {
-			  return x >= 1 ? halfPi$1 : x <= -1 ? -halfPi$1 : Math.asin(x);
-			}
-
-			function intersect(x0, y0, x1, y1, x2, y2, x3, y3) {
-			  var x10 = x1 - x0, y10 = y1 - y0,
-				  x32 = x3 - x2, y32 = y3 - y2,
-				  t = (x32 * (y0 - y2) - y32 * (x0 - x2)) / (y32 * x10 - x32 * y10);
-			  return [x0 + t * x10, y0 + t * y10];
-			}
-
-			// Compute perpendicular offset line of length rc.
-			// http://mathworld.wolfram.com/Circle-LineIntersection.html
-			function cornerTangents(x0, y0, x1, y1, r1, rc, cw) {
-			  var x01 = x0 - x1,
-				  y01 = y0 - y1,
-				  lo = (cw ? rc : -rc) / Math.sqrt(x01 * x01 + y01 * y01),
-				  ox = lo * y01,
-				  oy = -lo * x01,
-				  x11 = x0 + ox,
-				  y11 = y0 + oy,
-				  x10 = x1 + ox,
-				  y10 = y1 + oy,
-				  x00 = (x11 + x10) / 2,
-				  y00 = (y11 + y10) / 2,
-				  dx = x10 - x11,
-				  dy = y10 - y11,
-				  d2 = dx * dx + dy * dy,
-				  r = r1 - rc,
-				  D = x11 * y10 - x10 * y11,
-				  d = (dy < 0 ? -1 : 1) * Math.sqrt(Math.max(0, r * r * d2 - D * D)),
-				  cx0 = (D * dy - dx * d) / d2,
-				  cy0 = (-D * dx - dy * d) / d2,
-				  cx1 = (D * dy + dx * d) / d2,
-				  cy1 = (-D * dx + dy * d) / d2,
-				  dx0 = cx0 - x00,
-				  dy0 = cy0 - y00,
-				  dx1 = cx1 - x00,
-				  dy1 = cy1 - y00;
-
-			  // Pick the closer of the two intersection points.
-			  // TODO Is there a faster way to determine which intersection to use?
-			  if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1) cx0 = cx1, cy0 = cy1;
-
-			  return {
-				cx: cx0,
-				cy: cy0,
-				x01: -ox,
-				y01: -oy,
-				x11: cx0 * (r1 / r - 1),
-				y11: cy0 * (r1 / r - 1)
-			  };
-			}
-
-			var arc = function() {
-			  var innerRadius = arcInnerRadius,
-				  outerRadius = arcOuterRadius,
-				  cornerRadius = constant$2(0),
-				  padRadius = null,
-				  startAngle = arcStartAngle,
-				  endAngle = arcEndAngle,
-				  padAngle = arcPadAngle,
-				  context = null;
-
-			  function arc() {
-				var buffer,
-					r,
-					r0 = +innerRadius.apply(this, arguments),
-					r1 = +outerRadius.apply(this, arguments),
-					a0 = startAngle.apply(this, arguments) - halfPi$1,
-					a1 = endAngle.apply(this, arguments) - halfPi$1,
-					da = Math.abs(a1 - a0),
-					cw = a1 > a0;
-
-				if (!context) context = buffer = path();
-
-				// Ensure that the outer radius is always larger than the inner radius.
-				if (r1 < r0) r = r1, r1 = r0, r0 = r;
-
-				// Is it a point?
-				if (!(r1 > epsilon$1)) context.moveTo(0, 0);
-
-				// Or is it a circle or annulus?
-				else if (da > tau$2 - epsilon$1) {
-				  context.moveTo(r1 * Math.cos(a0), r1 * Math.sin(a0));
-				  context.arc(0, 0, r1, a0, a1, !cw);
-				  if (r0 > epsilon$1) {
-					context.moveTo(r0 * Math.cos(a1), r0 * Math.sin(a1));
-					context.arc(0, 0, r0, a1, a0, cw);
-				  }
-				}
-
-				// Or is it a circular or annular sector?
-				else {
-				  var a01 = a0,
-					  a11 = a1,
-					  a00 = a0,
-					  a10 = a1,
-					  da0 = da,
-					  da1 = da,
-					  ap = padAngle.apply(this, arguments) / 2,
-					  rp = (ap > epsilon$1) && (padRadius ? +padRadius.apply(this, arguments) : Math.sqrt(r0 * r0 + r1 * r1)),
-					  rc = Math.min(Math.abs(r1 - r0) / 2, +cornerRadius.apply(this, arguments)),
-					  rc0 = rc,
-					  rc1 = rc,
-					  t0,
-					  t1;
-
-				  // Apply padding? Note that since r1 ≥ r0, da1 ≥ da0.
-				  if (rp > epsilon$1) {
-					var p0 = asin(rp / r0 * Math.sin(ap)),
-						p1 = asin(rp / r1 * Math.sin(ap));
-					if ((da0 -= p0 * 2) > epsilon$1) p0 *= (cw ? 1 : -1), a00 += p0, a10 -= p0;
-					else da0 = 0, a00 = a10 = (a0 + a1) / 2;
-					if ((da1 -= p1 * 2) > epsilon$1) p1 *= (cw ? 1 : -1), a01 += p1, a11 -= p1;
-					else da1 = 0, a01 = a11 = (a0 + a1) / 2;
-				  }
-
-				  var x01 = r1 * Math.cos(a01),
-					  y01 = r1 * Math.sin(a01),
-					  x10 = r0 * Math.cos(a10),
-					  y10 = r0 * Math.sin(a10);
-
-				  // Apply rounded corners?
-				  if (rc > epsilon$1) {
-					var x11 = r1 * Math.cos(a11),
-						y11 = r1 * Math.sin(a11),
-						x00 = r0 * Math.cos(a00),
-						y00 = r0 * Math.sin(a00);
-
-					// Restrict the corner radius according to the sector angle.
-					if (da < pi$2) {
-					  var oc = da0 > epsilon$1 ? intersect(x01, y01, x00, y00, x11, y11, x10, y10) : [x10, y10],
-						  ax = x01 - oc[0],
-						  ay = y01 - oc[1],
-						  bx = x11 - oc[0],
-						  by = y11 - oc[1],
-						  kc = 1 / Math.sin(Math.acos((ax * bx + ay * by) / (Math.sqrt(ax * ax + ay * ay) * Math.sqrt(bx * bx + by * by))) / 2),
-						  lc = Math.sqrt(oc[0] * oc[0] + oc[1] * oc[1]);
-					  rc0 = Math.min(rc, (r0 - lc) / (kc - 1));
-					  rc1 = Math.min(rc, (r1 - lc) / (kc + 1));
-					}
-				  }
-
-				  // Is the sector collapsed to a line?
-				  if (!(da1 > epsilon$1)) context.moveTo(x01, y01);
-
-				  // Does the sector’s outer ring have rounded corners?
-				  else if (rc1 > epsilon$1) {
-					t0 = cornerTangents(x00, y00, x01, y01, r1, rc1, cw);
-					t1 = cornerTangents(x11, y11, x10, y10, r1, rc1, cw);
-
-					context.moveTo(t0.cx + t0.x01, t0.cy + t0.y01);
-
-					// Have the corners merged?
-					if (rc1 < rc) context.arc(t0.cx, t0.cy, rc1, Math.atan2(t0.y01, t0.x01), Math.atan2(t1.y01, t1.x01), !cw);
-
-					// Otherwise, draw the two corners and the ring.
-					else {
-					  context.arc(t0.cx, t0.cy, rc1, Math.atan2(t0.y01, t0.x01), Math.atan2(t0.y11, t0.x11), !cw);
-					  context.arc(0, 0, r1, Math.atan2(t0.cy + t0.y11, t0.cx + t0.x11), Math.atan2(t1.cy + t1.y11, t1.cx + t1.x11), !cw);
-					  context.arc(t1.cx, t1.cy, rc1, Math.atan2(t1.y11, t1.x11), Math.atan2(t1.y01, t1.x01), !cw);
-					}
-				  }
-
-				  // Or is the outer ring just a circular arc?
-				  else context.moveTo(x01, y01), context.arc(0, 0, r1, a01, a11, !cw);
-
-				  // Is there no inner ring, and it’s a circular sector?
-				  // Or perhaps it’s an annular sector collapsed due to padding?
-				  if (!(r0 > epsilon$1) || !(da0 > epsilon$1)) context.lineTo(x10, y10);
-
-				  // Does the sector’s inner ring (or point) have rounded corners?
-				  else if (rc0 > epsilon$1) {
-					t0 = cornerTangents(x10, y10, x11, y11, r0, -rc0, cw);
-					t1 = cornerTangents(x01, y01, x00, y00, r0, -rc0, cw);
-
-					context.lineTo(t0.cx + t0.x01, t0.cy + t0.y01);
-
-					// Have the corners merged?
-					if (rc0 < rc) context.arc(t0.cx, t0.cy, rc0, Math.atan2(t0.y01, t0.x01), Math.atan2(t1.y01, t1.x01), !cw);
-
-					// Otherwise, draw the two corners and the ring.
-					else {
-					  context.arc(t0.cx, t0.cy, rc0, Math.atan2(t0.y01, t0.x01), Math.atan2(t0.y11, t0.x11), !cw);
-					  context.arc(0, 0, r0, Math.atan2(t0.cy + t0.y11, t0.cx + t0.x11), Math.atan2(t1.cy + t1.y11, t1.cx + t1.x11), cw);
-					  context.arc(t1.cx, t1.cy, rc0, Math.atan2(t1.y11, t1.x11), Math.atan2(t1.y01, t1.x01), !cw);
-					}
-				  }
-
-				  // Or is the inner ring just a circular arc?
-				  else context.arc(0, 0, r0, a10, a00, cw);
-				}
-
-				context.closePath();
-
-				if (buffer) return context = null, buffer + "" || null;
-			  }
-
-			  arc.centroid = function() {
-				var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2,
-					a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - pi$2 / 2;
-				return [Math.cos(a) * r, Math.sin(a) * r];
-			  };
-
-			  arc.innerRadius = function(_) {
-				return arguments.length ? (innerRadius = typeof _ === "function" ? _ : constant$2(+_), arc) : innerRadius;
-			  };
-
-			  arc.outerRadius = function(_) {
-				return arguments.length ? (outerRadius = typeof _ === "function" ? _ : constant$2(+_), arc) : outerRadius;
-			  };
-
-			  arc.cornerRadius = function(_) {
-				return arguments.length ? (cornerRadius = typeof _ === "function" ? _ : constant$2(+_), arc) : cornerRadius;
-			  };
-
-			  arc.padRadius = function(_) {
-				return arguments.length ? (padRadius = _ == null ? null : typeof _ === "function" ? _ : constant$2(+_), arc) : padRadius;
-			  };
-
-			  arc.startAngle = function(_) {
-				return arguments.length ? (startAngle = typeof _ === "function" ? _ : constant$2(+_), arc) : startAngle;
-			  };
-
-			  arc.endAngle = function(_) {
-				return arguments.length ? (endAngle = typeof _ === "function" ? _ : constant$2(+_), arc) : endAngle;
-			  };
-
-			  arc.padAngle = function(_) {
-				return arguments.length ? (padAngle = typeof _ === "function" ? _ : constant$2(+_), arc) : padAngle;
-			  };
-
-			  arc.context = function(_) {
-				return arguments.length ? ((context = _ == null ? null : _), arc) : context;
-			  };
-
-			  return arc;
-			};
-
-			function Linear(context) {
-			  this._context = context;
-			}
-
-			Linear.prototype = {
-			  areaStart: function() {
-				this._line = 0;
-			  },
-			  areaEnd: function() {
-				this._line = NaN;
-			  },
-			  lineStart: function() {
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();
-				this._line = 1 - this._line;
-			  },
-			  point: function(x, y) {
-				x = +x, y = +y;
-				switch (this._point) {
-				  case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;
-				  case 1: this._point = 2; // proceed
-				  default: this._context.lineTo(x, y); break;
-				}
-			  }
-			};
-
-			var curveLinear = function(context) {
-			  return new Linear(context);
-			};
-
-			function x(p) {
-			  return p[0];
-			}
-
-			function y(p) {
-			  return p[1];
-			}
-
-			var line = function() {
-			  var x$$1 = x,
-				  y$$1 = y,
-				  defined = constant$2(true),
-				  context = null,
-				  curve = curveLinear,
-				  output = null;
-
-			  function line(data) {
-				var i,
-					n = data.length,
-					d,
-					defined0 = false,
-					buffer;
-
-				if (context == null) output = curve(buffer = path());
-
-				for (i = 0; i <= n; ++i) {
-				  if (!(i < n && defined(d = data[i], i, data)) === defined0) {
-					if (defined0 = !defined0) output.lineStart();
-					else output.lineEnd();
-				  }
-				  if (defined0) output.point(+x$$1(d, i, data), +y$$1(d, i, data));
-				}
-
-				if (buffer) return output = null, buffer + "" || null;
-			  }
-
-			  line.x = function(_) {
-				return arguments.length ? (x$$1 = typeof _ === "function" ? _ : constant$2(+_), line) : x$$1;
-			  };
-
-			  line.y = function(_) {
-				return arguments.length ? (y$$1 = typeof _ === "function" ? _ : constant$2(+_), line) : y$$1;
-			  };
-
-			  line.defined = function(_) {
-				return arguments.length ? (defined = typeof _ === "function" ? _ : constant$2(!!_), line) : defined;
-			  };
-
-			  line.curve = function(_) {
-				return arguments.length ? (curve = _, context != null && (output = curve(context)), line) : curve;
-			  };
-
-			  line.context = function(_) {
-				return arguments.length ? (_ == null ? context = output = null : output = curve(context = _), line) : context;
-			  };
-
-			  return line;
-			};
-
-			var area$1 = function() {
-			  var x0 = x,
-				  x1 = null,
-				  y0 = constant$2(0),
-				  y1 = y,
-				  defined = constant$2(true),
-				  context = null,
-				  curve = curveLinear,
-				  output = null;
-
-			  function area(data) {
-				var i,
-					j,
-					k,
-					n = data.length,
-					d,
-					defined0 = false,
-					buffer,
-					x0z = new Array(n),
-					y0z = new Array(n);
-
-				if (context == null) output = curve(buffer = path());
-
-				for (i = 0; i <= n; ++i) {
-				  if (!(i < n && defined(d = data[i], i, data)) === defined0) {
-					if (defined0 = !defined0) {
-					  j = i;
-					  output.areaStart();
-					  output.lineStart();
-					} else {
-					  output.lineEnd();
-					  output.lineStart();
-					  for (k = i - 1; k >= j; --k) {
-						output.point(x0z[k], y0z[k]);
-					  }
-					  output.lineEnd();
-					  output.areaEnd();
-					}
-				  }
-				  if (defined0) {
-					x0z[i] = +x0(d, i, data), y0z[i] = +y0(d, i, data);
-					output.point(x1 ? +x1(d, i, data) : x0z[i], y1 ? +y1(d, i, data) : y0z[i]);
-				  }
-				}
-
-				if (buffer) return output = null, buffer + "" || null;
-			  }
-
-			  function arealine() {
-				return line().defined(defined).curve(curve).context(context);
-			  }
-
-			  area.x = function(_) {
-				return arguments.length ? (x0 = typeof _ === "function" ? _ : constant$2(+_), x1 = null, area) : x0;
-			  };
-
-			  area.x0 = function(_) {
-				return arguments.length ? (x0 = typeof _ === "function" ? _ : constant$2(+_), area) : x0;
-			  };
-
-			  area.x1 = function(_) {
-				return arguments.length ? (x1 = _ == null ? null : typeof _ === "function" ? _ : constant$2(+_), area) : x1;
-			  };
-
-			  area.y = function(_) {
-				return arguments.length ? (y0 = typeof _ === "function" ? _ : constant$2(+_), y1 = null, area) : y0;
-			  };
-
-			  area.y0 = function(_) {
-				return arguments.length ? (y0 = typeof _ === "function" ? _ : constant$2(+_), area) : y0;
-			  };
-
-			  area.y1 = function(_) {
-				return arguments.length ? (y1 = _ == null ? null : typeof _ === "function" ? _ : constant$2(+_), area) : y1;
-			  };
-
-			  area.lineX0 =
-			  area.lineY0 = function() {
-				return arealine().x(x0).y(y0);
-			  };
-
-			  area.lineY1 = function() {
-				return arealine().x(x0).y(y1);
-			  };
-
-			  area.lineX1 = function() {
-				return arealine().x(x1).y(y0);
-			  };
-
-			  area.defined = function(_) {
-				return arguments.length ? (defined = typeof _ === "function" ? _ : constant$2(!!_), area) : defined;
-			  };
-
-			  area.curve = function(_) {
-				return arguments.length ? (curve = _, context != null && (output = curve(context)), area) : curve;
-			  };
-
-			  area.context = function(_) {
-				return arguments.length ? (_ == null ? context = output = null : output = curve(context = _), area) : context;
-			  };
-
-			  return area;
-			};
-
-			var descending$1 = function(a, b) {
-			  return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;
-			};
-
-			var identity$1 = function(d) {
-			  return d;
-			};
-
-			var pie = function() {
-			  var value = identity$1,
-				  sortValues = descending$1,
-				  sort = null,
-				  startAngle = constant$2(0),
-				  endAngle = constant$2(tau$2),
-				  padAngle = constant$2(0);
-
-			  function pie(data) {
-				var i,
-					n = data.length,
-					j,
-					k,
-					sum = 0,
-					index = new Array(n),
-					arcs = new Array(n),
-					a0 = +startAngle.apply(this, arguments),
-					da = Math.min(tau$2, Math.max(-tau$2, endAngle.apply(this, arguments) - a0)),
-					a1,
-					p = Math.min(Math.abs(da) / n, padAngle.apply(this, arguments)),
-					pa = p * (da < 0 ? -1 : 1),
-					v;
-
-				for (i = 0; i < n; ++i) {
-				  if ((v = arcs[index[i] = i] = +value(data[i], i, data)) > 0) {
-					sum += v;
-				  }
-				}
-
-				// Optionally sort the arcs by previously-computed values or by data.
-				if (sortValues != null) index.sort(function(i, j) { return sortValues(arcs[i], arcs[j]); });
-				else if (sort != null) index.sort(function(i, j) { return sort(data[i], data[j]); });
-
-				// Compute the arcs! They are stored in the original data's order.
-				for (i = 0, k = sum ? (da - n * pa) / sum : 0; i < n; ++i, a0 = a1) {
-				  j = index[i], v = arcs[j], a1 = a0 + (v > 0 ? v * k : 0) + pa, arcs[j] = {
-					data: data[j],
-					index: i,
-					value: v,
-					startAngle: a0,
-					endAngle: a1,
-					padAngle: p
-				  };
-				}
-
-				return arcs;
-			  }
-
-			  pie.value = function(_) {
-				return arguments.length ? (value = typeof _ === "function" ? _ : constant$2(+_), pie) : value;
-			  };
-
-			  pie.sortValues = function(_) {
-				return arguments.length ? (sortValues = _, sort = null, pie) : sortValues;
-			  };
-
-			  pie.sort = function(_) {
-				return arguments.length ? (sort = _, sortValues = null, pie) : sort;
-			  };
-
-			  pie.startAngle = function(_) {
-				return arguments.length ? (startAngle = typeof _ === "function" ? _ : constant$2(+_), pie) : startAngle;
-			  };
-
-			  pie.endAngle = function(_) {
-				return arguments.length ? (endAngle = typeof _ === "function" ? _ : constant$2(+_), pie) : endAngle;
-			  };
-
-			  pie.padAngle = function(_) {
-				return arguments.length ? (padAngle = typeof _ === "function" ? _ : constant$2(+_), pie) : padAngle;
-			  };
-
-			  return pie;
-			};
-
-			var curveRadialLinear = curveRadial(curveLinear);
-
-			function Radial(curve) {
-			  this._curve = curve;
-			}
-
-			Radial.prototype = {
-			  areaStart: function() {
-				this._curve.areaStart();
-			  },
-			  areaEnd: function() {
-				this._curve.areaEnd();
-			  },
-			  lineStart: function() {
-				this._curve.lineStart();
-			  },
-			  lineEnd: function() {
-				this._curve.lineEnd();
-			  },
-			  point: function(a, r) {
-				this._curve.point(r * Math.sin(a), r * -Math.cos(a));
-			  }
-			};
-
-			function curveRadial(curve) {
-
-			  function radial(context) {
-				return new Radial(curve(context));
-			  }
-
-			  radial._curve = curve;
-
-			  return radial;
-			}
-
-			function radialLine(l) {
-			  var c = l.curve;
-
-			  l.angle = l.x, delete l.x;
-			  l.radius = l.y, delete l.y;
-
-			  l.curve = function(_) {
-				return arguments.length ? c(curveRadial(_)) : c()._curve;
-			  };
-
-			  return l;
-			}
-
-			var radialLine$1 = function() {
-			  return radialLine(line().curve(curveRadialLinear));
-			};
-
-			var radialArea = function() {
-			  var a = area$1().curve(curveRadialLinear),
-				  c = a.curve,
-				  x0 = a.lineX0,
-				  x1 = a.lineX1,
-				  y0 = a.lineY0,
-				  y1 = a.lineY1;
-
-			  a.angle = a.x, delete a.x;
-			  a.startAngle = a.x0, delete a.x0;
-			  a.endAngle = a.x1, delete a.x1;
-			  a.radius = a.y, delete a.y;
-			  a.innerRadius = a.y0, delete a.y0;
-			  a.outerRadius = a.y1, delete a.y1;
-			  a.lineStartAngle = function() { return radialLine(x0()); }, delete a.lineX0;
-			  a.lineEndAngle = function() { return radialLine(x1()); }, delete a.lineX1;
-			  a.lineInnerRadius = function() { return radialLine(y0()); }, delete a.lineY0;
-			  a.lineOuterRadius = function() { return radialLine(y1()); }, delete a.lineY1;
-
-			  a.curve = function(_) {
-				return arguments.length ? c(curveRadial(_)) : c()._curve;
-			  };
-
-			  return a;
-			};
-
-			var circle = {
-			  draw: function(context, size) {
-				var r = Math.sqrt(size / pi$2);
-				context.moveTo(r, 0);
-				context.arc(0, 0, r, 0, tau$2);
-			  }
-			};
-
-			var cross$1 = {
-			  draw: function(context, size) {
-				var r = Math.sqrt(size / 5) / 2;
-				context.moveTo(-3 * r, -r);
-				context.lineTo(-r, -r);
-				context.lineTo(-r, -3 * r);
-				context.lineTo(r, -3 * r);
-				context.lineTo(r, -r);
-				context.lineTo(3 * r, -r);
-				context.lineTo(3 * r, r);
-				context.lineTo(r, r);
-				context.lineTo(r, 3 * r);
-				context.lineTo(-r, 3 * r);
-				context.lineTo(-r, r);
-				context.lineTo(-3 * r, r);
-				context.closePath();
-			  }
-			};
-
-			var tan30 = Math.sqrt(1 / 3);
-			var tan30_2 = tan30 * 2;
-
-			var diamond = {
-			  draw: function(context, size) {
-				var y = Math.sqrt(size / tan30_2),
-					x = y * tan30;
-				context.moveTo(0, -y);
-				context.lineTo(x, 0);
-				context.lineTo(0, y);
-				context.lineTo(-x, 0);
-				context.closePath();
-			  }
-			};
-
-			var ka = 0.89081309152928522810;
-			var kr = Math.sin(pi$2 / 10) / Math.sin(7 * pi$2 / 10);
-			var kx = Math.sin(tau$2 / 10) * kr;
-			var ky = -Math.cos(tau$2 / 10) * kr;
-
-			var star = {
-			  draw: function(context, size) {
-				var r = Math.sqrt(size * ka),
-					x = kx * r,
-					y = ky * r;
-				context.moveTo(0, -r);
-				context.lineTo(x, y);
-				for (var i = 1; i < 5; ++i) {
-				  var a = tau$2 * i / 5,
-					  c = Math.cos(a),
-					  s = Math.sin(a);
-				  context.lineTo(s * r, -c * r);
-				  context.lineTo(c * x - s * y, s * x + c * y);
-				}
-				context.closePath();
-			  }
-			};
-
-			var square = {
-			  draw: function(context, size) {
-				var w = Math.sqrt(size),
-					x = -w / 2;
-				context.rect(x, x, w, w);
-			  }
-			};
-
-			var sqrt3 = Math.sqrt(3);
-
-			var triangle = {
-			  draw: function(context, size) {
-				var y = -Math.sqrt(size / (sqrt3 * 3));
-				context.moveTo(0, y * 2);
-				context.lineTo(-sqrt3 * y, -y);
-				context.lineTo(sqrt3 * y, -y);
-				context.closePath();
-			  }
-			};
-
-			var c = -0.5;
-			var s = Math.sqrt(3) / 2;
-			var k = 1 / Math.sqrt(12);
-			var a = (k / 2 + 1) * 3;
-
-			var wye = {
-			  draw: function(context, size) {
-				var r = Math.sqrt(size / a),
-					x0 = r / 2,
-					y0 = r * k,
-					x1 = x0,
-					y1 = r * k + r,
-					x2 = -x1,
-					y2 = y1;
-				context.moveTo(x0, y0);
-				context.lineTo(x1, y1);
-				context.lineTo(x2, y2);
-				context.lineTo(c * x0 - s * y0, s * x0 + c * y0);
-				context.lineTo(c * x1 - s * y1, s * x1 + c * y1);
-				context.lineTo(c * x2 - s * y2, s * x2 + c * y2);
-				context.lineTo(c * x0 + s * y0, c * y0 - s * x0);
-				context.lineTo(c * x1 + s * y1, c * y1 - s * x1);
-				context.lineTo(c * x2 + s * y2, c * y2 - s * x2);
-				context.closePath();
-			  }
-			};
-
-			var symbols = [
-			  circle,
-			  cross$1,
-			  diamond,
-			  square,
-			  star,
-			  triangle,
-			  wye
-			];
-
-			var symbol = function() {
-			  var type = constant$2(circle),
-				  size = constant$2(64),
-				  context = null;
-
-			  function symbol() {
-				var buffer;
-				if (!context) context = buffer = path();
-				type.apply(this, arguments).draw(context, +size.apply(this, arguments));
-				if (buffer) return context = null, buffer + "" || null;
-			  }
-
-			  symbol.type = function(_) {
-				return arguments.length ? (type = typeof _ === "function" ? _ : constant$2(_), symbol) : type;
-			  };
-
-			  symbol.size = function(_) {
-				return arguments.length ? (size = typeof _ === "function" ? _ : constant$2(+_), symbol) : size;
-			  };
-
-			  symbol.context = function(_) {
-				return arguments.length ? (context = _ == null ? null : _, symbol) : context;
-			  };
-
-			  return symbol;
-			};
-
-			var noop = function() {};
-
-			function point(that, x, y) {
-			  that._context.bezierCurveTo(
-				(2 * that._x0 + that._x1) / 3,
-				(2 * that._y0 + that._y1) / 3,
-				(that._x0 + 2 * that._x1) / 3,
-				(that._y0 + 2 * that._y1) / 3,
-				(that._x0 + 4 * that._x1 + x) / 6,
-				(that._y0 + 4 * that._y1 + y) / 6
-			  );
-			}
-
-			function Basis(context) {
-			  this._context = context;
-			}
-
-			Basis.prototype = {
-			  areaStart: function() {
-				this._line = 0;
-			  },
-			  areaEnd: function() {
-				this._line = NaN;
-			  },
-			  lineStart: function() {
-				this._x0 = this._x1 =
-				this._y0 = this._y1 = NaN;
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				switch (this._point) {
-				  case 3: point(this, this._x1, this._y1); // proceed
-				  case 2: this._context.lineTo(this._x1, this._y1); break;
-				}
-				if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();
-				this._line = 1 - this._line;
-			  },
-			  point: function(x, y) {
-				x = +x, y = +y;
-				switch (this._point) {
-				  case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;
-				  case 1: this._point = 2; break;
-				  case 2: this._point = 3; this._context.lineTo((5 * this._x0 + this._x1) / 6, (5 * this._y0 + this._y1) / 6); // proceed
-				  default: point(this, x, y); break;
-				}
-				this._x0 = this._x1, this._x1 = x;
-				this._y0 = this._y1, this._y1 = y;
-			  }
-			};
-
-			var basis = function(context) {
-			  return new Basis(context);
-			};
-
-			function BasisClosed(context) {
-			  this._context = context;
-			}
-
-			BasisClosed.prototype = {
-			  areaStart: noop,
-			  areaEnd: noop,
-			  lineStart: function() {
-				this._x0 = this._x1 = this._x2 = this._x3 = this._x4 =
-				this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = NaN;
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				switch (this._point) {
-				  case 1: {
-					this._context.moveTo(this._x2, this._y2);
-					this._context.closePath();
-					break;
-				  }
-				  case 2: {
-					this._context.moveTo((this._x2 + 2 * this._x3) / 3, (this._y2 + 2 * this._y3) / 3);
-					this._context.lineTo((this._x3 + 2 * this._x2) / 3, (this._y3 + 2 * this._y2) / 3);
-					this._context.closePath();
-					break;
-				  }
-				  case 3: {
-					this.point(this._x2, this._y2);
-					this.point(this._x3, this._y3);
-					this.point(this._x4, this._y4);
-					break;
-				  }
-				}
-			  },
-			  point: function(x, y) {
-				x = +x, y = +y;
-				switch (this._point) {
-				  case 0: this._point = 1; this._x2 = x, this._y2 = y; break;
-				  case 1: this._point = 2; this._x3 = x, this._y3 = y; break;
-				  case 2: this._point = 3; this._x4 = x, this._y4 = y; this._context.moveTo((this._x0 + 4 * this._x1 + x) / 6, (this._y0 + 4 * this._y1 + y) / 6); break;
-				  default: point(this, x, y); break;
-				}
-				this._x0 = this._x1, this._x1 = x;
-				this._y0 = this._y1, this._y1 = y;
-			  }
-			};
-
-			var basisClosed = function(context) {
-			  return new BasisClosed(context);
-			};
-
-			function BasisOpen(context) {
-			  this._context = context;
-			}
-
-			BasisOpen.prototype = {
-			  areaStart: function() {
-				this._line = 0;
-			  },
-			  areaEnd: function() {
-				this._line = NaN;
-			  },
-			  lineStart: function() {
-				this._x0 = this._x1 =
-				this._y0 = this._y1 = NaN;
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();
-				this._line = 1 - this._line;
-			  },
-			  point: function(x, y) {
-				x = +x, y = +y;
-				switch (this._point) {
-				  case 0: this._point = 1; break;
-				  case 1: this._point = 2; break;
-				  case 2: this._point = 3; var x0 = (this._x0 + 4 * this._x1 + x) / 6, y0 = (this._y0 + 4 * this._y1 + y) / 6; this._line ? this._context.lineTo(x0, y0) : this._context.moveTo(x0, y0); break;
-				  case 3: this._point = 4; // proceed
-				  default: point(this, x, y); break;
-				}
-				this._x0 = this._x1, this._x1 = x;
-				this._y0 = this._y1, this._y1 = y;
-			  }
-			};
-
-			var basisOpen = function(context) {
-			  return new BasisOpen(context);
-			};
-
-			function Bundle(context, beta) {
-			  this._basis = new Basis(context);
-			  this._beta = beta;
-			}
-
-			Bundle.prototype = {
-			  lineStart: function() {
-				this._x = [];
-				this._y = [];
-				this._basis.lineStart();
-			  },
-			  lineEnd: function() {
-				var x = this._x,
-					y = this._y,
-					j = x.length - 1;
-
-				if (j > 0) {
-				  var x0 = x[0],
-					  y0 = y[0],
-					  dx = x[j] - x0,
-					  dy = y[j] - y0,
-					  i = -1,
-					  t;
-
-				  while (++i <= j) {
-					t = i / j;
-					this._basis.point(
-					  this._beta * x[i] + (1 - this._beta) * (x0 + t * dx),
-					  this._beta * y[i] + (1 - this._beta) * (y0 + t * dy)
-					);
-				  }
-				}
-
-				this._x = this._y = null;
-				this._basis.lineEnd();
-			  },
-			  point: function(x, y) {
-				this._x.push(+x);
-				this._y.push(+y);
-			  }
-			};
-
-			var bundle = (function custom(beta) {
-
-			  function bundle(context) {
-				return beta === 1 ? new Basis(context) : new Bundle(context, beta);
-			  }
-
-			  bundle.beta = function(beta) {
-				return custom(+beta);
-			  };
-
-			  return bundle;
-			})(0.85);
-
-			function point$1(that, x, y) {
-			  that._context.bezierCurveTo(
-				that._x1 + that._k * (that._x2 - that._x0),
-				that._y1 + that._k * (that._y2 - that._y0),
-				that._x2 + that._k * (that._x1 - x),
-				that._y2 + that._k * (that._y1 - y),
-				that._x2,
-				that._y2
-			  );
-			}
-
-			function Cardinal(context, tension) {
-			  this._context = context;
-			  this._k = (1 - tension) / 6;
-			}
-
-			Cardinal.prototype = {
-			  areaStart: function() {
-				this._line = 0;
-			  },
-			  areaEnd: function() {
-				this._line = NaN;
-			  },
-			  lineStart: function() {
-				this._x0 = this._x1 = this._x2 =
-				this._y0 = this._y1 = this._y2 = NaN;
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				switch (this._point) {
-				  case 2: this._context.lineTo(this._x2, this._y2); break;
-				  case 3: point$1(this, this._x1, this._y1); break;
-				}
-				if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();
-				this._line = 1 - this._line;
-			  },
-			  point: function(x, y) {
-				x = +x, y = +y;
-				switch (this._point) {
-				  case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;
-				  case 1: this._point = 2; this._x1 = x, this._y1 = y; break;
-				  case 2: this._point = 3; // proceed
-				  default: point$1(this, x, y); break;
-				}
-				this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;
-				this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;
-			  }
-			};
-
-			var cardinal = (function custom(tension) {
-
-			  function cardinal(context) {
-				return new Cardinal(context, tension);
-			  }
-
-			  cardinal.tension = function(tension) {
-				return custom(+tension);
-			  };
-
-			  return cardinal;
-			})(0);
-
-			function CardinalClosed(context, tension) {
-			  this._context = context;
-			  this._k = (1 - tension) / 6;
-			}
-
-			CardinalClosed.prototype = {
-			  areaStart: noop,
-			  areaEnd: noop,
-			  lineStart: function() {
-				this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =
-				this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				switch (this._point) {
-				  case 1: {
-					this._context.moveTo(this._x3, this._y3);
-					this._context.closePath();
-					break;
-				  }
-				  case 2: {
-					this._context.lineTo(this._x3, this._y3);
-					this._context.closePath();
-					break;
-				  }
-				  case 3: {
-					this.point(this._x3, this._y3);
-					this.point(this._x4, this._y4);
-					this.point(this._x5, this._y5);
-					break;
-				  }
-				}
-			  },
-			  point: function(x, y) {
-				x = +x, y = +y;
-				switch (this._point) {
-				  case 0: this._point = 1; this._x3 = x, this._y3 = y; break;
-				  case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;
-				  case 2: this._point = 3; this._x5 = x, this._y5 = y; break;
-				  default: point$1(this, x, y); break;
-				}
-				this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;
-				this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;
-			  }
-			};
-
-			var cardinalClosed = (function custom(tension) {
-
-			  function cardinal(context) {
-				return new CardinalClosed(context, tension);
-			  }
-
-			  cardinal.tension = function(tension) {
-				return custom(+tension);
-			  };
-
-			  return cardinal;
-			})(0);
-
-			function CardinalOpen(context, tension) {
-			  this._context = context;
-			  this._k = (1 - tension) / 6;
-			}
-
-			CardinalOpen.prototype = {
-			  areaStart: function() {
-				this._line = 0;
-			  },
-			  areaEnd: function() {
-				this._line = NaN;
-			  },
-			  lineStart: function() {
-				this._x0 = this._x1 = this._x2 =
-				this._y0 = this._y1 = this._y2 = NaN;
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();
-				this._line = 1 - this._line;
-			  },
-			  point: function(x, y) {
-				x = +x, y = +y;
-				switch (this._point) {
-				  case 0: this._point = 1; break;
-				  case 1: this._point = 2; break;
-				  case 2: this._point = 3; this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); break;
-				  case 3: this._point = 4; // proceed
-				  default: point$1(this, x, y); break;
-				}
-				this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;
-				this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;
-			  }
-			};
-
-			var cardinalOpen = (function custom(tension) {
-
-			  function cardinal(context) {
-				return new CardinalOpen(context, tension);
-			  }
-
-			  cardinal.tension = function(tension) {
-				return custom(+tension);
-			  };
-
-			  return cardinal;
-			})(0);
-
-			function point$2(that, x, y) {
-			  var x1 = that._x1,
-				  y1 = that._y1,
-				  x2 = that._x2,
-				  y2 = that._y2;
-
-			  if (that._l01_a > epsilon$1) {
-				var a = 2 * that._l01_2a + 3 * that._l01_a * that._l12_a + that._l12_2a,
-					n = 3 * that._l01_a * (that._l01_a + that._l12_a);
-				x1 = (x1 * a - that._x0 * that._l12_2a + that._x2 * that._l01_2a) / n;
-				y1 = (y1 * a - that._y0 * that._l12_2a + that._y2 * that._l01_2a) / n;
-			  }
-
-			  if (that._l23_a > epsilon$1) {
-				var b = 2 * that._l23_2a + 3 * that._l23_a * that._l12_a + that._l12_2a,
-					m = 3 * that._l23_a * (that._l23_a + that._l12_a);
-				x2 = (x2 * b + that._x1 * that._l23_2a - x * that._l12_2a) / m;
-				y2 = (y2 * b + that._y1 * that._l23_2a - y * that._l12_2a) / m;
-			  }
-
-			  that._context.bezierCurveTo(x1, y1, x2, y2, that._x2, that._y2);
-			}
-
-			function CatmullRom(context, alpha) {
-			  this._context = context;
-			  this._alpha = alpha;
-			}
-
-			CatmullRom.prototype = {
-			  areaStart: function() {
-				this._line = 0;
-			  },
-			  areaEnd: function() {
-				this._line = NaN;
-			  },
-			  lineStart: function() {
-				this._x0 = this._x1 = this._x2 =
-				this._y0 = this._y1 = this._y2 = NaN;
-				this._l01_a = this._l12_a = this._l23_a =
-				this._l01_2a = this._l12_2a = this._l23_2a =
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				switch (this._point) {
-				  case 2: this._context.lineTo(this._x2, this._y2); break;
-				  case 3: this.point(this._x2, this._y2); break;
-				}
-				if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();
-				this._line = 1 - this._line;
-			  },
-			  point: function(x, y) {
-				x = +x, y = +y;
-
-				if (this._point) {
-				  var x23 = this._x2 - x,
-					  y23 = this._y2 - y;
-				  this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));
-				}
-
-				switch (this._point) {
-				  case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;
-				  case 1: this._point = 2; break;
-				  case 2: this._point = 3; // proceed
-				  default: point$2(this, x, y); break;
-				}
-
-				this._l01_a = this._l12_a, this._l12_a = this._l23_a;
-				this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;
-				this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;
-				this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;
-			  }
-			};
-
-			var catmullRom = (function custom(alpha) {
-
-			  function catmullRom(context) {
-				return alpha ? new CatmullRom(context, alpha) : new Cardinal(context, 0);
-			  }
-
-			  catmullRom.alpha = function(alpha) {
-				return custom(+alpha);
-			  };
-
-			  return catmullRom;
-			})(0.5);
-
-			function CatmullRomClosed(context, alpha) {
-			  this._context = context;
-			  this._alpha = alpha;
-			}
-
-			CatmullRomClosed.prototype = {
-			  areaStart: noop,
-			  areaEnd: noop,
-			  lineStart: function() {
-				this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =
-				this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;
-				this._l01_a = this._l12_a = this._l23_a =
-				this._l01_2a = this._l12_2a = this._l23_2a =
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				switch (this._point) {
-				  case 1: {
-					this._context.moveTo(this._x3, this._y3);
-					this._context.closePath();
-					break;
-				  }
-				  case 2: {
-					this._context.lineTo(this._x3, this._y3);
-					this._context.closePath();
-					break;
-				  }
-				  case 3: {
-					this.point(this._x3, this._y3);
-					this.point(this._x4, this._y4);
-					this.point(this._x5, this._y5);
-					break;
-				  }
-				}
-			  },
-			  point: function(x, y) {
-				x = +x, y = +y;
-
-				if (this._point) {
-				  var x23 = this._x2 - x,
-					  y23 = this._y2 - y;
-				  this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));
-				}
-
-				switch (this._point) {
-				  case 0: this._point = 1; this._x3 = x, this._y3 = y; break;
-				  case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;
-				  case 2: this._point = 3; this._x5 = x, this._y5 = y; break;
-				  default: point$2(this, x, y); break;
-				}
-
-				this._l01_a = this._l12_a, this._l12_a = this._l23_a;
-				this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;
-				this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;
-				this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;
-			  }
-			};
-
-			var catmullRomClosed = (function custom(alpha) {
-
-			  function catmullRom(context) {
-				return alpha ? new CatmullRomClosed(context, alpha) : new CardinalClosed(context, 0);
-			  }
-
-			  catmullRom.alpha = function(alpha) {
-				return custom(+alpha);
-			  };
-
-			  return catmullRom;
-			})(0.5);
-
-			function CatmullRomOpen(context, alpha) {
-			  this._context = context;
-			  this._alpha = alpha;
-			}
-
-			CatmullRomOpen.prototype = {
-			  areaStart: function() {
-				this._line = 0;
-			  },
-			  areaEnd: function() {
-				this._line = NaN;
-			  },
-			  lineStart: function() {
-				this._x0 = this._x1 = this._x2 =
-				this._y0 = this._y1 = this._y2 = NaN;
-				this._l01_a = this._l12_a = this._l23_a =
-				this._l01_2a = this._l12_2a = this._l23_2a =
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();
-				this._line = 1 - this._line;
-			  },
-			  point: function(x, y) {
-				x = +x, y = +y;
-
-				if (this._point) {
-				  var x23 = this._x2 - x,
-					  y23 = this._y2 - y;
-				  this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));
-				}
-
-				switch (this._point) {
-				  case 0: this._point = 1; break;
-				  case 1: this._point = 2; break;
-				  case 2: this._point = 3; this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); break;
-				  case 3: this._point = 4; // proceed
-				  default: point$2(this, x, y); break;
-				}
-
-				this._l01_a = this._l12_a, this._l12_a = this._l23_a;
-				this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;
-				this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;
-				this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;
-			  }
-			};
-
-			var catmullRomOpen = (function custom(alpha) {
-
-			  function catmullRom(context) {
-				return alpha ? new CatmullRomOpen(context, alpha) : new CardinalOpen(context, 0);
-			  }
-
-			  catmullRom.alpha = function(alpha) {
-				return custom(+alpha);
-			  };
-
-			  return catmullRom;
-			})(0.5);
-
-			function LinearClosed(context) {
-			  this._context = context;
-			}
-
-			LinearClosed.prototype = {
-			  areaStart: noop,
-			  areaEnd: noop,
-			  lineStart: function() {
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				if (this._point) this._context.closePath();
-			  },
-			  point: function(x, y) {
-				x = +x, y = +y;
-				if (this._point) this._context.lineTo(x, y);
-				else this._point = 1, this._context.moveTo(x, y);
-			  }
-			};
-
-			var linearClosed = function(context) {
-			  return new LinearClosed(context);
-			};
-
-			function sign(x) {
-			  return x < 0 ? -1 : 1;
-			}
-
-			// Calculate the slopes of the tangents (Hermite-type interpolation) based on
-			// the following paper: Steffen, M. 1990. A Simple Method for Monotonic
-			// Interpolation in One Dimension. Astronomy and Astrophysics, Vol. 239, NO.
-			// NOV(II), P. 443, 1990.
-			function slope3(that, x2, y2) {
-			  var h0 = that._x1 - that._x0,
-				  h1 = x2 - that._x1,
-				  s0 = (that._y1 - that._y0) / (h0 || h1 < 0 && -0),
-				  s1 = (y2 - that._y1) / (h1 || h0 < 0 && -0),
-				  p = (s0 * h1 + s1 * h0) / (h0 + h1);
-			  return (sign(s0) + sign(s1)) * Math.min(Math.abs(s0), Math.abs(s1), 0.5 * Math.abs(p)) || 0;
-			}
-
-			// Calculate a one-sided slope.
-			function slope2(that, t) {
-			  var h = that._x1 - that._x0;
-			  return h ? (3 * (that._y1 - that._y0) / h - t) / 2 : t;
-			}
-
-			// According to https://en.wikipedia.org/wiki/Cubic_Hermite_spline#Representations
-			// "you can express cubic Hermite interpolation in terms of cubic Bézier curves
-			// with respect to the four values p0, p0 + m0 / 3, p1 - m1 / 3, p1".
-			function point$3(that, t0, t1) {
-			  var x0 = that._x0,
-				  y0 = that._y0,
-				  x1 = that._x1,
-				  y1 = that._y1,
-				  dx = (x1 - x0) / 3;
-			  that._context.bezierCurveTo(x0 + dx, y0 + dx * t0, x1 - dx, y1 - dx * t1, x1, y1);
-			}
-
-			function MonotoneX(context) {
-			  this._context = context;
-			}
-
-			MonotoneX.prototype = {
-			  areaStart: function() {
-				this._line = 0;
-			  },
-			  areaEnd: function() {
-				this._line = NaN;
-			  },
-			  lineStart: function() {
-				this._x0 = this._x1 =
-				this._y0 = this._y1 =
-				this._t0 = NaN;
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				switch (this._point) {
-				  case 2: this._context.lineTo(this._x1, this._y1); break;
-				  case 3: point$3(this, this._t0, slope2(this, this._t0)); break;
-				}
-				if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();
-				this._line = 1 - this._line;
-			  },
-			  point: function(x, y) {
-				var t1 = NaN;
-
-				x = +x, y = +y;
-				if (x === this._x1 && y === this._y1) return; // Ignore coincident points.
-				switch (this._point) {
-				  case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;
-				  case 1: this._point = 2; break;
-				  case 2: this._point = 3; point$3(this, slope2(this, t1 = slope3(this, x, y)), t1); break;
-				  default: point$3(this, this._t0, t1 = slope3(this, x, y)); break;
-				}
-
-				this._x0 = this._x1, this._x1 = x;
-				this._y0 = this._y1, this._y1 = y;
-				this._t0 = t1;
-			  }
-			};
-
-			function MonotoneY(context) {
-			  this._context = new ReflectContext(context);
-			}
-
-			(MonotoneY.prototype = Object.create(MonotoneX.prototype)).point = function(x, y) {
-			  MonotoneX.prototype.point.call(this, y, x);
-			};
-
-			function ReflectContext(context) {
-			  this._context = context;
-			}
-
-			ReflectContext.prototype = {
-			  moveTo: function(x, y) { this._context.moveTo(y, x); },
-			  closePath: function() { this._context.closePath(); },
-			  lineTo: function(x, y) { this._context.lineTo(y, x); },
-			  bezierCurveTo: function(x1, y1, x2, y2, x, y) { this._context.bezierCurveTo(y1, x1, y2, x2, y, x); }
-			};
-
-			function monotoneX(context) {
-			  return new MonotoneX(context);
-			}
-
-			function monotoneY(context) {
-			  return new MonotoneY(context);
-			}
-
-			function Natural(context) {
-			  this._context = context;
-			}
-
-			Natural.prototype = {
-			  areaStart: function() {
-				this._line = 0;
-			  },
-			  areaEnd: function() {
-				this._line = NaN;
-			  },
-			  lineStart: function() {
-				this._x = [];
-				this._y = [];
-			  },
-			  lineEnd: function() {
-				var x = this._x,
-					y = this._y,
-					n = x.length;
-
-				if (n) {
-				  this._line ? this._context.lineTo(x[0], y[0]) : this._context.moveTo(x[0], y[0]);
-				  if (n === 2) {
-					this._context.lineTo(x[1], y[1]);
-				  } else {
-					var px = controlPoints(x),
-						py = controlPoints(y);
-					for (var i0 = 0, i1 = 1; i1 < n; ++i0, ++i1) {
-					  this._context.bezierCurveTo(px[0][i0], py[0][i0], px[1][i0], py[1][i0], x[i1], y[i1]);
-					}
-				  }
-				}
-
-				if (this._line || (this._line !== 0 && n === 1)) this._context.closePath();
-				this._line = 1 - this._line;
-				this._x = this._y = null;
-			  },
-			  point: function(x, y) {
-				this._x.push(+x);
-				this._y.push(+y);
-			  }
-			};
-
-			// See https://www.particleincell.com/2012/bezier-splines/ for derivation.
-			function controlPoints(x) {
-			  var i,
-				  n = x.length - 1,
-				  m,
-				  a = new Array(n),
-				  b = new Array(n),
-				  r = new Array(n);
-			  a[0] = 0, b[0] = 2, r[0] = x[0] + 2 * x[1];
-			  for (i = 1; i < n - 1; ++i) a[i] = 1, b[i] = 4, r[i] = 4 * x[i] + 2 * x[i + 1];
-			  a[n - 1] = 2, b[n - 1] = 7, r[n - 1] = 8 * x[n - 1] + x[n];
-			  for (i = 1; i < n; ++i) m = a[i] / b[i - 1], b[i] -= m, r[i] -= m * r[i - 1];
-			  a[n - 1] = r[n - 1] / b[n - 1];
-			  for (i = n - 2; i >= 0; --i) a[i] = (r[i] - a[i + 1]) / b[i];
-			  b[n - 1] = (x[n] + a[n - 1]) / 2;
-			  for (i = 0; i < n - 1; ++i) b[i] = 2 * x[i + 1] - a[i + 1];
-			  return [a, b];
-			}
-
-			var natural = function(context) {
-			  return new Natural(context);
-			};
-
-			function Step(context, t) {
-			  this._context = context;
-			  this._t = t;
-			}
-
-			Step.prototype = {
-			  areaStart: function() {
-				this._line = 0;
-			  },
-			  areaEnd: function() {
-				this._line = NaN;
-			  },
-			  lineStart: function() {
-				this._x = this._y = NaN;
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				if (0 < this._t && this._t < 1 && this._point === 2) this._context.lineTo(this._x, this._y);
-				if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();
-				if (this._line >= 0) this._t = 1 - this._t, this._line = 1 - this._line;
-			  },
-			  point: function(x, y) {
-				x = +x, y = +y;
-				switch (this._point) {
-				  case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;
-				  case 1: this._point = 2; // proceed
-				  default: {
-					if (this._t <= 0) {
-					  this._context.lineTo(this._x, y);
-					  this._context.lineTo(x, y);
-					} else {
-					  var x1 = this._x * (1 - this._t) + x * this._t;
-					  this._context.lineTo(x1, this._y);
-					  this._context.lineTo(x1, y);
-					}
-					break;
-				  }
-				}
-				this._x = x, this._y = y;
-			  }
-			};
-
-			var step = function(context) {
-			  return new Step(context, 0.5);
-			};
-
-			function stepBefore(context) {
-			  return new Step(context, 0);
-			}
-
-			function stepAfter(context) {
-			  return new Step(context, 1);
-			}
-
-			var slice$2 = Array.prototype.slice;
-
-			var none = function(series, order) {
-			  if (!((n = series.length) > 1)) return;
-			  for (var i = 1, s0, s1 = series[order[0]], n, m = s1.length; i < n; ++i) {
-				s0 = s1, s1 = series[order[i]];
-				for (var j = 0; j < m; ++j) {
-				  s1[j][1] += s1[j][0] = isNaN(s0[j][1]) ? s0[j][0] : s0[j][1];
-				}
-			  }
-			};
-
-			var none$1 = function(series) {
-			  var n = series.length, o = new Array(n);
-			  while (--n >= 0) o[n] = n;
-			  return o;
-			};
-
-			function stackValue(d, key) {
-			  return d[key];
-			}
-
-			var stack = function() {
-			  var keys = constant$2([]),
-				  order = none$1,
-				  offset = none,
-				  value = stackValue;
-
-			  function stack(data) {
-				var kz = keys.apply(this, arguments),
-					i,
-					m = data.length,
-					n = kz.length,
-					sz = new Array(n),
-					oz;
-
-				for (i = 0; i < n; ++i) {
-				  for (var ki = kz[i], si = sz[i] = new Array(m), j = 0, sij; j < m; ++j) {
-					si[j] = sij = [0, +value(data[j], ki, j, data)];
-					sij.data = data[j];
-				  }
-				  si.key = ki;
-				}
-
-				for (i = 0, oz = order(sz); i < n; ++i) {
-				  sz[oz[i]].index = i;
-				}
-
-				offset(sz, oz);
-				return sz;
-			  }
-
-			  stack.keys = function(_) {
-				return arguments.length ? (keys = typeof _ === "function" ? _ : constant$2(slice$2.call(_)), stack) : keys;
-			  };
-
-			  stack.value = function(_) {
-				return arguments.length ? (value = typeof _ === "function" ? _ : constant$2(+_), stack) : value;
-			  };
-
-			  stack.order = function(_) {
-				return arguments.length ? (order = _ == null ? none$1 : typeof _ === "function" ? _ : constant$2(slice$2.call(_)), stack) : order;
-			  };
-
-			  stack.offset = function(_) {
-				return arguments.length ? (offset = _ == null ? none : _, stack) : offset;
-			  };
-
-			  return stack;
-			};
-
-			var expand = function(series, order) {
-			  if (!((n = series.length) > 0)) return;
-			  for (var i, n, j = 0, m = series[0].length, y; j < m; ++j) {
-				for (y = i = 0; i < n; ++i) y += series[i][j][1] || 0;
-				if (y) for (i = 0; i < n; ++i) series[i][j][1] /= y;
-			  }
-			  none(series, order);
-			};
-
-			var silhouette = function(series, order) {
-			  if (!((n = series.length) > 0)) return;
-			  for (var j = 0, s0 = series[order[0]], n, m = s0.length; j < m; ++j) {
-				for (var i = 0, y = 0; i < n; ++i) y += series[i][j][1] || 0;
-				s0[j][1] += s0[j][0] = -y / 2;
-			  }
-			  none(series, order);
-			};
-
-			var wiggle = function(series, order) {
-			  if (!((n = series.length) > 0) || !((m = (s0 = series[order[0]]).length) > 0)) return;
-			  for (var y = 0, j = 1, s0, m, n; j < m; ++j) {
-				for (var i = 0, s1 = 0, s2 = 0; i < n; ++i) {
-				  var si = series[order[i]],
-					  sij0 = si[j][1] || 0,
-					  sij1 = si[j - 1][1] || 0,
-					  s3 = (sij0 - sij1) / 2;
-				  for (var k = 0; k < i; ++k) {
-					var sk = series[order[k]],
-						skj0 = sk[j][1] || 0,
-						skj1 = sk[j - 1][1] || 0;
-					s3 += skj0 - skj1;
-				  }
-				  s1 += sij0, s2 += s3 * sij0;
-				}
-				s0[j - 1][1] += s0[j - 1][0] = y;
-				if (s1) y -= s2 / s1;
-			  }
-			  s0[j - 1][1] += s0[j - 1][0] = y;
-			  none(series, order);
-			};
-
-			var ascending$1 = function(series) {
-			  var sums = series.map(sum$1);
-			  return none$1(series).sort(function(a, b) { return sums[a] - sums[b]; });
-			};
-
-			function sum$1(series) {
-			  var s = 0, i = -1, n = series.length, v;
-			  while (++i < n) if (v = +series[i][1]) s += v;
-			  return s;
-			}
-
-			var descending$2 = function(series) {
-			  return ascending$1(series).reverse();
-			};
-
-			var insideOut = function(series) {
-			  var n = series.length,
-				  i,
-				  j,
-				  sums = series.map(sum$1),
-				  order = none$1(series).sort(function(a, b) { return sums[b] - sums[a]; }),
-				  top = 0,
-				  bottom = 0,
-				  tops = [],
-				  bottoms = [];
-
-			  for (i = 0; i < n; ++i) {
-				j = order[i];
-				if (top < bottom) {
-				  top += sums[j];
-				  tops.push(j);
-				} else {
-				  bottom += sums[j];
-				  bottoms.push(j);
-				}
-			  }
-
-			  return bottoms.reverse().concat(tops);
-			};
-
-			var reverse = function(series) {
-			  return none$1(series).reverse();
-			};
-
-			var define = function(constructor, factory, prototype) {
-			  constructor.prototype = factory.prototype = prototype;
-			  prototype.constructor = constructor;
-			};
-
-			function extend(parent, definition) {
-			  var prototype = Object.create(parent.prototype);
-			  for (var key in definition) prototype[key] = definition[key];
-			  return prototype;
-			}
-
-			function Color() {}
-
-			var darker = 0.7;
-			var brighter = 1 / darker;
-
-			var reHex3 = /^#([0-9a-f]{3})$/;
-			var reHex6 = /^#([0-9a-f]{6})$/;
-			var reRgbInteger = /^rgb\(\s*([-+]?\d+)\s*,\s*([-+]?\d+)\s*,\s*([-+]?\d+)\s*\)$/;
-			var reRgbPercent = /^rgb\(\s*([-+]?\d+(?:\.\d+)?)%\s*,\s*([-+]?\d+(?:\.\d+)?)%\s*,\s*([-+]?\d+(?:\.\d+)?)%\s*\)$/;
-			var reRgbaInteger = /^rgba\(\s*([-+]?\d+)\s*,\s*([-+]?\d+)\s*,\s*([-+]?\d+)\s*,\s*([-+]?\d+(?:\.\d+)?)\s*\)$/;
-			var reRgbaPercent = /^rgba\(\s*([-+]?\d+(?:\.\d+)?)%\s*,\s*([-+]?\d+(?:\.\d+)?)%\s*,\s*([-+]?\d+(?:\.\d+)?)%\s*,\s*([-+]?\d+(?:\.\d+)?)\s*\)$/;
-			var reHslPercent = /^hsl\(\s*([-+]?\d+(?:\.\d+)?)\s*,\s*([-+]?\d+(?:\.\d+)?)%\s*,\s*([-+]?\d+(?:\.\d+)?)%\s*\)$/;
-			var reHslaPercent = /^hsla\(\s*([-+]?\d+(?:\.\d+)?)\s*,\s*([-+]?\d+(?:\.\d+)?)%\s*,\s*([-+]?\d+(?:\.\d+)?)%\s*,\s*([-+]?\d+(?:\.\d+)?)\s*\)$/;
-
-			var named = {
-			  aliceblue: 0xf0f8ff,
-			  antiquewhite: 0xfaebd7,
-			  aqua: 0x00ffff,
-			  aquamarine: 0x7fffd4,
-			  azure: 0xf0ffff,
-			  beige: 0xf5f5dc,
-			  bisque: 0xffe4c4,
-			  black: 0x000000,
-			  blanchedalmond: 0xffebcd,
-			  blue: 0x0000ff,
-			  blueviolet: 0x8a2be2,
-			  brown: 0xa52a2a,
-			  burlywood: 0xdeb887,
-			  cadetblue: 0x5f9ea0,
-			  chartreuse: 0x7fff00,
-			  chocolate: 0xd2691e,
-			  coral: 0xff7f50,
-			  cornflowerblue: 0x6495ed,
-			  cornsilk: 0xfff8dc,
-			  crimson: 0xdc143c,
-			  cyan: 0x00ffff,
-			  darkblue: 0x00008b,
-			  darkcyan: 0x008b8b,
-			  darkgoldenrod: 0xb8860b,
-			  darkgray: 0xa9a9a9,
-			  darkgreen: 0x006400,
-			  darkgrey: 0xa9a9a9,
-			  darkkhaki: 0xbdb76b,
-			  darkmagenta: 0x8b008b,
-			  darkolivegreen: 0x556b2f,
-			  darkorange: 0xff8c00,
-			  darkorchid: 0x9932cc,
-			  darkred: 0x8b0000,
-			  darksalmon: 0xe9967a,
-			  darkseagreen: 0x8fbc8f,
-			  darkslateblue: 0x483d8b,
-			  darkslategray: 0x2f4f4f,
-			  darkslategrey: 0x2f4f4f,
-			  darkturquoise: 0x00ced1,
-			  darkviolet: 0x9400d3,
-			  deeppink: 0xff1493,
-			  deepskyblue: 0x00bfff,
-			  dimgray: 0x696969,
-			  dimgrey: 0x696969,
-			  dodgerblue: 0x1e90ff,
-			  firebrick: 0xb22222,
-			  floralwhite: 0xfffaf0,
-			  forestgreen: 0x228b22,
-			  fuchsia: 0xff00ff,
-			  gainsboro: 0xdcdcdc,
-			  ghostwhite: 0xf8f8ff,
-			  gold: 0xffd700,
-			  goldenrod: 0xdaa520,
-			  gray: 0x808080,
-			  green: 0x008000,
-			  greenyellow: 0xadff2f,
-			  grey: 0x808080,
-			  honeydew: 0xf0fff0,
-			  hotpink: 0xff69b4,
-			  indianred: 0xcd5c5c,
-			  indigo: 0x4b0082,
-			  ivory: 0xfffff0,
-			  khaki: 0xf0e68c,
-			  lavender: 0xe6e6fa,
-			  lavenderblush: 0xfff0f5,
-			  lawngreen: 0x7cfc00,
-			  lemonchiffon: 0xfffacd,
-			  lightblue: 0xadd8e6,
-			  lightcoral: 0xf08080,
-			  lightcyan: 0xe0ffff,
-			  lightgoldenrodyellow: 0xfafad2,
-			  lightgray: 0xd3d3d3,
-			  lightgreen: 0x90ee90,
-			  lightgrey: 0xd3d3d3,
-			  lightpink: 0xffb6c1,
-			  lightsalmon: 0xffa07a,
-			  lightseagreen: 0x20b2aa,
-			  lightskyblue: 0x87cefa,
-			  lightslategray: 0x778899,
-			  lightslategrey: 0x778899,
-			  lightsteelblue: 0xb0c4de,
-			  lightyellow: 0xffffe0,
-			  lime: 0x00ff00,
-			  limegreen: 0x32cd32,
-			  linen: 0xfaf0e6,
-			  magenta: 0xff00ff,
-			  maroon: 0x800000,
-			  mediumaquamarine: 0x66cdaa,
-			  mediumblue: 0x0000cd,
-			  mediumorchid: 0xba55d3,
-			  mediumpurple: 0x9370db,
-			  mediumseagreen: 0x3cb371,
-			  mediumslateblue: 0x7b68ee,
-			  mediumspringgreen: 0x00fa9a,
-			  mediumturquoise: 0x48d1cc,
-			  mediumvioletred: 0xc71585,
-			  midnightblue: 0x191970,
-			  mintcream: 0xf5fffa,
-			  mistyrose: 0xffe4e1,
-			  moccasin: 0xffe4b5,
-			  navajowhite: 0xffdead,
-			  navy: 0x000080,
-			  oldlace: 0xfdf5e6,
-			  olive: 0x808000,
-			  olivedrab: 0x6b8e23,
-			  orange: 0xffa500,
-			  orangered: 0xff4500,
-			  orchid: 0xda70d6,
-			  palegoldenrod: 0xeee8aa,
-			  palegreen: 0x98fb98,
-			  paleturquoise: 0xafeeee,
-			  palevioletred: 0xdb7093,
-			  papayawhip: 0xffefd5,
-			  peachpuff: 0xffdab9,
-			  peru: 0xcd853f,
-			  pink: 0xffc0cb,
-			  plum: 0xdda0dd,
-			  powderblue: 0xb0e0e6,
-			  purple: 0x800080,
-			  rebeccapurple: 0x663399,
-			  red: 0xff0000,
-			  rosybrown: 0xbc8f8f,
-			  royalblue: 0x4169e1,
-			  saddlebrown: 0x8b4513,
-			  salmon: 0xfa8072,
-			  sandybrown: 0xf4a460,
-			  seagreen: 0x2e8b57,
-			  seashell: 0xfff5ee,
-			  sienna: 0xa0522d,
-			  silver: 0xc0c0c0,
-			  skyblue: 0x87ceeb,
-			  slateblue: 0x6a5acd,
-			  slategray: 0x708090,
-			  slategrey: 0x708090,
-			  snow: 0xfffafa,
-			  springgreen: 0x00ff7f,
-			  steelblue: 0x4682b4,
-			  tan: 0xd2b48c,
-			  teal: 0x008080,
-			  thistle: 0xd8bfd8,
-			  tomato: 0xff6347,
-			  turquoise: 0x40e0d0,
-			  violet: 0xee82ee,
-			  wheat: 0xf5deb3,
-			  white: 0xffffff,
-			  whitesmoke: 0xf5f5f5,
-			  yellow: 0xffff00,
-			  yellowgreen: 0x9acd32
-			};
-
-			define(Color, color, {
-			  displayable: function() {
-				return this.rgb().displayable();
-			  },
-			  toString: function() {
-				return this.rgb() + "";
-			  }
-			});
-
-			function color(format) {
-			  var m;
-			  format = (format + "").trim().toLowerCase();
-			  return (m = reHex3.exec(format)) ? (m = parseInt(m[1], 16), new Rgb((m >> 8 & 0xf) | (m >> 4 & 0x0f0), (m >> 4 & 0xf) | (m & 0xf0), ((m & 0xf) << 4) | (m & 0xf), 1)) // #f00
-				  : (m = reHex6.exec(format)) ? rgbn(parseInt(m[1], 16)) // #ff0000
-				  : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)
-				  : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)
-				  : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)
-				  : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)
-				  : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)
-				  : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)
-				  : named.hasOwnProperty(format) ? rgbn(named[format])
-				  : format === "transparent" ? new Rgb(NaN, NaN, NaN, 0)
-				  : null;
-			}
-
-			function rgbn(n) {
-			  return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);
-			}
-
-			function rgba(r, g, b, a) {
-			  if (a <= 0) r = g = b = NaN;
-			  return new Rgb(r, g, b, a);
-			}
-
-			function rgbConvert(o) {
-			  if (!(o instanceof Color)) o = color(o);
-			  if (!o) return new Rgb;
-			  o = o.rgb();
-			  return new Rgb(o.r, o.g, o.b, o.opacity);
-			}
-
-			function rgb(r, g, b, opacity) {
-			  return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);
-			}
-
-			function Rgb(r, g, b, opacity) {
-			  this.r = +r;
-			  this.g = +g;
-			  this.b = +b;
-			  this.opacity = +opacity;
-			}
-
-			define(Rgb, rgb, extend(Color, {
-			  brighter: function(k) {
-				k = k == null ? brighter : Math.pow(brighter, k);
-				return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);
-			  },
-			  darker: function(k) {
-				k = k == null ? darker : Math.pow(darker, k);
-				return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);
-			  },
-			  rgb: function() {
-				return this;
-			  },
-			  displayable: function() {
-				return (0 <= this.r && this.r <= 255)
-					&& (0 <= this.g && this.g <= 255)
-					&& (0 <= this.b && this.b <= 255)
-					&& (0 <= this.opacity && this.opacity <= 1);
-			  },
-			  toString: function() {
-				var a = this.opacity; a = isNaN(a) ? 1 : Math.max(0, Math.min(1, a));
-				return (a === 1 ? "rgb(" : "rgba(")
-					+ Math.max(0, Math.min(255, Math.round(this.r) || 0)) + ", "
-					+ Math.max(0, Math.min(255, Math.round(this.g) || 0)) + ", "
-					+ Math.max(0, Math.min(255, Math.round(this.b) || 0))
-					+ (a === 1 ? ")" : ", " + a + ")");
-			  }
-			}));
-
-			function hsla(h, s, l, a) {
-			  if (a <= 0) h = s = l = NaN;
-			  else if (l <= 0 || l >= 1) h = s = NaN;
-			  else if (s <= 0) h = NaN;
-			  return new Hsl(h, s, l, a);
-			}
-
-			function hslConvert(o) {
-			  if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);
-			  if (!(o instanceof Color)) o = color(o);
-			  if (!o) return new Hsl;
-			  if (o instanceof Hsl) return o;
-			  o = o.rgb();
-			  var r = o.r / 255,
-				  g = o.g / 255,
-				  b = o.b / 255,
-				  min = Math.min(r, g, b),
-				  max = Math.max(r, g, b),
-				  h = NaN,
-				  s = max - min,
-				  l = (max + min) / 2;
-			  if (s) {
-				if (r === max) h = (g - b) / s + (g < b) * 6;
-				else if (g === max) h = (b - r) / s + 2;
-				else h = (r - g) / s + 4;
-				s /= l < 0.5 ? max + min : 2 - max - min;
-				h *= 60;
-			  } else {
-				s = l > 0 && l < 1 ? 0 : h;
-			  }
-			  return new Hsl(h, s, l, o.opacity);
-			}
-
-			function hsl(h, s, l, opacity) {
-			  return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);
-			}
-
-			function Hsl(h, s, l, opacity) {
-			  this.h = +h;
-			  this.s = +s;
-			  this.l = +l;
-			  this.opacity = +opacity;
-			}
-
-			define(Hsl, hsl, extend(Color, {
-			  brighter: function(k) {
-				k = k == null ? brighter : Math.pow(brighter, k);
-				return new Hsl(this.h, this.s, this.l * k, this.opacity);
-			  },
-			  darker: function(k) {
-				k = k == null ? darker : Math.pow(darker, k);
-				return new Hsl(this.h, this.s, this.l * k, this.opacity);
-			  },
-			  rgb: function() {
-				var h = this.h % 360 + (this.h < 0) * 360,
-					s = isNaN(h) || isNaN(this.s) ? 0 : this.s,
-					l = this.l,
-					m2 = l + (l < 0.5 ? l : 1 - l) * s,
-					m1 = 2 * l - m2;
-				return new Rgb(
-				  hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2),
-				  hsl2rgb(h, m1, m2),
-				  hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2),
-				  this.opacity
-				);
-			  },
-			  displayable: function() {
-				return (0 <= this.s && this.s <= 1 || isNaN(this.s))
-					&& (0 <= this.l && this.l <= 1)
-					&& (0 <= this.opacity && this.opacity <= 1);
-			  }
-			}));
-
-			/* From FvD 13.37, CSS Color Module Level 3 */
-			function hsl2rgb(h, m1, m2) {
-			  return (h < 60 ? m1 + (m2 - m1) * h / 60
-				  : h < 180 ? m2
-				  : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60
-				  : m1) * 255;
-			}
-
-			var deg2rad = Math.PI / 180;
-			var rad2deg = 180 / Math.PI;
-
-			var Kn = 18;
-			var Xn = 0.950470;
-			var Yn = 1;
-			var Zn = 1.088830;
-			var t0 = 4 / 29;
-			var t1 = 6 / 29;
-			var t2 = 3 * t1 * t1;
-			var t3 = t1 * t1 * t1;
-
-			function labConvert(o) {
-			  if (o instanceof Lab) return new Lab(o.l, o.a, o.b, o.opacity);
-			  if (o instanceof Hcl) {
-				var h = o.h * deg2rad;
-				return new Lab(o.l, Math.cos(h) * o.c, Math.sin(h) * o.c, o.opacity);
-			  }
-			  if (!(o instanceof Rgb)) o = rgbConvert(o);
-			  var b = rgb2xyz(o.r),
-				  a = rgb2xyz(o.g),
-				  l = rgb2xyz(o.b),
-				  x = xyz2lab((0.4124564 * b + 0.3575761 * a + 0.1804375 * l) / Xn),
-				  y = xyz2lab((0.2126729 * b + 0.7151522 * a + 0.0721750 * l) / Yn),
-				  z = xyz2lab((0.0193339 * b + 0.1191920 * a + 0.9503041 * l) / Zn);
-			  return new Lab(116 * y - 16, 500 * (x - y), 200 * (y - z), o.opacity);
-			}
-
-			function lab(l, a, b, opacity) {
-			  return arguments.length === 1 ? labConvert(l) : new Lab(l, a, b, opacity == null ? 1 : opacity);
-			}
-
-			function Lab(l, a, b, opacity) {
-			  this.l = +l;
-			  this.a = +a;
-			  this.b = +b;
-			  this.opacity = +opacity;
-			}
-
-			define(Lab, lab, extend(Color, {
-			  brighter: function(k) {
-				return new Lab(this.l + Kn * (k == null ? 1 : k), this.a, this.b, this.opacity);
-			  },
-			  darker: function(k) {
-				return new Lab(this.l - Kn * (k == null ? 1 : k), this.a, this.b, this.opacity);
-			  },
-			  rgb: function() {
-				var y = (this.l + 16) / 116,
-					x = isNaN(this.a) ? y : y + this.a / 500,
-					z = isNaN(this.b) ? y : y - this.b / 200;
-				y = Yn * lab2xyz(y);
-				x = Xn * lab2xyz(x);
-				z = Zn * lab2xyz(z);
-				return new Rgb(
-				  xyz2rgb( 3.2404542 * x - 1.5371385 * y - 0.4985314 * z), // D65 -> sRGB
-				  xyz2rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z),
-				  xyz2rgb( 0.0556434 * x - 0.2040259 * y + 1.0572252 * z),
-				  this.opacity
-				);
-			  }
-			}));
-
-			function xyz2lab(t) {
-			  return t > t3 ? Math.pow(t, 1 / 3) : t / t2 + t0;
-			}
-
-			function lab2xyz(t) {
-			  return t > t1 ? t * t * t : t2 * (t - t0);
-			}
-
-			function xyz2rgb(x) {
-			  return 255 * (x <= 0.0031308 ? 12.92 * x : 1.055 * Math.pow(x, 1 / 2.4) - 0.055);
-			}
-
-			function rgb2xyz(x) {
-			  return (x /= 255) <= 0.04045 ? x / 12.92 : Math.pow((x + 0.055) / 1.055, 2.4);
-			}
-
-			function hclConvert(o) {
-			  if (o instanceof Hcl) return new Hcl(o.h, o.c, o.l, o.opacity);
-			  if (!(o instanceof Lab)) o = labConvert(o);
-			  var h = Math.atan2(o.b, o.a) * rad2deg;
-			  return new Hcl(h < 0 ? h + 360 : h, Math.sqrt(o.a * o.a + o.b * o.b), o.l, o.opacity);
-			}
-
-			function hcl(h, c, l, opacity) {
-			  return arguments.length === 1 ? hclConvert(h) : new Hcl(h, c, l, opacity == null ? 1 : opacity);
-			}
-
-			function Hcl(h, c, l, opacity) {
-			  this.h = +h;
-			  this.c = +c;
-			  this.l = +l;
-			  this.opacity = +opacity;
-			}
-
-			define(Hcl, hcl, extend(Color, {
-			  brighter: function(k) {
-				return new Hcl(this.h, this.c, this.l + Kn * (k == null ? 1 : k), this.opacity);
-			  },
-			  darker: function(k) {
-				return new Hcl(this.h, this.c, this.l - Kn * (k == null ? 1 : k), this.opacity);
-			  },
-			  rgb: function() {
-				return labConvert(this).rgb();
-			  }
-			}));
-
-			var A = -0.14861;
-			var B = +1.78277;
-			var C = -0.29227;
-			var D = -0.90649;
-			var E = +1.97294;
-			var ED = E * D;
-			var EB = E * B;
-			var BC_DA = B * C - D * A;
-
-			function cubehelixConvert(o) {
-			  if (o instanceof Cubehelix) return new Cubehelix(o.h, o.s, o.l, o.opacity);
-			  if (!(o instanceof Rgb)) o = rgbConvert(o);
-			  var r = o.r / 255,
-				  g = o.g / 255,
-				  b = o.b / 255,
-				  l = (BC_DA * b + ED * r - EB * g) / (BC_DA + ED - EB),
-				  bl = b - l,
-				  k = (E * (g - l) - C * bl) / D,
-				  s = Math.sqrt(k * k + bl * bl) / (E * l * (1 - l)), // NaN if l=0 or l=1
-				  h = s ? Math.atan2(k, bl) * rad2deg - 120 : NaN;
-			  return new Cubehelix(h < 0 ? h + 360 : h, s, l, o.opacity);
-			}
-
-			function cubehelix(h, s, l, opacity) {
-			  return arguments.length === 1 ? cubehelixConvert(h) : new Cubehelix(h, s, l, opacity == null ? 1 : opacity);
-			}
-
-			function Cubehelix(h, s, l, opacity) {
-			  this.h = +h;
-			  this.s = +s;
-			  this.l = +l;
-			  this.opacity = +opacity;
-			}
-
-			define(Cubehelix, cubehelix, extend(Color, {
-			  brighter: function(k) {
-				k = k == null ? brighter : Math.pow(brighter, k);
-				return new Cubehelix(this.h, this.s, this.l * k, this.opacity);
-			  },
-			  darker: function(k) {
-				k = k == null ? darker : Math.pow(darker, k);
-				return new Cubehelix(this.h, this.s, this.l * k, this.opacity);
-			  },
-			  rgb: function() {
-				var h = isNaN(this.h) ? 0 : (this.h + 120) * deg2rad,
-					l = +this.l,
-					a = isNaN(this.s) ? 0 : this.s * l * (1 - l),
-					cosh = Math.cos(h),
-					sinh = Math.sin(h);
-				return new Rgb(
-				  255 * (l + a * (A * cosh + B * sinh)),
-				  255 * (l + a * (C * cosh + D * sinh)),
-				  255 * (l + a * (E * cosh)),
-				  this.opacity
-				);
-			  }
-			}));
-
-			function basis$1(t1, v0, v1, v2, v3) {
-			  var t2 = t1 * t1, t3 = t2 * t1;
-			  return ((1 - 3 * t1 + 3 * t2 - t3) * v0
-				  + (4 - 6 * t2 + 3 * t3) * v1
-				  + (1 + 3 * t1 + 3 * t2 - 3 * t3) * v2
-				  + t3 * v3) / 6;
-			}
-
-			var basis$2 = function(values) {
-			  var n = values.length - 1;
-			  return function(t) {
-				var i = t <= 0 ? (t = 0) : t >= 1 ? (t = 1, n - 1) : Math.floor(t * n),
-					v1 = values[i],
-					v2 = values[i + 1],
-					v0 = i > 0 ? values[i - 1] : 2 * v1 - v2,
-					v3 = i < n - 1 ? values[i + 2] : 2 * v2 - v1;
-				return basis$1((t - i / n) * n, v0, v1, v2, v3);
-			  };
-			};
-
-			var basisClosed$1 = function(values) {
-			  var n = values.length;
-			  return function(t) {
-				var i = Math.floor(((t %= 1) < 0 ? ++t : t) * n),
-					v0 = values[(i + n - 1) % n],
-					v1 = values[i % n],
-					v2 = values[(i + 1) % n],
-					v3 = values[(i + 2) % n];
-				return basis$1((t - i / n) * n, v0, v1, v2, v3);
-			  };
-			};
-
-			var constant$3 = function(x) {
-			  return function() {
-				return x;
-			  };
-			};
-
-			function linear$1(a, d) {
-			  return function(t) {
-				return a + t * d;
-			  };
-			}
-
-			function exponential$1(a, b, y) {
-			  return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) {
-				return Math.pow(a + t * b, y);
-			  };
-			}
-
-			function hue(a, b) {
-			  var d = b - a;
-			  return d ? linear$1(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant$3(isNaN(a) ? b : a);
-			}
-
-			function gamma(y) {
-			  return (y = +y) === 1 ? nogamma : function(a, b) {
-				return b - a ? exponential$1(a, b, y) : constant$3(isNaN(a) ? b : a);
-			  };
-			}
-
-			function nogamma(a, b) {
-			  var d = b - a;
-			  return d ? linear$1(a, d) : constant$3(isNaN(a) ? b : a);
-			}
-
-			var interpolateRgb = (function rgbGamma(y) {
-			  var color$$1 = gamma(y);
-
-			  function rgb$$1(start, end) {
-				var r = color$$1((start = rgb(start)).r, (end = rgb(end)).r),
-					g = color$$1(start.g, end.g),
-					b = color$$1(start.b, end.b),
-					opacity = color$$1(start.opacity, end.opacity);
-				return function(t) {
-				  start.r = r(t);
-				  start.g = g(t);
-				  start.b = b(t);
-				  start.opacity = opacity(t);
-				  return start + "";
-				};
-			  }
-
-			  rgb$$1.gamma = rgbGamma;
-
-			  return rgb$$1;
-			})(1);
-
-			function rgbSpline(spline) {
-			  return function(colors) {
-				var n = colors.length,
-					r = new Array(n),
-					g = new Array(n),
-					b = new Array(n),
-					i, color$$1;
-				for (i = 0; i < n; ++i) {
-				  color$$1 = rgb(colors[i]);
-				  r[i] = color$$1.r || 0;
-				  g[i] = color$$1.g || 0;
-				  b[i] = color$$1.b || 0;
-				}
-				r = spline(r);
-				g = spline(g);
-				b = spline(b);
-				color$$1.opacity = 1;
-				return function(t) {
-				  color$$1.r = r(t);
-				  color$$1.g = g(t);
-				  color$$1.b = b(t);
-				  return color$$1 + "";
-				};
-			  };
-			}
-
-			var rgbBasis = rgbSpline(basis$2);
-			var rgbBasisClosed = rgbSpline(basisClosed$1);
-
-			var array$1 = function(a, b) {
-			  var nb = b ? b.length : 0,
-				  na = a ? Math.min(nb, a.length) : 0,
-				  x = new Array(nb),
-				  c = new Array(nb),
-				  i;
-
-			  for (i = 0; i < na; ++i) x[i] = interpolate(a[i], b[i]);
-			  for (; i < nb; ++i) c[i] = b[i];
-
-			  return function(t) {
-				for (i = 0; i < na; ++i) c[i] = x[i](t);
-				return c;
-			  };
-			};
-
-			var date = function(a, b) {
-			  var d = new Date;
-			  return a = +a, b -= a, function(t) {
-				return d.setTime(a + b * t), d;
-			  };
-			};
-
-			var interpolateNumber = function(a, b) {
-			  return a = +a, b -= a, function(t) {
-				return a + b * t;
-			  };
-			};
-
-			var object = function(a, b) {
-			  var i = {},
-				  c = {},
-				  k;
-
-			  if (a === null || typeof a !== "object") a = {};
-			  if (b === null || typeof b !== "object") b = {};
-
-			  for (k in b) {
-				if (k in a) {
-				  i[k] = interpolate(a[k], b[k]);
-				} else {
-				  c[k] = b[k];
-				}
-			  }
-
-			  return function(t) {
-				for (k in i) c[k] = i[k](t);
-				return c;
-			  };
-			};
-
-			var reA = /[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g;
-			var reB = new RegExp(reA.source, "g");
-
-			function zero(b) {
-			  return function() {
-				return b;
-			  };
-			}
-
-			function one(b) {
-			  return function(t) {
-				return b(t) + "";
-			  };
-			}
-
-			var interpolateString = function(a, b) {
-			  var bi = reA.lastIndex = reB.lastIndex = 0, // scan index for next number in b
-				  am, // current match in a
-				  bm, // current match in b
-				  bs, // string preceding current number in b, if any
-				  i = -1, // index in s
-				  s = [], // string constants and placeholders
-				  q = []; // number interpolators
-
-			  // Coerce inputs to strings.
-			  a = a + "", b = b + "";
-
-			  // Interpolate pairs of numbers in a & b.
-			  while ((am = reA.exec(a))
-				  && (bm = reB.exec(b))) {
-				if ((bs = bm.index) > bi) { // a string precedes the next number in b
-				  bs = b.slice(bi, bs);
-				  if (s[i]) s[i] += bs; // coalesce with previous string
-				  else s[++i] = bs;
-				}
-				if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match
-				  if (s[i]) s[i] += bm; // coalesce with previous string
-				  else s[++i] = bm;
-				} else { // interpolate non-matching numbers
-				  s[++i] = null;
-				  q.push({i: i, x: interpolateNumber(am, bm)});
-				}
-				bi = reB.lastIndex;
-			  }
-
-			  // Add remains of b.
-			  if (bi < b.length) {
-				bs = b.slice(bi);
-				if (s[i]) s[i] += bs; // coalesce with previous string
-				else s[++i] = bs;
-			  }
-
-			  // Special optimization for only a single match.
-			  // Otherwise, interpolate each of the numbers and rejoin the string.
-			  return s.length < 2 ? (q[0]
-				  ? one(q[0].x)
-				  : zero(b))
-				  : (b = q.length, function(t) {
-					  for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);
-					  return s.join("");
-					});
-			};
-
-			var interpolate = function(a, b) {
-			  var t = typeof b, c;
-			  return b == null || t === "boolean" ? constant$3(b)
-				  : (t === "number" ? interpolateNumber
-				  : t === "string" ? ((c = color(b)) ? (b = c, interpolateRgb) : interpolateString)
-				  : b instanceof color ? interpolateRgb
-				  : b instanceof Date ? date
-				  : Array.isArray(b) ? array$1
-				  : isNaN(b) ? object
-				  : interpolateNumber)(a, b);
-			};
-
-			var interpolateRound = function(a, b) {
-			  return a = +a, b -= a, function(t) {
-				return Math.round(a + b * t);
-			  };
-			};
-
-			var degrees = 180 / Math.PI;
-
-			var identity$2 = {
-			  translateX: 0,
-			  translateY: 0,
-			  rotate: 0,
-			  skewX: 0,
-			  scaleX: 1,
-			  scaleY: 1
-			};
-
-			var decompose = function(a, b, c, d, e, f) {
-			  var scaleX, scaleY, skewX;
-			  if (scaleX = Math.sqrt(a * a + b * b)) a /= scaleX, b /= scaleX;
-			  if (skewX = a * c + b * d) c -= a * skewX, d -= b * skewX;
-			  if (scaleY = Math.sqrt(c * c + d * d)) c /= scaleY, d /= scaleY, skewX /= scaleY;
-			  if (a * d < b * c) a = -a, b = -b, skewX = -skewX, scaleX = -scaleX;
-			  return {
-				translateX: e,
-				translateY: f,
-				rotate: Math.atan2(b, a) * degrees,
-				skewX: Math.atan(skewX) * degrees,
-				scaleX: scaleX,
-				scaleY: scaleY
-			  };
-			};
-
-			var cssNode;
-			var cssRoot;
-			var cssView;
-			var svgNode;
-
-			function parseCss(value) {
-			  if (value === "none") return identity$2;
-			  if (!cssNode) cssNode = document.createElement("DIV"), cssRoot = document.documentElement, cssView = document.defaultView;
-			  cssNode.style.transform = value;
-			  value = cssView.getComputedStyle(cssRoot.appendChild(cssNode), null).getPropertyValue("transform");
-			  cssRoot.removeChild(cssNode);
-			  value = value.slice(7, -1).split(",");
-			  return decompose(+value[0], +value[1], +value[2], +value[3], +value[4], +value[5]);
-			}
-
-			function parseSvg(value) {
-			  if (value == null) return identity$2;
-			  if (!svgNode) svgNode = document.createElementNS("http://www.w3.org/2000/svg", "g");
-			  svgNode.setAttribute("transform", value);
-			  if (!(value = svgNode.transform.baseVal.consolidate())) return identity$2;
-			  value = value.matrix;
-			  return decompose(value.a, value.b, value.c, value.d, value.e, value.f);
-			}
-
-			function interpolateTransform(parse, pxComma, pxParen, degParen) {
-
-			  function pop(s) {
-				return s.length ? s.pop() + " " : "";
-			  }
-
-			  function translate(xa, ya, xb, yb, s, q) {
-				if (xa !== xb || ya !== yb) {
-				  var i = s.push("translate(", null, pxComma, null, pxParen);
-				  q.push({i: i - 4, x: interpolateNumber(xa, xb)}, {i: i - 2, x: interpolateNumber(ya, yb)});
-				} else if (xb || yb) {
-				  s.push("translate(" + xb + pxComma + yb + pxParen);
-				}
-			  }
-
-			  function rotate(a, b, s, q) {
-				if (a !== b) {
-				  if (a - b > 180) b += 360; else if (b - a > 180) a += 360; // shortest path
-				  q.push({i: s.push(pop(s) + "rotate(", null, degParen) - 2, x: interpolateNumber(a, b)});
-				} else if (b) {
-				  s.push(pop(s) + "rotate(" + b + degParen);
-				}
-			  }
-
-			  function skewX(a, b, s, q) {
-				if (a !== b) {
-				  q.push({i: s.push(pop(s) + "skewX(", null, degParen) - 2, x: interpolateNumber(a, b)});
-				} else if (b) {
-				  s.push(pop(s) + "skewX(" + b + degParen);
-				}
-			  }
-
-			  function scale(xa, ya, xb, yb, s, q) {
-				if (xa !== xb || ya !== yb) {
-				  var i = s.push(pop(s) + "scale(", null, ",", null, ")");
-				  q.push({i: i - 4, x: interpolateNumber(xa, xb)}, {i: i - 2, x: interpolateNumber(ya, yb)});
-				} else if (xb !== 1 || yb !== 1) {
-				  s.push(pop(s) + "scale(" + xb + "," + yb + ")");
-				}
-			  }
-
-			  return function(a, b) {
-				var s = [], // string constants and placeholders
-					q = []; // number interpolators
-				a = parse(a), b = parse(b);
-				translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q);
-				rotate(a.rotate, b.rotate, s, q);
-				skewX(a.skewX, b.skewX, s, q);
-				scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q);
-				a = b = null; // gc
-				return function(t) {
-				  var i = -1, n = q.length, o;
-				  while (++i < n) s[(o = q[i]).i] = o.x(t);
-				  return s.join("");
-				};
-			  };
-			}
-
-			var interpolateTransformCss = interpolateTransform(parseCss, "px, ", "px)", "deg)");
-			var interpolateTransformSvg = interpolateTransform(parseSvg, ", ", ")", ")");
-
-			var rho = Math.SQRT2;
-			var rho2 = 2;
-			var rho4 = 4;
-			var epsilon2 = 1e-12;
-
-			function cosh(x) {
-			  return ((x = Math.exp(x)) + 1 / x) / 2;
-			}
-
-			function sinh(x) {
-			  return ((x = Math.exp(x)) - 1 / x) / 2;
-			}
-
-			function tanh(x) {
-			  return ((x = Math.exp(2 * x)) - 1) / (x + 1);
-			}
-
-			// p0 = [ux0, uy0, w0]
-			// p1 = [ux1, uy1, w1]
-			var interpolateZoom = function(p0, p1) {
-			  var ux0 = p0[0], uy0 = p0[1], w0 = p0[2],
-				  ux1 = p1[0], uy1 = p1[1], w1 = p1[2],
-				  dx = ux1 - ux0,
-				  dy = uy1 - uy0,
-				  d2 = dx * dx + dy * dy,
-				  i,
-				  S;
-
-			  // Special case for u0 ≅ u1.
-			  if (d2 < epsilon2) {
-				S = Math.log(w1 / w0) / rho;
-				i = function(t) {
-				  return [
-					ux0 + t * dx,
-					uy0 + t * dy,
-					w0 * Math.exp(rho * t * S)
-				  ];
-				};
-			  }
-
-			  // General case.
-			  else {
-				var d1 = Math.sqrt(d2),
-					b0 = (w1 * w1 - w0 * w0 + rho4 * d2) / (2 * w0 * rho2 * d1),
-					b1 = (w1 * w1 - w0 * w0 - rho4 * d2) / (2 * w1 * rho2 * d1),
-					r0 = Math.log(Math.sqrt(b0 * b0 + 1) - b0),
-					r1 = Math.log(Math.sqrt(b1 * b1 + 1) - b1);
-				S = (r1 - r0) / rho;
-				i = function(t) {
-				  var s = t * S,
-					  coshr0 = cosh(r0),
-					  u = w0 / (rho2 * d1) * (coshr0 * tanh(rho * s + r0) - sinh(r0));
-				  return [
-					ux0 + u * dx,
-					uy0 + u * dy,
-					w0 * coshr0 / cosh(rho * s + r0)
-				  ];
-				};
-			  }
-
-			  i.duration = S * 1000;
-
-			  return i;
-			};
-
-			function hsl$1(hue$$1) {
-			  return function(start, end) {
-				var h = hue$$1((start = hsl(start)).h, (end = hsl(end)).h),
-					s = nogamma(start.s, end.s),
-					l = nogamma(start.l, end.l),
-					opacity = nogamma(start.opacity, end.opacity);
-				return function(t) {
-				  start.h = h(t);
-				  start.s = s(t);
-				  start.l = l(t);
-				  start.opacity = opacity(t);
-				  return start + "";
-				};
-			  }
-			}
-
-			var hsl$2 = hsl$1(hue);
-			var hslLong = hsl$1(nogamma);
-
-			function lab$1(start, end) {
-			  var l = nogamma((start = lab(start)).l, (end = lab(end)).l),
-				  a = nogamma(start.a, end.a),
-				  b = nogamma(start.b, end.b),
-				  opacity = nogamma(start.opacity, end.opacity);
-			  return function(t) {
-				start.l = l(t);
-				start.a = a(t);
-				start.b = b(t);
-				start.opacity = opacity(t);
-				return start + "";
-			  };
-			}
-
-			function hcl$1(hue$$1) {
-			  return function(start, end) {
-				var h = hue$$1((start = hcl(start)).h, (end = hcl(end)).h),
-					c = nogamma(start.c, end.c),
-					l = nogamma(start.l, end.l),
-					opacity = nogamma(start.opacity, end.opacity);
-				return function(t) {
-				  start.h = h(t);
-				  start.c = c(t);
-				  start.l = l(t);
-				  start.opacity = opacity(t);
-				  return start + "";
-				};
-			  }
-			}
-
-			var hcl$2 = hcl$1(hue);
-			var hclLong = hcl$1(nogamma);
-
-			function cubehelix$1(hue$$1) {
-			  return (function cubehelixGamma(y) {
-				y = +y;
-
-				function cubehelix$$1(start, end) {
-				  var h = hue$$1((start = cubehelix(start)).h, (end = cubehelix(end)).h),
-					  s = nogamma(start.s, end.s),
-					  l = nogamma(start.l, end.l),
-					  opacity = nogamma(start.opacity, end.opacity);
-				  return function(t) {
-					start.h = h(t);
-					start.s = s(t);
-					start.l = l(Math.pow(t, y));
-					start.opacity = opacity(t);
-					return start + "";
-				  };
-				}
-
-				cubehelix$$1.gamma = cubehelixGamma;
-
-				return cubehelix$$1;
-			  })(1);
-			}
-
-			var cubehelix$2 = cubehelix$1(hue);
-			var cubehelixLong = cubehelix$1(nogamma);
-
-			var quantize = function(interpolator, n) {
-			  var samples = new Array(n);
-			  for (var i = 0; i < n; ++i) samples[i] = interpolator(i / (n - 1));
-			  return samples;
-			};
-
-			var noop$1 = {value: function() {}};
-
-			function dispatch() {
-			  for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {
-				if (!(t = arguments[i] + "") || (t in _)) throw new Error("illegal type: " + t);
-				_[t] = [];
-			  }
-			  return new Dispatch(_);
-			}
-
-			function Dispatch(_) {
-			  this._ = _;
-			}
-
-			function parseTypenames(typenames, types) {
-			  return typenames.trim().split(/^|\s+/).map(function(t) {
-				var name = "", i = t.indexOf(".");
-				if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);
-				if (t && !types.hasOwnProperty(t)) throw new Error("unknown type: " + t);
-				return {type: t, name: name};
-			  });
-			}
-
-			Dispatch.prototype = dispatch.prototype = {
-			  constructor: Dispatch,
-			  on: function(typename, callback) {
-				var _ = this._,
-					T = parseTypenames(typename + "", _),
-					t,
-					i = -1,
-					n = T.length;
-
-				// If no callback was specified, return the callback of the given type and name.
-				if (arguments.length < 2) {
-				  while (++i < n) if ((t = (typename = T[i]).type) && (t = get(_[t], typename.name))) return t;
-				  return;
-				}
-
-				// If a type was specified, set the callback for the given type and name.
-				// Otherwise, if a null callback was specified, remove callbacks of the given name.
-				if (callback != null && typeof callback !== "function") throw new Error("invalid callback: " + callback);
-				while (++i < n) {
-				  if (t = (typename = T[i]).type) _[t] = set$2(_[t], typename.name, callback);
-				  else if (callback == null) for (t in _) _[t] = set$2(_[t], typename.name, null);
-				}
-
-				return this;
-			  },
-			  copy: function() {
-				var copy = {}, _ = this._;
-				for (var t in _) copy[t] = _[t].slice();
-				return new Dispatch(copy);
-			  },
-			  call: function(type, that) {
-				if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];
-				if (!this._.hasOwnProperty(type)) throw new Error("unknown type: " + type);
-				for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);
-			  },
-			  apply: function(type, that, args) {
-				if (!this._.hasOwnProperty(type)) throw new Error("unknown type: " + type);
-				for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);
-			  }
-			};
-
-			function get(type, name) {
-			  for (var i = 0, n = type.length, c; i < n; ++i) {
-				if ((c = type[i]).name === name) {
-				  return c.value;
-				}
-			  }
-			}
-
-			function set$2(type, name, callback) {
-			  for (var i = 0, n = type.length; i < n; ++i) {
-				if (type[i].name === name) {
-				  type[i] = noop$1, type = type.slice(0, i).concat(type.slice(i + 1));
-				  break;
-				}
-			  }
-			  if (callback != null) type.push({name: name, value: callback});
-			  return type;
-			}
-
-			function objectConverter(columns) {
-			  return new Function("d", "return {" + columns.map(function(name, i) {
-				return JSON.stringify(name) + ": d[" + i + "]";
-			  }).join(",") + "}");
-			}
-
-			function customConverter(columns, f) {
-			  var object = objectConverter(columns);
-			  return function(row, i) {
-				return f(object(row), i, columns);
-			  };
-			}
-
-			// Compute unique columns in order of discovery.
-			function inferColumns(rows) {
-			  var columnSet = Object.create(null),
-				  columns = [];
-
-			  rows.forEach(function(row) {
-				for (var column in row) {
-				  if (!(column in columnSet)) {
-					columns.push(columnSet[column] = column);
-				  }
-				}
-			  });
-
-			  return columns;
-			}
-
-			var dsv = function(delimiter) {
-			  var reFormat = new RegExp("[\"" + delimiter + "\n]"),
-				  delimiterCode = delimiter.charCodeAt(0);
-
-			  function parse(text, f) {
-				var convert, columns, rows = parseRows(text, function(row, i) {
-				  if (convert) return convert(row, i - 1);
-				  columns = row, convert = f ? customConverter(row, f) : objectConverter(row);
-				});
-				rows.columns = columns;
-				return rows;
-			  }
-
-			  function parseRows(text, f) {
-				var EOL = {}, // sentinel value for end-of-line
-					EOF = {}, // sentinel value for end-of-file
-					rows = [], // output rows
-					N = text.length,
-					I = 0, // current character index
-					n = 0, // the current line number
-					t, // the current token
-					eol; // is the current token followed by EOL?
-
-				function token() {
-				  if (I >= N) return EOF; // special case: end of file
-				  if (eol) return eol = false, EOL; // special case: end of line
-
-				  // special case: quotes
-				  var j = I, c;
-				  if (text.charCodeAt(j) === 34) {
-					var i = j;
-					while (i++ < N) {
-					  if (text.charCodeAt(i) === 34) {
-						if (text.charCodeAt(i + 1) !== 34) break;
-						++i;
-					  }
-					}
-					I = i + 2;
-					c = text.charCodeAt(i + 1);
-					if (c === 13) {
-					  eol = true;
-					  if (text.charCodeAt(i + 2) === 10) ++I;
-					} else if (c === 10) {
-					  eol = true;
-					}
-					return text.slice(j + 1, i).replace(/""/g, "\"");
-				  }
-
-				  // common case: find next delimiter or newline
-				  while (I < N) {
-					var k = 1;
-					c = text.charCodeAt(I++);
-					if (c === 10) eol = true; // \n
-					else if (c === 13) { eol = true; if (text.charCodeAt(I) === 10) ++I, ++k; } // \r|\r\n
-					else if (c !== delimiterCode) continue;
-					return text.slice(j, I - k);
-				  }
-
-				  // special case: last token before EOF
-				  return text.slice(j);
-				}
-
-				while ((t = token()) !== EOF) {
-				  var a = [];
-				  while (t !== EOL && t !== EOF) {
-					a.push(t);
-					t = token();
-				  }
-				  if (f && (a = f(a, n++)) == null) continue;
-				  rows.push(a);
-				}
-
-				return rows;
-			  }
-
-			  function format(rows, columns) {
-				if (columns == null) columns = inferColumns(rows);
-				return [columns.map(formatValue).join(delimiter)].concat(rows.map(function(row) {
-				  return columns.map(function(column) {
-					return formatValue(row[column]);
-				  }).join(delimiter);
-				})).join("\n");
-			  }
-
-			  function formatRows(rows) {
-				return rows.map(formatRow).join("\n");
-			  }
-
-			  function formatRow(row) {
-				return row.map(formatValue).join(delimiter);
-			  }
-
-			  function formatValue(text) {
-				return text == null ? ""
-					: reFormat.test(text += "") ? "\"" + text.replace(/\"/g, "\"\"") + "\""
-					: text;
-			  }
-
-			  return {
-				parse: parse,
-				parseRows: parseRows,
-				format: format,
-				formatRows: formatRows
-			  };
-			};
-
-			var csv = dsv(",");
-
-			var csvParse = csv.parse;
-			var csvParseRows = csv.parseRows;
-			var csvFormat = csv.format;
-			var csvFormatRows = csv.formatRows;
-
-			var tsv = dsv("\t");
-
-			var tsvParse = tsv.parse;
-			var tsvParseRows = tsv.parseRows;
-			var tsvFormat = tsv.format;
-			var tsvFormatRows = tsv.formatRows;
-
-			var request = function(url, callback) {
-			  var request,
-				  event = dispatch("beforesend", "progress", "load", "error"),
-				  mimeType,
-				  headers = map$1(),
-				  xhr = new XMLHttpRequest,
-				  user = null,
-				  password = null,
-				  response,
-				  responseType,
-				  timeout = 0;
-
-			  // If IE does not support CORS, use XDomainRequest.
-			  if (typeof XDomainRequest !== "undefined"
-				  && !("withCredentials" in xhr)
-				  && /^(http(s)?:)?\/\//.test(url)) xhr = new XDomainRequest;
-
-			  "onload" in xhr
-				  ? xhr.onload = xhr.onerror = xhr.ontimeout = respond
-				  : xhr.onreadystatechange = function(o) { xhr.readyState > 3 && respond(o); };
-
-			  function respond(o) {
-				var status = xhr.status, result;
-				if (!status && hasResponse(xhr)
-					|| status >= 200 && status < 300
-					|| status === 304) {
-				  if (response) {
-					try {
-					  result = response.call(request, xhr);
-					} catch (e) {
-					  event.call("error", request, e);
-					  return;
-					}
-				  } else {
-					result = xhr;
-				  }
-				  event.call("load", request, result);
-				} else {
-				  event.call("error", request, o);
-				}
-			  }
-
-			  xhr.onprogress = function(e) {
-				event.call("progress", request, e);
-			  };
-
-			  request = {
-				header: function(name, value) {
-				  name = (name + "").toLowerCase();
-				  if (arguments.length < 2) return headers.get(name);
-				  if (value == null) headers.remove(name);
-				  else headers.set(name, value + "");
-				  return request;
-				},
-
-				// If mimeType is non-null and no Accept header is set, a default is used.
-				mimeType: function(value) {
-				  if (!arguments.length) return mimeType;
-				  mimeType = value == null ? null : value + "";
-				  return request;
-				},
-
-				// Specifies what type the response value should take;
-				// for instance, arraybuffer, blob, document, or text.
-				responseType: function(value) {
-				  if (!arguments.length) return responseType;
-				  responseType = value;
-				  return request;
-				},
-
-				timeout: function(value) {
-				  if (!arguments.length) return timeout;
-				  timeout = +value;
-				  return request;
-				},
-
-				user: function(value) {
-				  return arguments.length < 1 ? user : (user = value == null ? null : value + "", request);
-				},
-
-				password: function(value) {
-				  return arguments.length < 1 ? password : (password = value == null ? null : value + "", request);
-				},
-
-				// Specify how to convert the response content to a specific type;
-				// changes the callback value on "load" events.
-				response: function(value) {
-				  response = value;
-				  return request;
-				},
-
-				// Alias for send("GET", …).
-				get: function(data, callback) {
-				  return request.send("GET", data, callback);
-				},
-
-				// Alias for send("POST", …).
-				post: function(data, callback) {
-				  return request.send("POST", data, callback);
-				},
-
-				// If callback is non-null, it will be used for error and load events.
-				send: function(method, data, callback) {
-				  xhr.open(method, url, true, user, password);
-				  if (mimeType != null && !headers.has("accept")) headers.set("accept", mimeType + ",*/*");
-				  if (xhr.setRequestHeader) headers.each(function(value, name) { xhr.setRequestHeader(name, value); });
-				  if (mimeType != null && xhr.overrideMimeType) xhr.overrideMimeType(mimeType);
-				  if (responseType != null) xhr.responseType = responseType;
-				  if (timeout > 0) xhr.timeout = timeout;
-				  if (callback == null && typeof data === "function") callback = data, data = null;
-				  if (callback != null && callback.length === 1) callback = fixCallback(callback);
-				  if (callback != null) request.on("error", callback).on("load", function(xhr) { callback(null, xhr); });
-				  event.call("beforesend", request, xhr);
-				  xhr.send(data == null ? null : data);
-				  return request;
-				},
-
-				abort: function() {
-				  xhr.abort();
-				  return request;
-				},
-
-				on: function() {
-				  var value = event.on.apply(event, arguments);
-				  return value === event ? request : value;
-				}
-			  };
-
-			  if (callback != null) {
-				if (typeof callback !== "function") throw new Error("invalid callback: " + callback);
-				return request.get(callback);
-			  }
-
-			  return request;
-			};
-
-			function fixCallback(callback) {
-			  return function(error, xhr) {
-				callback(error == null ? xhr : null);
-			  };
-			}
-
-			function hasResponse(xhr) {
-			  var type = xhr.responseType;
-			  return type && type !== "text"
-				  ? xhr.response // null on error
-				  : xhr.responseText; // "" on error
-			}
-
-			var type = function(defaultMimeType, response) {
-			  return function(url, callback) {
-				var r = request(url).mimeType(defaultMimeType).response(response);
-				if (callback != null) {
-				  if (typeof callback !== "function") throw new Error("invalid callback: " + callback);
-				  return r.get(callback);
-				}
-				return r;
-			  };
-			};
-
-			var html = type("text/html", function(xhr) {
-			  return document.createRange().createContextualFragment(xhr.responseText);
-			});
-
-			var json = type("application/json", function(xhr) {
-			  return JSON.parse(xhr.responseText);
-			});
-
-			var text = type("text/plain", function(xhr) {
-			  return xhr.responseText;
-			});
-
-			var xml = type("application/xml", function(xhr) {
-			  var xml = xhr.responseXML;
-			  if (!xml) throw new Error("parse error");
-			  return xml;
-			});
-
-			var dsv$1 = function(defaultMimeType, parse) {
-			  return function(url, row, callback) {
-				if (arguments.length < 3) callback = row, row = null;
-				var r = request(url).mimeType(defaultMimeType);
-				r.row = function(_) { return arguments.length ? r.response(responseOf(parse, row = _)) : row; };
-				r.row(row);
-				return callback ? r.get(callback) : r;
-			  };
-			};
-
-			function responseOf(parse, row) {
-			  return function(request$$1) {
-				return parse(request$$1.responseText, row);
-			  };
-			}
-
-			var csv$1 = dsv$1("text/csv", csvParse);
-
-			var tsv$1 = dsv$1("text/tab-separated-values", tsvParse);
-
-			var frame = 0;
-			var timeout = 0;
-			var interval = 0;
-			var pokeDelay = 1000;
-			var taskHead;
-			var taskTail;
-			var clockLast = 0;
-			var clockNow = 0;
-			var clockSkew = 0;
-			var clock = typeof performance === "object" && performance.now ? performance : Date;
-			var setFrame = typeof requestAnimationFrame === "function" ? requestAnimationFrame : function(f) { setTimeout(f, 17); };
-
-			function now() {
-			  return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);
-			}
-
-			function clearNow() {
-			  clockNow = 0;
-			}
-
-			function Timer() {
-			  this._call =
-			  this._time =
-			  this._next = null;
-			}
-
-			Timer.prototype = timer.prototype = {
-			  constructor: Timer,
-			  restart: function(callback, delay, time) {
-				if (typeof callback !== "function") throw new TypeError("callback is not a function");
-				time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);
-				if (!this._next && taskTail !== this) {
-				  if (taskTail) taskTail._next = this;
-				  else taskHead = this;
-				  taskTail = this;
-				}
-				this._call = callback;
-				this._time = time;
-				sleep();
-			  },
-			  stop: function() {
-				if (this._call) {
-				  this._call = null;
-				  this._time = Infinity;
-				  sleep();
-				}
-			  }
-			};
-
-			function timer(callback, delay, time) {
-			  var t = new Timer;
-			  t.restart(callback, delay, time);
-			  return t;
-			}
-
-			function timerFlush() {
-			  now(); // Get the current time, if not already set.
-			  ++frame; // Pretend we’ve set an alarm, if we haven’t already.
-			  var t = taskHead, e;
-			  while (t) {
-				if ((e = clockNow - t._time) >= 0) t._call.call(null, e);
-				t = t._next;
-			  }
-			  --frame;
-			}
-
-			function wake() {
-			  clockNow = (clockLast = clock.now()) + clockSkew;
-			  frame = timeout = 0;
-			  try {
-				timerFlush();
-			  } finally {
-				frame = 0;
-				nap();
-				clockNow = 0;
-			  }
-			}
-
-			function poke$1() {
-			  var now = clock.now(), delay = now - clockLast;
-			  if (delay > pokeDelay) clockSkew -= delay, clockLast = now;
-			}
-
-			function nap() {
-			  var t0, t1 = taskHead, t2, time = Infinity;
-			  while (t1) {
-				if (t1._call) {
-				  if (time > t1._time) time = t1._time;
-				  t0 = t1, t1 = t1._next;
-				} else {
-				  t2 = t1._next, t1._next = null;
-				  t1 = t0 ? t0._next = t2 : taskHead = t2;
-				}
-			  }
-			  taskTail = t0;
-			  sleep(time);
-			}
-
-			function sleep(time) {
-			  if (frame) return; // Soonest alarm already set, or will be.
-			  if (timeout) timeout = clearTimeout(timeout);
-			  var delay = time - clockNow;
-			  if (delay > 24) {
-				if (time < Infinity) timeout = setTimeout(wake, delay);
-				if (interval) interval = clearInterval(interval);
-			  } else {
-				if (!interval) interval = setInterval(poke$1, pokeDelay);
-				frame = 1, setFrame(wake);
-			  }
-			}
-
-			var timeout$1 = function(callback, delay, time) {
-			  var t = new Timer;
-			  delay = delay == null ? 0 : +delay;
-			  t.restart(function(elapsed) {
-				t.stop();
-				callback(elapsed + delay);
-			  }, delay, time);
-			  return t;
-			};
-
-			var interval$1 = function(callback, delay, time) {
-			  var t = new Timer, total = delay;
-			  if (delay == null) return t.restart(callback, delay, time), t;
-			  delay = +delay, time = time == null ? now() : +time;
-			  t.restart(function tick(elapsed) {
-				elapsed += total;
-				t.restart(tick, total += delay, time);
-				callback(elapsed);
-			  }, delay, time);
-			  return t;
-			};
-
-			var t0$1 = new Date;
-			var t1$1 = new Date;
-
-			function newInterval(floori, offseti, count, field) {
-
-			  function interval(date) {
-				return floori(date = new Date(+date)), date;
-			  }
-
-			  interval.floor = interval;
-
-			  interval.ceil = function(date) {
-				return floori(date = new Date(date - 1)), offseti(date, 1), floori(date), date;
-			  };
-
-			  interval.round = function(date) {
-				var d0 = interval(date),
-					d1 = interval.ceil(date);
-				return date - d0 < d1 - date ? d0 : d1;
-			  };
-
-			  interval.offset = function(date, step) {
-				return offseti(date = new Date(+date), step == null ? 1 : Math.floor(step)), date;
-			  };
-
-			  interval.range = function(start, stop, step) {
-				var range = [];
-				start = interval.ceil(start);
-				step = step == null ? 1 : Math.floor(step);
-				if (!(start < stop) || !(step > 0)) return range; // also handles Invalid Date
-				do range.push(new Date(+start)); while (offseti(start, step), floori(start), start < stop)
-				return range;
-			  };
-
-			  interval.filter = function(test) {
-				return newInterval(function(date) {
-				  if (date >= date) while (floori(date), !test(date)) date.setTime(date - 1);
-				}, function(date, step) {
-				  if (date >= date) while (--step >= 0) while (offseti(date, 1), !test(date)) {} // eslint-disable-line no-empty
-				});
-			  };
-
-			  if (count) {
-				interval.count = function(start, end) {
-				  t0$1.setTime(+start), t1$1.setTime(+end);
-				  floori(t0$1), floori(t1$1);
-				  return Math.floor(count(t0$1, t1$1));
-				};
-
-				interval.every = function(step) {
-				  step = Math.floor(step);
-				  return !isFinite(step) || !(step > 0) ? null
-					  : !(step > 1) ? interval
-					  : interval.filter(field
-						  ? function(d) { return field(d) % step === 0; }
-						  : function(d) { return interval.count(0, d) % step === 0; });
-				};
-			  }
-
-			  return interval;
-			}
-
-			var millisecond = newInterval(function() {
-			  // noop
-			}, function(date, step) {
-			  date.setTime(+date + step);
-			}, function(start, end) {
-			  return end - start;
-			});
-
-			// An optimized implementation for this simple case.
-			millisecond.every = function(k) {
-			  k = Math.floor(k);
-			  if (!isFinite(k) || !(k > 0)) return null;
-			  if (!(k > 1)) return millisecond;
-			  return newInterval(function(date) {
-				date.setTime(Math.floor(date / k) * k);
-			  }, function(date, step) {
-				date.setTime(+date + step * k);
-			  }, function(start, end) {
-				return (end - start) / k;
-			  });
-			};
-
-			var milliseconds = millisecond.range;
-
-			var durationSecond = 1e3;
-			var durationMinute = 6e4;
-			var durationHour = 36e5;
-			var durationDay = 864e5;
-			var durationWeek = 6048e5;
-
-			var second = newInterval(function(date) {
-			  date.setTime(Math.floor(date / durationSecond) * durationSecond);
-			}, function(date, step) {
-			  date.setTime(+date + step * durationSecond);
-			}, function(start, end) {
-			  return (end - start) / durationSecond;
-			}, function(date) {
-			  return date.getUTCSeconds();
-			});
-
-			var seconds = second.range;
-
-			var minute = newInterval(function(date) {
-			  date.setTime(Math.floor(date / durationMinute) * durationMinute);
-			}, function(date, step) {
-			  date.setTime(+date + step * durationMinute);
-			}, function(start, end) {
-			  return (end - start) / durationMinute;
-			}, function(date) {
-			  return date.getMinutes();
-			});
-
-			var minutes = minute.range;
-
-			var hour = newInterval(function(date) {
-			  var offset = date.getTimezoneOffset() * durationMinute % durationHour;
-			  if (offset < 0) offset += durationHour;
-			  date.setTime(Math.floor((+date - offset) / durationHour) * durationHour + offset);
-			}, function(date, step) {
-			  date.setTime(+date + step * durationHour);
-			}, function(start, end) {
-			  return (end - start) / durationHour;
-			}, function(date) {
-			  return date.getHours();
-			});
-
-			var hours = hour.range;
-
-			var day = newInterval(function(date) {
-			  date.setHours(0, 0, 0, 0);
-			}, function(date, step) {
-			  date.setDate(date.getDate() + step);
-			}, function(start, end) {
-			  return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationDay;
-			}, function(date) {
-			  return date.getDate() - 1;
-			});
-
-			var days = day.range;
-
-			function weekday(i) {
-			  return newInterval(function(date) {
-				date.setDate(date.getDate() - (date.getDay() + 7 - i) % 7);
-				date.setHours(0, 0, 0, 0);
-			  }, function(date, step) {
-				date.setDate(date.getDate() + step * 7);
-			  }, function(start, end) {
-				return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationWeek;
-			  });
-			}
-
-			var sunday = weekday(0);
-			var monday = weekday(1);
-			var tuesday = weekday(2);
-			var wednesday = weekday(3);
-			var thursday = weekday(4);
-			var friday = weekday(5);
-			var saturday = weekday(6);
-
-			var sundays = sunday.range;
-			var mondays = monday.range;
-			var tuesdays = tuesday.range;
-			var wednesdays = wednesday.range;
-			var thursdays = thursday.range;
-			var fridays = friday.range;
-			var saturdays = saturday.range;
-
-			var month = newInterval(function(date) {
-			  date.setDate(1);
-			  date.setHours(0, 0, 0, 0);
-			}, function(date, step) {
-			  date.setMonth(date.getMonth() + step);
-			}, function(start, end) {
-			  return end.getMonth() - start.getMonth() + (end.getFullYear() - start.getFullYear()) * 12;
-			}, function(date) {
-			  return date.getMonth();
-			});
-
-			var months = month.range;
-
-			var year = newInterval(function(date) {
-			  date.setMonth(0, 1);
-			  date.setHours(0, 0, 0, 0);
-			}, function(date, step) {
-			  date.setFullYear(date.getFullYear() + step);
-			}, function(start, end) {
-			  return end.getFullYear() - start.getFullYear();
-			}, function(date) {
-			  return date.getFullYear();
-			});
-
-			// An optimized implementation for this simple case.
-			year.every = function(k) {
-			  return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : newInterval(function(date) {
-				date.setFullYear(Math.floor(date.getFullYear() / k) * k);
-				date.setMonth(0, 1);
-				date.setHours(0, 0, 0, 0);
-			  }, function(date, step) {
-				date.setFullYear(date.getFullYear() + step * k);
-			  });
-			};
-
-			var years = year.range;
-
-			var utcMinute = newInterval(function(date) {
-			  date.setUTCSeconds(0, 0);
-			}, function(date, step) {
-			  date.setTime(+date + step * durationMinute);
-			}, function(start, end) {
-			  return (end - start) / durationMinute;
-			}, function(date) {
-			  return date.getUTCMinutes();
-			});
-
-			var utcMinutes = utcMinute.range;
-
-			var utcHour = newInterval(function(date) {
-			  date.setUTCMinutes(0, 0, 0);
-			}, function(date, step) {
-			  date.setTime(+date + step * durationHour);
-			}, function(start, end) {
-			  return (end - start) / durationHour;
-			}, function(date) {
-			  return date.getUTCHours();
-			});
-
-			var utcHours = utcHour.range;
-
-			var utcDay = newInterval(function(date) {
-			  date.setUTCHours(0, 0, 0, 0);
-			}, function(date, step) {
-			  date.setUTCDate(date.getUTCDate() + step);
-			}, function(start, end) {
-			  return (end - start) / durationDay;
-			}, function(date) {
-			  return date.getUTCDate() - 1;
-			});
-
-			var utcDays = utcDay.range;
-
-			function utcWeekday(i) {
-			  return newInterval(function(date) {
-				date.setUTCDate(date.getUTCDate() - (date.getUTCDay() + 7 - i) % 7);
-				date.setUTCHours(0, 0, 0, 0);
-			  }, function(date, step) {
-				date.setUTCDate(date.getUTCDate() + step * 7);
-			  }, function(start, end) {
-				return (end - start) / durationWeek;
-			  });
-			}
-
-			var utcSunday = utcWeekday(0);
-			var utcMonday = utcWeekday(1);
-			var utcTuesday = utcWeekday(2);
-			var utcWednesday = utcWeekday(3);
-			var utcThursday = utcWeekday(4);
-			var utcFriday = utcWeekday(5);
-			var utcSaturday = utcWeekday(6);
-
-			var utcSundays = utcSunday.range;
-			var utcMondays = utcMonday.range;
-			var utcTuesdays = utcTuesday.range;
-			var utcWednesdays = utcWednesday.range;
-			var utcThursdays = utcThursday.range;
-			var utcFridays = utcFriday.range;
-			var utcSaturdays = utcSaturday.range;
-
-			var utcMonth = newInterval(function(date) {
-			  date.setUTCDate(1);
-			  date.setUTCHours(0, 0, 0, 0);
-			}, function(date, step) {
-			  date.setUTCMonth(date.getUTCMonth() + step);
-			}, function(start, end) {
-			  return end.getUTCMonth() - start.getUTCMonth() + (end.getUTCFullYear() - start.getUTCFullYear()) * 12;
-			}, function(date) {
-			  return date.getUTCMonth();
-			});
-
-			var utcMonths = utcMonth.range;
-
-			var utcYear = newInterval(function(date) {
-			  date.setUTCMonth(0, 1);
-			  date.setUTCHours(0, 0, 0, 0);
-			}, function(date, step) {
-			  date.setUTCFullYear(date.getUTCFullYear() + step);
-			}, function(start, end) {
-			  return end.getUTCFullYear() - start.getUTCFullYear();
-			}, function(date) {
-			  return date.getUTCFullYear();
-			});
-
-			// An optimized implementation for this simple case.
-			utcYear.every = function(k) {
-			  return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : newInterval(function(date) {
-				date.setUTCFullYear(Math.floor(date.getUTCFullYear() / k) * k);
-				date.setUTCMonth(0, 1);
-				date.setUTCHours(0, 0, 0, 0);
-			  }, function(date, step) {
-				date.setUTCFullYear(date.getUTCFullYear() + step * k);
-			  });
-			};
-
-			var utcYears = utcYear.range;
-
-			// Computes the decimal coefficient and exponent of the specified number x with
-			// significant digits p, where x is positive and p is in [1, 21] or undefined.
-			// For example, formatDecimal(1.23) returns ["123", 0].
-			var formatDecimal = function(x, p) {
-			  if ((i = (x = p ? x.toExponential(p - 1) : x.toExponential()).indexOf("e")) < 0) return null; // NaN, ±Infinity
-			  var i, coefficient = x.slice(0, i);
-
-			  // The string returned by toExponential either has the form \d\.\d+e[-+]\d+
-			  // (e.g., 1.2e+3) or the form \de[-+]\d+ (e.g., 1e+3).
-			  return [
-				coefficient.length > 1 ? coefficient[0] + coefficient.slice(2) : coefficient,
-				+x.slice(i + 1)
-			  ];
-			};
-
-			var exponent$1 = function(x) {
-			  return x = formatDecimal(Math.abs(x)), x ? x[1] : NaN;
-			};
-
-			var formatGroup = function(grouping, thousands) {
-			  return function(value, width) {
-				var i = value.length,
-					t = [],
-					j = 0,
-					g = grouping[0],
-					length = 0;
-
-				while (i > 0 && g > 0) {
-				  if (length + g + 1 > width) g = Math.max(1, width - length);
-				  t.push(value.substring(i -= g, i + g));
-				  if ((length += g + 1) > width) break;
-				  g = grouping[j = (j + 1) % grouping.length];
-				}
-
-				return t.reverse().join(thousands);
-			  };
-			};
-
-			var formatDefault = function(x, p) {
-			  x = x.toPrecision(p);
-
-			  out: for (var n = x.length, i = 1, i0 = -1, i1; i < n; ++i) {
-				switch (x[i]) {
-				  case ".": i0 = i1 = i; break;
-				  case "0": if (i0 === 0) i0 = i; i1 = i; break;
-				  case "e": break out;
-				  default: if (i0 > 0) i0 = 0; break;
-				}
-			  }
-
-			  return i0 > 0 ? x.slice(0, i0) + x.slice(i1 + 1) : x;
-			};
-
-			var prefixExponent;
-
-			var formatPrefixAuto = function(x, p) {
-			  var d = formatDecimal(x, p);
-			  if (!d) return x + "";
-			  var coefficient = d[0],
-				  exponent = d[1],
-				  i = exponent - (prefixExponent = Math.max(-8, Math.min(8, Math.floor(exponent / 3))) * 3) + 1,
-				  n = coefficient.length;
-			  return i === n ? coefficient
-				  : i > n ? coefficient + new Array(i - n + 1).join("0")
-				  : i > 0 ? coefficient.slice(0, i) + "." + coefficient.slice(i)
-				  : "0." + new Array(1 - i).join("0") + formatDecimal(x, Math.max(0, p + i - 1))[0]; // less than 1y!
-			};
-
-			var formatRounded = function(x, p) {
-			  var d = formatDecimal(x, p);
-			  if (!d) return x + "";
-			  var coefficient = d[0],
-				  exponent = d[1];
-			  return exponent < 0 ? "0." + new Array(-exponent).join("0") + coefficient
-				  : coefficient.length > exponent + 1 ? coefficient.slice(0, exponent + 1) + "." + coefficient.slice(exponent + 1)
-				  : coefficient + new Array(exponent - coefficient.length + 2).join("0");
-			};
-
-			var formatTypes = {
-			  "": formatDefault,
-			  "%": function(x, p) { return (x * 100).toFixed(p); },
-			  "b": function(x) { return Math.round(x).toString(2); },
-			  "c": function(x) { return x + ""; },
-			  "d": function(x) { return Math.round(x).toString(10); },
-			  "e": function(x, p) { return x.toExponential(p); },
-			  "f": function(x, p) { return x.toFixed(p); },
-			  "g": function(x, p) { return x.toPrecision(p); },
-			  "o": function(x) { return Math.round(x).toString(8); },
-			  "p": function(x, p) { return formatRounded(x * 100, p); },
-			  "r": formatRounded,
-			  "s": formatPrefixAuto,
-			  "X": function(x) { return Math.round(x).toString(16).toUpperCase(); },
-			  "x": function(x) { return Math.round(x).toString(16); }
-			};
-
-			// [[fill]align][sign][symbol][0][width][,][.precision][type]
-			var re = /^(?:(.)?([<>=^]))?([+\-\( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?([a-z%])?$/i;
-
-			var formatSpecifier = function(specifier) {
-			  return new FormatSpecifier(specifier);
-			};
-
-			function FormatSpecifier(specifier) {
-			  if (!(match = re.exec(specifier))) throw new Error("invalid format: " + specifier);
-
-			  var match,
-				  fill = match[1] || " ",
-				  align = match[2] || ">",
-				  sign = match[3] || "-",
-				  symbol = match[4] || "",
-				  zero = !!match[5],
-				  width = match[6] && +match[6],
-				  comma = !!match[7],
-				  precision = match[8] && +match[8].slice(1),
-				  type = match[9] || "";
-
-			  // The "n" type is an alias for ",g".
-			  if (type === "n") comma = true, type = "g";
-
-			  // Map invalid types to the default format.
-			  else if (!formatTypes[type]) type = "";
-
-			  // If zero fill is specified, padding goes after sign and before digits.
-			  if (zero || (fill === "0" && align === "=")) zero = true, fill = "0", align = "=";
-
-			  this.fill = fill;
-			  this.align = align;
-			  this.sign = sign;
-			  this.symbol = symbol;
-			  this.zero = zero;
-			  this.width = width;
-			  this.comma = comma;
-			  this.precision = precision;
-			  this.type = type;
-			}
-
-			FormatSpecifier.prototype.toString = function() {
-			  return this.fill
-				  + this.align
-				  + this.sign
-				  + this.symbol
-				  + (this.zero ? "0" : "")
-				  + (this.width == null ? "" : Math.max(1, this.width | 0))
-				  + (this.comma ? "," : "")
-				  + (this.precision == null ? "" : "." + Math.max(0, this.precision | 0))
-				  + this.type;
-			};
-
-			var prefixes = ["y","z","a","f","p","n","\xB5","m","","k","M","G","T","P","E","Z","Y"];
-
-			function identity$3(x) {
-			  return x;
-			}
-
-			var formatLocale = function(locale) {
-			  var group = locale.grouping && locale.thousands ? formatGroup(locale.grouping, locale.thousands) : identity$3,
-				  currency = locale.currency,
-				  decimal = locale.decimal;
-
-			  function newFormat(specifier) {
-				specifier = formatSpecifier(specifier);
-
-				var fill = specifier.fill,
-					align = specifier.align,
-					sign = specifier.sign,
-					symbol = specifier.symbol,
-					zero = specifier.zero,
-					width = specifier.width,
-					comma = specifier.comma,
-					precision = specifier.precision,
-					type = specifier.type;
-
-				// Compute the prefix and suffix.
-				// For SI-prefix, the suffix is lazily computed.
-				var prefix = symbol === "$" ? currency[0] : symbol === "#" && /[boxX]/.test(type) ? "0" + type.toLowerCase() : "",
-					suffix = symbol === "$" ? currency[1] : /[%p]/.test(type) ? "%" : "";
-
-				// What format function should we use?
-				// Is this an integer type?
-				// Can this type generate exponential notation?
-				var formatType = formatTypes[type],
-					maybeSuffix = !type || /[defgprs%]/.test(type);
-
-				// Set the default precision if not specified,
-				// or clamp the specified precision to the supported range.
-				// For significant precision, it must be in [1, 21].
-				// For fixed precision, it must be in [0, 20].
-				precision = precision == null ? (type ? 6 : 12)
-					: /[gprs]/.test(type) ? Math.max(1, Math.min(21, precision))
-					: Math.max(0, Math.min(20, precision));
-
-				function format(value) {
-				  var valuePrefix = prefix,
-					  valueSuffix = suffix,
-					  i, n, c;
-
-				  if (type === "c") {
-					valueSuffix = formatType(value) + valueSuffix;
-					value = "";
-				  } else {
-					value = +value;
-
-					// Convert negative to positive, and compute the prefix.
-					// Note that -0 is not less than 0, but 1 / -0 is!
-					var valueNegative = (value < 0 || 1 / value < 0) && (value *= -1, true);
-
-					// Perform the initial formatting.
-					value = formatType(value, precision);
-
-					// If the original value was negative, it may be rounded to zero during
-					// formatting; treat this as (positive) zero.
-					if (valueNegative) {
-					  i = -1, n = value.length;
-					  valueNegative = false;
-					  while (++i < n) {
-						if (c = value.charCodeAt(i), (48 < c && c < 58)
-							|| (type === "x" && 96 < c && c < 103)
-							|| (type === "X" && 64 < c && c < 71)) {
-						  valueNegative = true;
-						  break;
-						}
-					  }
-					}
-
-					// Compute the prefix and suffix.
-					valuePrefix = (valueNegative ? (sign === "(" ? sign : "-") : sign === "-" || sign === "(" ? "" : sign) + valuePrefix;
-					valueSuffix = valueSuffix + (type === "s" ? prefixes[8 + prefixExponent / 3] : "") + (valueNegative && sign === "(" ? ")" : "");
-
-					// Break the formatted value into the integer “value” part that can be
-					// grouped, and fractional or exponential “suffix” part that is not.
-					if (maybeSuffix) {
-					  i = -1, n = value.length;
-					  while (++i < n) {
-						if (c = value.charCodeAt(i), 48 > c || c > 57) {
-						  valueSuffix = (c === 46 ? decimal + value.slice(i + 1) : value.slice(i)) + valueSuffix;
-						  value = value.slice(0, i);
-						  break;
-						}
-					  }
-					}
-				  }
-
-				  // If the fill character is not "0", grouping is applied before padding.
-				  if (comma && !zero) value = group(value, Infinity);
-
-				  // Compute the padding.
-				  var length = valuePrefix.length + value.length + valueSuffix.length,
-					  padding = length < width ? new Array(width - length + 1).join(fill) : "";
-
-				  // If the fill character is "0", grouping is applied after padding.
-				  if (comma && zero) value = group(padding + value, padding.length ? width - valueSuffix.length : Infinity), padding = "";
-
-				  // Reconstruct the final output based on the desired alignment.
-				  switch (align) {
-					case "<": return valuePrefix + value + valueSuffix + padding;
-					case "=": return valuePrefix + padding + value + valueSuffix;
-					case "^": return padding.slice(0, length = padding.length >> 1) + valuePrefix + value + valueSuffix + padding.slice(length);
-				  }
-				  return padding + valuePrefix + value + valueSuffix;
-				}
-
-				format.toString = function() {
-				  return specifier + "";
-				};
-
-				return format;
-			  }
-
-			  function formatPrefix(specifier, value) {
-				var f = newFormat((specifier = formatSpecifier(specifier), specifier.type = "f", specifier)),
-					e = Math.max(-8, Math.min(8, Math.floor(exponent$1(value) / 3))) * 3,
-					k = Math.pow(10, -e),
-					prefix = prefixes[8 + e / 3];
-				return function(value) {
-				  return f(k * value) + prefix;
-				};
-			  }
-
-			  return {
-				format: newFormat,
-				formatPrefix: formatPrefix
-			  };
-			};
-
-			var locale$1;
-
-
-
-			defaultLocale({
-			  decimal: ".",
-			  thousands: ",",
-			  grouping: [3],
-			  currency: ["$", ""]
-			});
-
-			function defaultLocale(definition) {
-			  locale$1 = formatLocale(definition);
-			  exports.format = locale$1.format;
-			  exports.formatPrefix = locale$1.formatPrefix;
-			  return locale$1;
-			}
-
-			var precisionFixed = function(step) {
-			  return Math.max(0, -exponent$1(Math.abs(step)));
-			};
-
-			var precisionPrefix = function(step, value) {
-			  return Math.max(0, Math.max(-8, Math.min(8, Math.floor(exponent$1(value) / 3))) * 3 - exponent$1(Math.abs(step)));
-			};
-
-			var precisionRound = function(step, max) {
-			  step = Math.abs(step), max = Math.abs(max) - step;
-			  return Math.max(0, exponent$1(max) - exponent$1(step)) + 1;
-			};
-
-			function localDate(d) {
-			  if (0 <= d.y && d.y < 100) {
-				var date = new Date(-1, d.m, d.d, d.H, d.M, d.S, d.L);
-				date.setFullYear(d.y);
-				return date;
-			  }
-			  return new Date(d.y, d.m, d.d, d.H, d.M, d.S, d.L);
-			}
-
-			function utcDate(d) {
-			  if (0 <= d.y && d.y < 100) {
-				var date = new Date(Date.UTC(-1, d.m, d.d, d.H, d.M, d.S, d.L));
-				date.setUTCFullYear(d.y);
-				return date;
-			  }
-			  return new Date(Date.UTC(d.y, d.m, d.d, d.H, d.M, d.S, d.L));
-			}
-
-			function newYear(y) {
-			  return {y: y, m: 0, d: 1, H: 0, M: 0, S: 0, L: 0};
-			}
-
-			function formatLocale$1(locale) {
-			  var locale_dateTime = locale.dateTime,
-				  locale_date = locale.date,
-				  locale_time = locale.time,
-				  locale_periods = locale.periods,
-				  locale_weekdays = locale.days,
-				  locale_shortWeekdays = locale.shortDays,
-				  locale_months = locale.months,
-				  locale_shortMonths = locale.shortMonths;
-
-			  var periodRe = formatRe(locale_periods),
-				  periodLookup = formatLookup(locale_periods),
-				  weekdayRe = formatRe(locale_weekdays),
-				  weekdayLookup = formatLookup(locale_weekdays),
-				  shortWeekdayRe = formatRe(locale_shortWeekdays),
-				  shortWeekdayLookup = formatLookup(locale_shortWeekdays),
-				  monthRe = formatRe(locale_months),
-				  monthLookup = formatLookup(locale_months),
-				  shortMonthRe = formatRe(locale_shortMonths),
-				  shortMonthLookup = formatLookup(locale_shortMonths);
-
-			  var formats = {
-				"a": formatShortWeekday,
-				"A": formatWeekday,
-				"b": formatShortMonth,
-				"B": formatMonth,
-				"c": null,
-				"d": formatDayOfMonth,
-				"e": formatDayOfMonth,
-				"H": formatHour24,
-				"I": formatHour12,
-				"j": formatDayOfYear,
-				"L": formatMilliseconds,
-				"m": formatMonthNumber,
-				"M": formatMinutes,
-				"p": formatPeriod,
-				"S": formatSeconds,
-				"U": formatWeekNumberSunday,
-				"w": formatWeekdayNumber,
-				"W": formatWeekNumberMonday,
-				"x": null,
-				"X": null,
-				"y": formatYear,
-				"Y": formatFullYear,
-				"Z": formatZone,
-				"%": formatLiteralPercent
-			  };
-
-			  var utcFormats = {
-				"a": formatUTCShortWeekday,
-				"A": formatUTCWeekday,
-				"b": formatUTCShortMonth,
-				"B": formatUTCMonth,
-				"c": null,
-				"d": formatUTCDayOfMonth,
-				"e": formatUTCDayOfMonth,
-				"H": formatUTCHour24,
-				"I": formatUTCHour12,
-				"j": formatUTCDayOfYear,
-				"L": formatUTCMilliseconds,
-				"m": formatUTCMonthNumber,
-				"M": formatUTCMinutes,
-				"p": formatUTCPeriod,
-				"S": formatUTCSeconds,
-				"U": formatUTCWeekNumberSunday,
-				"w": formatUTCWeekdayNumber,
-				"W": formatUTCWeekNumberMonday,
-				"x": null,
-				"X": null,
-				"y": formatUTCYear,
-				"Y": formatUTCFullYear,
-				"Z": formatUTCZone,
-				"%": formatLiteralPercent
-			  };
-
-			  var parses = {
-				"a": parseShortWeekday,
-				"A": parseWeekday,
-				"b": parseShortMonth,
-				"B": parseMonth,
-				"c": parseLocaleDateTime,
-				"d": parseDayOfMonth,
-				"e": parseDayOfMonth,
-				"H": parseHour24,
-				"I": parseHour24,
-				"j": parseDayOfYear,
-				"L": parseMilliseconds,
-				"m": parseMonthNumber,
-				"M": parseMinutes,
-				"p": parsePeriod,
-				"S": parseSeconds,
-				"U": parseWeekNumberSunday,
-				"w": parseWeekdayNumber,
-				"W": parseWeekNumberMonday,
-				"x": parseLocaleDate,
-				"X": parseLocaleTime,
-				"y": parseYear,
-				"Y": parseFullYear,
-				"Z": parseZone,
-				"%": parseLiteralPercent
-			  };
-
-			  // These recursive directive definitions must be deferred.
-			  formats.x = newFormat(locale_date, formats);
-			  formats.X = newFormat(locale_time, formats);
-			  formats.c = newFormat(locale_dateTime, formats);
-			  utcFormats.x = newFormat(locale_date, utcFormats);
-			  utcFormats.X = newFormat(locale_time, utcFormats);
-			  utcFormats.c = newFormat(locale_dateTime, utcFormats);
-
-			  function newFormat(specifier, formats) {
-				return function(date) {
-				  var string = [],
-					  i = -1,
-					  j = 0,
-					  n = specifier.length,
-					  c,
-					  pad,
-					  format;
-
-				  if (!(date instanceof Date)) date = new Date(+date);
-
-				  while (++i < n) {
-					if (specifier.charCodeAt(i) === 37) {
-					  string.push(specifier.slice(j, i));
-					  if ((pad = pads[c = specifier.charAt(++i)]) != null) c = specifier.charAt(++i);
-					  else pad = c === "e" ? " " : "0";
-					  if (format = formats[c]) c = format(date, pad);
-					  string.push(c);
-					  j = i + 1;
-					}
-				  }
-
-				  string.push(specifier.slice(j, i));
-				  return string.join("");
-				};
-			  }
-
-			  function newParse(specifier, newDate) {
-				return function(string) {
-				  var d = newYear(1900),
-					  i = parseSpecifier(d, specifier, string += "", 0);
-				  if (i != string.length) return null;
-
-				  // The am-pm flag is 0 for AM, and 1 for PM.
-				  if ("p" in d) d.H = d.H % 12 + d.p * 12;
-
-				  // Convert day-of-week and week-of-year to day-of-year.
-				  if ("W" in d || "U" in d) {
-					if (!("w" in d)) d.w = "W" in d ? 1 : 0;
-					var day$$1 = "Z" in d ? utcDate(newYear(d.y)).getUTCDay() : newDate(newYear(d.y)).getDay();
-					d.m = 0;
-					d.d = "W" in d ? (d.w + 6) % 7 + d.W * 7 - (day$$1 + 5) % 7 : d.w + d.U * 7 - (day$$1 + 6) % 7;
-				  }
-
-				  // If a time zone is specified, all fields are interpreted as UTC and then
-				  // offset according to the specified time zone.
-				  if ("Z" in d) {
-					d.H += d.Z / 100 | 0;
-					d.M += d.Z % 100;
-					return utcDate(d);
-				  }
-
-				  // Otherwise, all fields are in local time.
-				  return newDate(d);
-				};
-			  }
-
-			  function parseSpecifier(d, specifier, string, j) {
-				var i = 0,
-					n = specifier.length,
-					m = string.length,
-					c,
-					parse;
-
-				while (i < n) {
-				  if (j >= m) return -1;
-				  c = specifier.charCodeAt(i++);
-				  if (c === 37) {
-					c = specifier.charAt(i++);
-					parse = parses[c in pads ? specifier.charAt(i++) : c];
-					if (!parse || ((j = parse(d, string, j)) < 0)) return -1;
-				  } else if (c != string.charCodeAt(j++)) {
-					return -1;
-				  }
-				}
-
-				return j;
-			  }
-
-			  function parsePeriod(d, string, i) {
-				var n = periodRe.exec(string.slice(i));
-				return n ? (d.p = periodLookup[n[0].toLowerCase()], i + n[0].length) : -1;
-			  }
-
-			  function parseShortWeekday(d, string, i) {
-				var n = shortWeekdayRe.exec(string.slice(i));
-				return n ? (d.w = shortWeekdayLookup[n[0].toLowerCase()], i + n[0].length) : -1;
-			  }
-
-			  function parseWeekday(d, string, i) {
-				var n = weekdayRe.exec(string.slice(i));
-				return n ? (d.w = weekdayLookup[n[0].toLowerCase()], i + n[0].length) : -1;
-			  }
-
-			  function parseShortMonth(d, string, i) {
-				var n = shortMonthRe.exec(string.slice(i));
-				return n ? (d.m = shortMonthLookup[n[0].toLowerCase()], i + n[0].length) : -1;
-			  }
-
-			  function parseMonth(d, string, i) {
-				var n = monthRe.exec(string.slice(i));
-				return n ? (d.m = monthLookup[n[0].toLowerCase()], i + n[0].length) : -1;
-			  }
-
-			  function parseLocaleDateTime(d, string, i) {
-				return parseSpecifier(d, locale_dateTime, string, i);
-			  }
-
-			  function parseLocaleDate(d, string, i) {
-				return parseSpecifier(d, locale_date, string, i);
-			  }
-
-			  function parseLocaleTime(d, string, i) {
-				return parseSpecifier(d, locale_time, string, i);
-			  }
-
-			  function formatShortWeekday(d) {
-				return locale_shortWeekdays[d.getDay()];
-			  }
-
-			  function formatWeekday(d) {
-				return locale_weekdays[d.getDay()];
-			  }
-
-			  function formatShortMonth(d) {
-				return locale_shortMonths[d.getMonth()];
-			  }
-
-			  function formatMonth(d) {
-				return locale_months[d.getMonth()];
-			  }
-
-			  function formatPeriod(d) {
-				return locale_periods[+(d.getHours() >= 12)];
-			  }
-
-			  function formatUTCShortWeekday(d) {
-				return locale_shortWeekdays[d.getUTCDay()];
-			  }
-
-			  function formatUTCWeekday(d) {
-				return locale_weekdays[d.getUTCDay()];
-			  }
-
-			  function formatUTCShortMonth(d) {
-				return locale_shortMonths[d.getUTCMonth()];
-			  }
-
-			  function formatUTCMonth(d) {
-				return locale_months[d.getUTCMonth()];
-			  }
-
-			  function formatUTCPeriod(d) {
-				return locale_periods[+(d.getUTCHours() >= 12)];
-			  }
-
-			  return {
-				format: function(specifier) {
-				  var f = newFormat(specifier += "", formats);
-				  f.toString = function() { return specifier; };
-				  return f;
-				},
-				parse: function(specifier) {
-				  var p = newParse(specifier += "", localDate);
-				  p.toString = function() { return specifier; };
-				  return p;
-				},
-				utcFormat: function(specifier) {
-				  var f = newFormat(specifier += "", utcFormats);
-				  f.toString = function() { return specifier; };
-				  return f;
-				},
-				utcParse: function(specifier) {
-				  var p = newParse(specifier, utcDate);
-				  p.toString = function() { return specifier; };
-				  return p;
-				}
-			  };
-			}
-
-			var pads = {"-": "", "_": " ", "0": "0"};
-			var numberRe = /^\s*\d+/;
-			var percentRe = /^%/;
-			var requoteRe = /[\\\^\$\*\+\?\|\[\]\(\)\.\{\}]/g;
-
-			function pad(value, fill, width) {
-			  var sign = value < 0 ? "-" : "",
-				  string = (sign ? -value : value) + "",
-				  length = string.length;
-			  return sign + (length < width ? new Array(width - length + 1).join(fill) + string : string);
-			}
-
-			function requote(s) {
-			  return s.replace(requoteRe, "\\$&");
-			}
-
-			function formatRe(names) {
-			  return new RegExp("^(?:" + names.map(requote).join("|") + ")", "i");
-			}
-
-			function formatLookup(names) {
-			  var map = {}, i = -1, n = names.length;
-			  while (++i < n) map[names[i].toLowerCase()] = i;
-			  return map;
-			}
-
-			function parseWeekdayNumber(d, string, i) {
-			  var n = numberRe.exec(string.slice(i, i + 1));
-			  return n ? (d.w = +n[0], i + n[0].length) : -1;
-			}
-
-			function parseWeekNumberSunday(d, string, i) {
-			  var n = numberRe.exec(string.slice(i));
-			  return n ? (d.U = +n[0], i + n[0].length) : -1;
-			}
-
-			function parseWeekNumberMonday(d, string, i) {
-			  var n = numberRe.exec(string.slice(i));
-			  return n ? (d.W = +n[0], i + n[0].length) : -1;
-			}
-
-			function parseFullYear(d, string, i) {
-			  var n = numberRe.exec(string.slice(i, i + 4));
-			  return n ? (d.y = +n[0], i + n[0].length) : -1;
-			}
-
-			function parseYear(d, string, i) {
-			  var n = numberRe.exec(string.slice(i, i + 2));
-			  return n ? (d.y = +n[0] + (+n[0] > 68 ? 1900 : 2000), i + n[0].length) : -1;
-			}
-
-			function parseZone(d, string, i) {
-			  var n = /^(Z)|([+-]\d\d)(?:\:?(\d\d))?/.exec(string.slice(i, i + 6));
-			  return n ? (d.Z = n[1] ? 0 : -(n[2] + (n[3] || "00")), i + n[0].length) : -1;
-			}
-
-			function parseMonthNumber(d, string, i) {
-			  var n = numberRe.exec(string.slice(i, i + 2));
-			  return n ? (d.m = n[0] - 1, i + n[0].length) : -1;
-			}
-
-			function parseDayOfMonth(d, string, i) {
-			  var n = numberRe.exec(string.slice(i, i + 2));
-			  return n ? (d.d = +n[0], i + n[0].length) : -1;
-			}
-
-			function parseDayOfYear(d, string, i) {
-			  var n = numberRe.exec(string.slice(i, i + 3));
-			  return n ? (d.m = 0, d.d = +n[0], i + n[0].length) : -1;
-			}
-
-			function parseHour24(d, string, i) {
-			  var n = numberRe.exec(string.slice(i, i + 2));
-			  return n ? (d.H = +n[0], i + n[0].length) : -1;
-			}
-
-			function parseMinutes(d, string, i) {
-			  var n = numberRe.exec(string.slice(i, i + 2));
-			  return n ? (d.M = +n[0], i + n[0].length) : -1;
-			}
-
-			function parseSeconds(d, string, i) {
-			  var n = numberRe.exec(string.slice(i, i + 2));
-			  return n ? (d.S = +n[0], i + n[0].length) : -1;
-			}
-
-			function parseMilliseconds(d, string, i) {
-			  var n = numberRe.exec(string.slice(i, i + 3));
-			  return n ? (d.L = +n[0], i + n[0].length) : -1;
-			}
-
-			function parseLiteralPercent(d, string, i) {
-			  var n = percentRe.exec(string.slice(i, i + 1));
-			  return n ? i + n[0].length : -1;
-			}
-
-			function formatDayOfMonth(d, p) {
-			  return pad(d.getDate(), p, 2);
-			}
-
-			function formatHour24(d, p) {
-			  return pad(d.getHours(), p, 2);
-			}
-
-			function formatHour12(d, p) {
-			  return pad(d.getHours() % 12 || 12, p, 2);
-			}
-
-			function formatDayOfYear(d, p) {
-			  return pad(1 + day.count(year(d), d), p, 3);
-			}
-
-			function formatMilliseconds(d, p) {
-			  return pad(d.getMilliseconds(), p, 3);
-			}
-
-			function formatMonthNumber(d, p) {
-			  return pad(d.getMonth() + 1, p, 2);
-			}
-
-			function formatMinutes(d, p) {
-			  return pad(d.getMinutes(), p, 2);
-			}
-
-			function formatSeconds(d, p) {
-			  return pad(d.getSeconds(), p, 2);
-			}
-
-			function formatWeekNumberSunday(d, p) {
-			  return pad(sunday.count(year(d), d), p, 2);
-			}
-
-			function formatWeekdayNumber(d) {
-			  return d.getDay();
-			}
-
-			function formatWeekNumberMonday(d, p) {
-			  return pad(monday.count(year(d), d), p, 2);
-			}
-
-			function formatYear(d, p) {
-			  return pad(d.getFullYear() % 100, p, 2);
-			}
-
-			function formatFullYear(d, p) {
-			  return pad(d.getFullYear() % 10000, p, 4);
-			}
-
-			function formatZone(d) {
-			  var z = d.getTimezoneOffset();
-			  return (z > 0 ? "-" : (z *= -1, "+"))
-				  + pad(z / 60 | 0, "0", 2)
-				  + pad(z % 60, "0", 2);
-			}
-
-			function formatUTCDayOfMonth(d, p) {
-			  return pad(d.getUTCDate(), p, 2);
-			}
-
-			function formatUTCHour24(d, p) {
-			  return pad(d.getUTCHours(), p, 2);
-			}
-
-			function formatUTCHour12(d, p) {
-			  return pad(d.getUTCHours() % 12 || 12, p, 2);
-			}
-
-			function formatUTCDayOfYear(d, p) {
-			  return pad(1 + utcDay.count(utcYear(d), d), p, 3);
-			}
-
-			function formatUTCMilliseconds(d, p) {
-			  return pad(d.getUTCMilliseconds(), p, 3);
-			}
-
-			function formatUTCMonthNumber(d, p) {
-			  return pad(d.getUTCMonth() + 1, p, 2);
-			}
-
-			function formatUTCMinutes(d, p) {
-			  return pad(d.getUTCMinutes(), p, 2);
-			}
-
-			function formatUTCSeconds(d, p) {
-			  return pad(d.getUTCSeconds(), p, 2);
-			}
-
-			function formatUTCWeekNumberSunday(d, p) {
-			  return pad(utcSunday.count(utcYear(d), d), p, 2);
-			}
-
-			function formatUTCWeekdayNumber(d) {
-			  return d.getUTCDay();
-			}
-
-			function formatUTCWeekNumberMonday(d, p) {
-			  return pad(utcMonday.count(utcYear(d), d), p, 2);
-			}
-
-			function formatUTCYear(d, p) {
-			  return pad(d.getUTCFullYear() % 100, p, 2);
-			}
-
-			function formatUTCFullYear(d, p) {
-			  return pad(d.getUTCFullYear() % 10000, p, 4);
-			}
-
-			function formatUTCZone() {
-			  return "+0000";
-			}
-
-			function formatLiteralPercent() {
-			  return "%";
-			}
-
-			var locale$2;
-
-
-
-
-
-			defaultLocale$1({
-			  dateTime: "%x, %X",
-			  date: "%-m/%-d/%Y",
-			  time: "%-I:%M:%S %p",
-			  periods: ["AM", "PM"],
-			  days: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"],
-			  shortDays: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
-			  months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"],
-			  shortMonths: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]
-			});
-
-			function defaultLocale$1(definition) {
-			  locale$2 = formatLocale$1(definition);
-			  exports.timeFormat = locale$2.format;
-			  exports.timeParse = locale$2.parse;
-			  exports.utcFormat = locale$2.utcFormat;
-			  exports.utcParse = locale$2.utcParse;
-			  return locale$2;
-			}
-
-			var isoSpecifier = "%Y-%m-%dT%H:%M:%S.%LZ";
-
-			function formatIsoNative(date) {
-			  return date.toISOString();
-			}
-
-			var formatIso = Date.prototype.toISOString
-				? formatIsoNative
-				: exports.utcFormat(isoSpecifier);
-
-			function parseIsoNative(string) {
-			  var date = new Date(string);
-			  return isNaN(date) ? null : date;
-			}
-
-			var parseIso = +new Date("2000-01-01T00:00:00.000Z")
-				? parseIsoNative
-				: exports.utcParse(isoSpecifier);
-
-			var array$2 = Array.prototype;
-
-			var map$3 = array$2.map;
-			var slice$3 = array$2.slice;
-
-			var implicit = {name: "implicit"};
-
-			function ordinal(range) {
-			  var index = map$1(),
-				  domain = [],
-				  unknown = implicit;
-
-			  range = range == null ? [] : slice$3.call(range);
-
-			  function scale(d) {
-				var key = d + "", i = index.get(key);
-				if (!i) {
-				  if (unknown !== implicit) return unknown;
-				  index.set(key, i = domain.push(d));
-				}
-				return range[(i - 1) % range.length];
-			  }
-
-			  scale.domain = function(_) {
-				if (!arguments.length) return domain.slice();
-				domain = [], index = map$1();
-				var i = -1, n = _.length, d, key;
-				while (++i < n) if (!index.has(key = (d = _[i]) + "")) index.set(key, domain.push(d));
-				return scale;
-			  };
-
-			  scale.range = function(_) {
-				return arguments.length ? (range = slice$3.call(_), scale) : range.slice();
-			  };
-
-			  scale.unknown = function(_) {
-				return arguments.length ? (unknown = _, scale) : unknown;
-			  };
-
-			  scale.copy = function() {
-				return ordinal()
-					.domain(domain)
-					.range(range)
-					.unknown(unknown);
-			  };
-
-			  return scale;
-			}
-
-			function band() {
-			  var scale = ordinal().unknown(undefined),
-				  domain = scale.domain,
-				  ordinalRange = scale.range,
-				  range$$1 = [0, 1],
-				  step,
-				  bandwidth,
-				  round = false,
-				  paddingInner = 0,
-				  paddingOuter = 0,
-				  align = 0.5;
-
-			  delete scale.unknown;
-
-			  function rescale() {
-				var n = domain().length,
-					reverse = range$$1[1] < range$$1[0],
-					start = range$$1[reverse - 0],
-					stop = range$$1[1 - reverse];
-				step = (stop - start) / Math.max(1, n - paddingInner + paddingOuter * 2);
-				if (round) step = Math.floor(step);
-				start += (stop - start - step * (n - paddingInner)) * align;
-				bandwidth = step * (1 - paddingInner);
-				if (round) start = Math.round(start), bandwidth = Math.round(bandwidth);
-				var values = range(n).map(function(i) { return start + step * i; });
-				return ordinalRange(reverse ? values.reverse() : values);
-			  }
-
-			  scale.domain = function(_) {
-				return arguments.length ? (domain(_), rescale()) : domain();
-			  };
-
-			  scale.range = function(_) {
-				return arguments.length ? (range$$1 = [+_[0], +_[1]], rescale()) : range$$1.slice();
-			  };
-
-			  scale.rangeRound = function(_) {
-				return range$$1 = [+_[0], +_[1]], round = true, rescale();
-			  };
-
-			  scale.bandwidth = function() {
-				return bandwidth;
-			  };
-
-			  scale.step = function() {
-				return step;
-			  };
-
-			  scale.round = function(_) {
-				return arguments.length ? (round = !!_, rescale()) : round;
-			  };
-
-			  scale.padding = function(_) {
-				return arguments.length ? (paddingInner = paddingOuter = Math.max(0, Math.min(1, _)), rescale()) : paddingInner;
-			  };
-
-			  scale.paddingInner = function(_) {
-				return arguments.length ? (paddingInner = Math.max(0, Math.min(1, _)), rescale()) : paddingInner;
-			  };
-
-			  scale.paddingOuter = function(_) {
-				return arguments.length ? (paddingOuter = Math.max(0, Math.min(1, _)), rescale()) : paddingOuter;
-			  };
-
-			  scale.align = function(_) {
-				return arguments.length ? (align = Math.max(0, Math.min(1, _)), rescale()) : align;
-			  };
-
-			  scale.copy = function() {
-				return band()
-					.domain(domain())
-					.range(range$$1)
-					.round(round)
-					.paddingInner(paddingInner)
-					.paddingOuter(paddingOuter)
-					.align(align);
-			  };
-
-			  return rescale();
-			}
-
-			function pointish(scale) {
-			  var copy = scale.copy;
-
-			  scale.padding = scale.paddingOuter;
-			  delete scale.paddingInner;
-			  delete scale.paddingOuter;
-
-			  scale.copy = function() {
-				return pointish(copy());
-			  };
-
-			  return scale;
-			}
-
-			function point$4() {
-			  return pointish(band().paddingInner(1));
-			}
-
-			var constant$4 = function(x) {
-			  return function() {
-				return x;
-			  };
-			};
-
-			var number$1 = function(x) {
-			  return +x;
-			};
-
-			var unit = [0, 1];
-
-			function deinterpolateLinear(a, b) {
-			  return (b -= (a = +a))
-				  ? function(x) { return (x - a) / b; }
-				  : constant$4(b);
-			}
-
-			function deinterpolateClamp(deinterpolate) {
-			  return function(a, b) {
-				var d = deinterpolate(a = +a, b = +b);
-				return function(x) { return x <= a ? 0 : x >= b ? 1 : d(x); };
-			  };
-			}
-
-			function reinterpolateClamp(reinterpolate) {
-			  return function(a, b) {
-				var r = reinterpolate(a = +a, b = +b);
-				return function(t) { return t <= 0 ? a : t >= 1 ? b : r(t); };
-			  };
-			}
-
-			function bimap(domain, range$$1, deinterpolate, reinterpolate) {
-			  var d0 = domain[0], d1 = domain[1], r0 = range$$1[0], r1 = range$$1[1];
-			  if (d1 < d0) d0 = deinterpolate(d1, d0), r0 = reinterpolate(r1, r0);
-			  else d0 = deinterpolate(d0, d1), r0 = reinterpolate(r0, r1);
-			  return function(x) { return r0(d0(x)); };
-			}
-
-			function polymap(domain, range$$1, deinterpolate, reinterpolate) {
-			  var j = Math.min(domain.length, range$$1.length) - 1,
-				  d = new Array(j),
-				  r = new Array(j),
-				  i = -1;
-
-			  // Reverse descending domains.
-			  if (domain[j] < domain[0]) {
-				domain = domain.slice().reverse();
-				range$$1 = range$$1.slice().reverse();
-			  }
-
-			  while (++i < j) {
-				d[i] = deinterpolate(domain[i], domain[i + 1]);
-				r[i] = reinterpolate(range$$1[i], range$$1[i + 1]);
-			  }
-
-			  return function(x) {
-				var i = bisectRight(domain, x, 1, j) - 1;
-				return r[i](d[i](x));
-			  };
-			}
-
-			function copy(source, target) {
-			  return target
-				  .domain(source.domain())
-				  .range(source.range())
-				  .interpolate(source.interpolate())
-				  .clamp(source.clamp());
-			}
-
-			// deinterpolate(a, b)(x) takes a domain value x in [a,b] and returns the corresponding parameter t in [0,1].
-			// reinterpolate(a, b)(t) takes a parameter t in [0,1] and returns the corresponding domain value x in [a,b].
-			function continuous(deinterpolate, reinterpolate) {
-			  var domain = unit,
-				  range$$1 = unit,
-				  interpolate$$1 = interpolate,
-				  clamp = false,
-				  piecewise,
-				  output,
-				  input;
-
-			  function rescale() {
-				piecewise = Math.min(domain.length, range$$1.length) > 2 ? polymap : bimap;
-				output = input = null;
-				return scale;
-			  }
-
-			  function scale(x) {
-				return (output || (output = piecewise(domain, range$$1, clamp ? deinterpolateClamp(deinterpolate) : deinterpolate, interpolate$$1)))(+x);
-			  }
-
-			  scale.invert = function(y) {
-				return (input || (input = piecewise(range$$1, domain, deinterpolateLinear, clamp ? reinterpolateClamp(reinterpolate) : reinterpolate)))(+y);
-			  };
-
-			  scale.domain = function(_) {
-				return arguments.length ? (domain = map$3.call(_, number$1), rescale()) : domain.slice();
-			  };
-
-			  scale.range = function(_) {
-				return arguments.length ? (range$$1 = slice$3.call(_), rescale()) : range$$1.slice();
-			  };
-
-			  scale.rangeRound = function(_) {
-				return range$$1 = slice$3.call(_), interpolate$$1 = interpolateRound, rescale();
-			  };
-
-			  scale.clamp = function(_) {
-				return arguments.length ? (clamp = !!_, rescale()) : clamp;
-			  };
-
-			  scale.interpolate = function(_) {
-				return arguments.length ? (interpolate$$1 = _, rescale()) : interpolate$$1;
-			  };
-
-			  return rescale();
-			}
-
-			var tickFormat = function(domain, count, specifier) {
-			  var start = domain[0],
-				  stop = domain[domain.length - 1],
-				  step = tickStep(start, stop, count == null ? 10 : count),
-				  precision;
-			  specifier = formatSpecifier(specifier == null ? ",f" : specifier);
-			  switch (specifier.type) {
-				case "s": {
-				  var value = Math.max(Math.abs(start), Math.abs(stop));
-				  if (specifier.precision == null && !isNaN(precision = precisionPrefix(step, value))) specifier.precision = precision;
-				  return exports.formatPrefix(specifier, value);
-				}
-				case "":
-				case "e":
-				case "g":
-				case "p":
-				case "r": {
-				  if (specifier.precision == null && !isNaN(precision = precisionRound(step, Math.max(Math.abs(start), Math.abs(stop))))) specifier.precision = precision - (specifier.type === "e");
-				  break;
-				}
-				case "f":
-				case "%": {
-				  if (specifier.precision == null && !isNaN(precision = precisionFixed(step))) specifier.precision = precision - (specifier.type === "%") * 2;
-				  break;
-				}
-			  }
-			  return exports.format(specifier);
-			};
-
-			function linearish(scale) {
-			  var domain = scale.domain;
-
-			  scale.ticks = function(count) {
-				var d = domain();
-				return ticks(d[0], d[d.length - 1], count == null ? 10 : count);
-			  };
-
-			  scale.tickFormat = function(count, specifier) {
-				return tickFormat(domain(), count, specifier);
-			  };
-
-			  scale.nice = function(count) {
-				var d = domain(),
-					i = d.length - 1,
-					n = count == null ? 10 : count,
-					start = d[0],
-					stop = d[i],
-					step = tickStep(start, stop, n);
-
-				if (step) {
-				  step = tickStep(Math.floor(start / step) * step, Math.ceil(stop / step) * step, n);
-				  d[0] = Math.floor(start / step) * step;
-				  d[i] = Math.ceil(stop / step) * step;
-				  domain(d);
-				}
-
-				return scale;
-			  };
-
-			  return scale;
-			}
-
-			function linear$2() {
-			  var scale = continuous(deinterpolateLinear, interpolateNumber);
-
-			  scale.copy = function() {
-				return copy(scale, linear$2());
-			  };
-
-			  return linearish(scale);
-			}
-
-			function identity$4() {
-			  var domain = [0, 1];
-
-			  function scale(x) {
-				return +x;
-			  }
-
-			  scale.invert = scale;
-
-			  scale.domain = scale.range = function(_) {
-				return arguments.length ? (domain = map$3.call(_, number$1), scale) : domain.slice();
-			  };
-
-			  scale.copy = function() {
-				return identity$4().domain(domain);
-			  };
-
-			  return linearish(scale);
-			}
-
-			var nice = function(domain, interval) {
-			  domain = domain.slice();
-
-			  var i0 = 0,
-				  i1 = domain.length - 1,
-				  x0 = domain[i0],
-				  x1 = domain[i1],
-				  t;
-
-			  if (x1 < x0) {
-				t = i0, i0 = i1, i1 = t;
-				t = x0, x0 = x1, x1 = t;
-			  }
-
-			  domain[i0] = interval.floor(x0);
-			  domain[i1] = interval.ceil(x1);
-			  return domain;
-			};
-
-			function deinterpolate(a, b) {
-			  return (b = Math.log(b / a))
-				  ? function(x) { return Math.log(x / a) / b; }
-				  : constant$4(b);
-			}
-
-			function reinterpolate(a, b) {
-			  return a < 0
-				  ? function(t) { return -Math.pow(-b, t) * Math.pow(-a, 1 - t); }
-				  : function(t) { return Math.pow(b, t) * Math.pow(a, 1 - t); };
-			}
-
-			function pow10(x) {
-			  return isFinite(x) ? +("1e" + x) : x < 0 ? 0 : x;
-			}
-
-			function powp(base) {
-			  return base === 10 ? pow10
-				  : base === Math.E ? Math.exp
-				  : function(x) { return Math.pow(base, x); };
-			}
-
-			function logp(base) {
-			  return base === Math.E ? Math.log
-				  : base === 10 && Math.log10
-				  || base === 2 && Math.log2
-				  || (base = Math.log(base), function(x) { return Math.log(x) / base; });
-			}
-
-			function reflect(f) {
-			  return function(x) {
-				return -f(-x);
-			  };
-			}
-
-			function log() {
-			  var scale = continuous(deinterpolate, reinterpolate).domain([1, 10]),
-				  domain = scale.domain,
-				  base = 10,
-				  logs = logp(10),
-				  pows = powp(10);
-
-			  function rescale() {
-				logs = logp(base), pows = powp(base);
-				if (domain()[0] < 0) logs = reflect(logs), pows = reflect(pows);
-				return scale;
-			  }
-
-			  scale.base = function(_) {
-				return arguments.length ? (base = +_, rescale()) : base;
-			  };
-
-			  scale.domain = function(_) {
-				return arguments.length ? (domain(_), rescale()) : domain();
-			  };
-
-			  scale.ticks = function(count) {
-				var d = domain(),
-					u = d[0],
-					v = d[d.length - 1],
-					r;
-
-				if (r = v < u) i = u, u = v, v = i;
-
-				var i = logs(u),
-					j = logs(v),
-					p,
-					k,
-					t,
-					n = count == null ? 10 : +count,
-					z = [];
-
-				if (!(base % 1) && j - i < n) {
-				  i = Math.round(i) - 1, j = Math.round(j) + 1;
-				  if (u > 0) for (; i < j; ++i) {
-					for (k = 1, p = pows(i); k < base; ++k) {
-					  t = p * k;
-					  if (t < u) continue;
-					  if (t > v) break;
-					  z.push(t);
-					}
-				  } else for (; i < j; ++i) {
-					for (k = base - 1, p = pows(i); k >= 1; --k) {
-					  t = p * k;
-					  if (t < u) continue;
-					  if (t > v) break;
-					  z.push(t);
-					}
-				  }
-				} else {
-				  z = ticks(i, j, Math.min(j - i, n)).map(pows);
-				}
-
-				return r ? z.reverse() : z;
-			  };
-
-			  scale.tickFormat = function(count, specifier) {
-				if (specifier == null) specifier = base === 10 ? ".0e" : ",";
-				if (typeof specifier !== "function") specifier = exports.format(specifier);
-				if (count === Infinity) return specifier;
-				if (count == null) count = 10;
-				var k = Math.max(1, base * count / scale.ticks().length); // TODO fast estimate?
-				return function(d) {
-				  var i = d / pows(Math.round(logs(d)));
-				  if (i * base < base - 0.5) i *= base;
-				  return i <= k ? specifier(d) : "";
-				};
-			  };
-
-			  scale.nice = function() {
-				return domain(nice(domain(), {
-				  floor: function(x) { return pows(Math.floor(logs(x))); },
-				  ceil: function(x) { return pows(Math.ceil(logs(x))); }
-				}));
-			  };
-
-			  scale.copy = function() {
-				return copy(scale, log().base(base));
-			  };
-
-			  return scale;
-			}
-
-			function raise(x, exponent) {
-			  return x < 0 ? -Math.pow(-x, exponent) : Math.pow(x, exponent);
-			}
-
-			function pow() {
-			  var exponent = 1,
-				  scale = continuous(deinterpolate, reinterpolate),
-				  domain = scale.domain;
-
-			  function deinterpolate(a, b) {
-				return (b = raise(b, exponent) - (a = raise(a, exponent)))
-					? function(x) { return (raise(x, exponent) - a) / b; }
-					: constant$4(b);
-			  }
-
-			  function reinterpolate(a, b) {
-				b = raise(b, exponent) - (a = raise(a, exponent));
-				return function(t) { return raise(a + b * t, 1 / exponent); };
-			  }
-
-			  scale.exponent = function(_) {
-				return arguments.length ? (exponent = +_, domain(domain())) : exponent;
-			  };
-
-			  scale.copy = function() {
-				return copy(scale, pow().exponent(exponent));
-			  };
-
-			  return linearish(scale);
-			}
-
-			function sqrt() {
-			  return pow().exponent(0.5);
-			}
-
-			function quantile$$1() {
-			  var domain = [],
-				  range$$1 = [],
-				  thresholds = [];
-
-			  function rescale() {
-				var i = 0, n = Math.max(1, range$$1.length);
-				thresholds = new Array(n - 1);
-				while (++i < n) thresholds[i - 1] = threshold(domain, i / n);
-				return scale;
-			  }
-
-			  function scale(x) {
-				if (!isNaN(x = +x)) return range$$1[bisectRight(thresholds, x)];
-			  }
-
-			  scale.invertExtent = function(y) {
-				var i = range$$1.indexOf(y);
-				return i < 0 ? [NaN, NaN] : [
-				  i > 0 ? thresholds[i - 1] : domain[0],
-				  i < thresholds.length ? thresholds[i] : domain[domain.length - 1]
-				];
-			  };
-
-			  scale.domain = function(_) {
-				if (!arguments.length) return domain.slice();
-				domain = [];
-				for (var i = 0, n = _.length, d; i < n; ++i) if (d = _[i], d != null && !isNaN(d = +d)) domain.push(d);
-				domain.sort(ascending);
-				return rescale();
-			  };
-
-			  scale.range = function(_) {
-				return arguments.length ? (range$$1 = slice$3.call(_), rescale()) : range$$1.slice();
-			  };
-
-			  scale.quantiles = function() {
-				return thresholds.slice();
-			  };
-
-			  scale.copy = function() {
-				return quantile$$1()
-					.domain(domain)
-					.range(range$$1);
-			  };
-
-			  return scale;
-			}
-
-			function quantize$1() {
-			  var x0 = 0,
-				  x1 = 1,
-				  n = 1,
-				  domain = [0.5],
-				  range$$1 = [0, 1];
-
-			  function scale(x) {
-				if (x <= x) return range$$1[bisectRight(domain, x, 0, n)];
-			  }
-
-			  function rescale() {
-				var i = -1;
-				domain = new Array(n);
-				while (++i < n) domain[i] = ((i + 1) * x1 - (i - n) * x0) / (n + 1);
-				return scale;
-			  }
-
-			  scale.domain = function(_) {
-				return arguments.length ? (x0 = +_[0], x1 = +_[1], rescale()) : [x0, x1];
-			  };
-
-			  scale.range = function(_) {
-				return arguments.length ? (n = (range$$1 = slice$3.call(_)).length - 1, rescale()) : range$$1.slice();
-			  };
-
-			  scale.invertExtent = function(y) {
-				var i = range$$1.indexOf(y);
-				return i < 0 ? [NaN, NaN]
-					: i < 1 ? [x0, domain[0]]
-					: i >= n ? [domain[n - 1], x1]
-					: [domain[i - 1], domain[i]];
-			  };
-
-			  scale.copy = function() {
-				return quantize$1()
-					.domain([x0, x1])
-					.range(range$$1);
-			  };
-
-			  return linearish(scale);
-			}
-
-			function threshold$1() {
-			  var domain = [0.5],
-				  range$$1 = [0, 1],
-				  n = 1;
-
-			  function scale(x) {
-				if (x <= x) return range$$1[bisectRight(domain, x, 0, n)];
-			  }
-
-			  scale.domain = function(_) {
-				return arguments.length ? (domain = slice$3.call(_), n = Math.min(domain.length, range$$1.length - 1), scale) : domain.slice();
-			  };
-
-			  scale.range = function(_) {
-				return arguments.length ? (range$$1 = slice$3.call(_), n = Math.min(domain.length, range$$1.length - 1), scale) : range$$1.slice();
-			  };
-
-			  scale.invertExtent = function(y) {
-				var i = range$$1.indexOf(y);
-				return [domain[i - 1], domain[i]];
-			  };
-
-			  scale.copy = function() {
-				return threshold$1()
-					.domain(domain)
-					.range(range$$1);
-			  };
-
-			  return scale;
-			}
-
-			var durationSecond$1 = 1000;
-			var durationMinute$1 = durationSecond$1 * 60;
-			var durationHour$1 = durationMinute$1 * 60;
-			var durationDay$1 = durationHour$1 * 24;
-			var durationWeek$1 = durationDay$1 * 7;
-			var durationMonth = durationDay$1 * 30;
-			var durationYear = durationDay$1 * 365;
-
-			function date$1(t) {
-			  return new Date(t);
-			}
-
-			function number$2(t) {
-			  return t instanceof Date ? +t : +new Date(+t);
-			}
-
-			function calendar(year$$1, month$$1, week, day$$1, hour$$1, minute$$1, second$$1, millisecond$$1, format) {
-			  var scale = continuous(deinterpolateLinear, interpolateNumber),
-				  invert = scale.invert,
-				  domain = scale.domain;
-
-			  var formatMillisecond = format(".%L"),
-				  formatSecond = format(":%S"),
-				  formatMinute = format("%I:%M"),
-				  formatHour = format("%I %p"),
-				  formatDay = format("%a %d"),
-				  formatWeek = format("%b %d"),
-				  formatMonth = format("%B"),
-				  formatYear = format("%Y");
-
-			  var tickIntervals = [
-				[second$$1,  1,      durationSecond$1],
-				[second$$1,  5,  5 * durationSecond$1],
-				[second$$1, 15, 15 * durationSecond$1],
-				[second$$1, 30, 30 * durationSecond$1],
-				[minute$$1,  1,      durationMinute$1],
-				[minute$$1,  5,  5 * durationMinute$1],
-				[minute$$1, 15, 15 * durationMinute$1],
-				[minute$$1, 30, 30 * durationMinute$1],
-				[  hour$$1,  1,      durationHour$1  ],
-				[  hour$$1,  3,  3 * durationHour$1  ],
-				[  hour$$1,  6,  6 * durationHour$1  ],
-				[  hour$$1, 12, 12 * durationHour$1  ],
-				[   day$$1,  1,      durationDay$1   ],
-				[   day$$1,  2,  2 * durationDay$1   ],
-				[  week,  1,      durationWeek$1  ],
-				[ month$$1,  1,      durationMonth ],
-				[ month$$1,  3,  3 * durationMonth ],
-				[  year$$1,  1,      durationYear  ]
-			  ];
-
-			  function tickFormat(date) {
-				return (second$$1(date) < date ? formatMillisecond
-					: minute$$1(date) < date ? formatSecond
-					: hour$$1(date) < date ? formatMinute
-					: day$$1(date) < date ? formatHour
-					: month$$1(date) < date ? (week(date) < date ? formatDay : formatWeek)
-					: year$$1(date) < date ? formatMonth
-					: formatYear)(date);
-			  }
-
-			  function tickInterval(interval, start, stop, step) {
-				if (interval == null) interval = 10;
-
-				// If a desired tick count is specified, pick a reasonable tick interval
-				// based on the extent of the domain and a rough estimate of tick size.
-				// Otherwise, assume interval is already a time interval and use it.
-				if (typeof interval === "number") {
-				  var target = Math.abs(stop - start) / interval,
-					  i = bisector(function(i) { return i[2]; }).right(tickIntervals, target);
-				  if (i === tickIntervals.length) {
-					step = tickStep(start / durationYear, stop / durationYear, interval);
-					interval = year$$1;
-				  } else if (i) {
-					i = tickIntervals[target / tickIntervals[i - 1][2] < tickIntervals[i][2] / target ? i - 1 : i];
-					step = i[1];
-					interval = i[0];
-				  } else {
-					step = tickStep(start, stop, interval);
-					interval = millisecond$$1;
-				  }
-				}
-
-				return step == null ? interval : interval.every(step);
-			  }
-
-			  scale.invert = function(y) {
-				return new Date(invert(y));
-			  };
-
-			  scale.domain = function(_) {
-				return arguments.length ? domain(map$3.call(_, number$2)) : domain().map(date$1);
-			  };
-
-			  scale.ticks = function(interval, step) {
-				var d = domain(),
-					t0 = d[0],
-					t1 = d[d.length - 1],
-					r = t1 < t0,
-					t;
-				if (r) t = t0, t0 = t1, t1 = t;
-				t = tickInterval(interval, t0, t1, step);
-				t = t ? t.range(t0, t1 + 1) : []; // inclusive stop
-				return r ? t.reverse() : t;
-			  };
-
-			  scale.tickFormat = function(count, specifier) {
-				return specifier == null ? tickFormat : format(specifier);
-			  };
-
-			  scale.nice = function(interval, step) {
-				var d = domain();
-				return (interval = tickInterval(interval, d[0], d[d.length - 1], step))
-					? domain(nice(d, interval))
-					: scale;
-			  };
-
-			  scale.copy = function() {
-				return copy(scale, calendar(year$$1, month$$1, week, day$$1, hour$$1, minute$$1, second$$1, millisecond$$1, format));
-			  };
-
-			  return scale;
-			}
-
-			var time = function() {
-			  return calendar(year, month, sunday, day, hour, minute, second, millisecond, exports.timeFormat).domain([new Date(2000, 0, 1), new Date(2000, 0, 2)]);
-			};
-
-			var utcTime = function() {
-			  return calendar(utcYear, utcMonth, utcSunday, utcDay, utcHour, utcMinute, second, millisecond, exports.utcFormat).domain([Date.UTC(2000, 0, 1), Date.UTC(2000, 0, 2)]);
-			};
-
-			var colors = function(s) {
-			  return s.match(/.{6}/g).map(function(x) {
-				return "#" + x;
-			  });
-			};
-
-			var category10 = colors("1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf");
-
-			var category20b = colors("393b795254a36b6ecf9c9ede6379398ca252b5cf6bcedb9c8c6d31bd9e39e7ba52e7cb94843c39ad494ad6616be7969c7b4173a55194ce6dbdde9ed6");
-
-			var category20c = colors("3182bd6baed69ecae1c6dbefe6550dfd8d3cfdae6bfdd0a231a35474c476a1d99bc7e9c0756bb19e9ac8bcbddcdadaeb636363969696bdbdbdd9d9d9");
-
-			var category20 = colors("1f77b4aec7e8ff7f0effbb782ca02c98df8ad62728ff98969467bdc5b0d58c564bc49c94e377c2f7b6d27f7f7fc7c7c7bcbd22dbdb8d17becf9edae5");
-
-			var cubehelix$3 = cubehelixLong(cubehelix(300, 0.5, 0.0), cubehelix(-240, 0.5, 1.0));
-
-			var warm = cubehelixLong(cubehelix(-100, 0.75, 0.35), cubehelix(80, 1.50, 0.8));
-
-			var cool = cubehelixLong(cubehelix(260, 0.75, 0.35), cubehelix(80, 1.50, 0.8));
-
-			var rainbow = cubehelix();
-
-			var rainbow$1 = function(t) {
-			  if (t < 0 || t > 1) t -= Math.floor(t);
-			  var ts = Math.abs(t - 0.5);
-			  rainbow.h = 360 * t - 100;
-			  rainbow.s = 1.5 - 1.5 * ts;
-			  rainbow.l = 0.8 - 0.9 * ts;
-			  return rainbow + "";
-			};
-
-			function ramp(range) {
-			  var n = range.length;
-			  return function(t) {
-				return range[Math.max(0, Math.min(n - 1, Math.floor(t * n)))];
-			  };
-			}
-
-			var viridis = ramp(colors("44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725"));
-
-			var magma = ramp(colors("00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf"));
-
-			var inferno = ramp(colors("00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4"));
-
-			var plasma = ramp(colors("0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921"));
-
-			function sequential(interpolator) {
-			  var x0 = 0,
-				  x1 = 1,
-				  clamp = false;
-
-			  function scale(x) {
-				var t = (x - x0) / (x1 - x0);
-				return interpolator(clamp ? Math.max(0, Math.min(1, t)) : t);
-			  }
-
-			  scale.domain = function(_) {
-				return arguments.length ? (x0 = +_[0], x1 = +_[1], scale) : [x0, x1];
-			  };
-
-			  scale.clamp = function(_) {
-				return arguments.length ? (clamp = !!_, scale) : clamp;
-			  };
-
-			  scale.interpolator = function(_) {
-				return arguments.length ? (interpolator = _, scale) : interpolator;
-			  };
-
-			  scale.copy = function() {
-				return sequential(interpolator).domain([x0, x1]).clamp(clamp);
-			  };
-
-			  return linearish(scale);
-			}
-
-			var xhtml = "http://www.w3.org/1999/xhtml";
-
-			var namespaces = {
-			  svg: "http://www.w3.org/2000/svg",
-			  xhtml: xhtml,
-			  xlink: "http://www.w3.org/1999/xlink",
-			  xml: "http://www.w3.org/XML/1998/namespace",
-			  xmlns: "http://www.w3.org/2000/xmlns/"
-			};
-
-			var namespace = function(name) {
-			  var prefix = name += "", i = prefix.indexOf(":");
-			  if (i >= 0 && (prefix = name.slice(0, i)) !== "xmlns") name = name.slice(i + 1);
-			  return namespaces.hasOwnProperty(prefix) ? {space: namespaces[prefix], local: name} : name;
-			};
-
-			function creatorInherit(name) {
-			  return function() {
-				var document = this.ownerDocument,
-					uri = this.namespaceURI;
-				return uri === xhtml && document.documentElement.namespaceURI === xhtml
-					? document.createElement(name)
-					: document.createElementNS(uri, name);
-			  };
-			}
-
-			function creatorFixed(fullname) {
-			  return function() {
-				return this.ownerDocument.createElementNS(fullname.space, fullname.local);
-			  };
-			}
-
-			var creator = function(name) {
-			  var fullname = namespace(name);
-			  return (fullname.local
-				  ? creatorFixed
-				  : creatorInherit)(fullname);
-			};
-
-			var nextId = 0;
-
-			function local() {
-			  return new Local;
-			}
-
-			function Local() {
-			  this._ = "@" + (++nextId).toString(36);
-			}
-
-			Local.prototype = local.prototype = {
-			  constructor: Local,
-			  get: function(node) {
-				var id = this._;
-				while (!(id in node)) if (!(node = node.parentNode)) return;
-				return node[id];
-			  },
-			  set: function(node, value) {
-				return node[this._] = value;
-			  },
-			  remove: function(node) {
-				return this._ in node && delete node[this._];
-			  },
-			  toString: function() {
-				return this._;
-			  }
-			};
-
-			var matcher = function(selector) {
-			  return function() {
-				return this.matches(selector);
-			  };
-			};
-
-			if (typeof document !== "undefined") {
-			  var element = document.documentElement;
-			  if (!element.matches) {
-				var vendorMatches = element.webkitMatchesSelector
-					|| element.msMatchesSelector
-					|| element.mozMatchesSelector
-					|| element.oMatchesSelector;
-				matcher = function(selector) {
-				  return function() {
-					return vendorMatches.call(this, selector);
-				  };
-				};
-			  }
-			}
-
-			var matcher$1 = matcher;
-
-			var filterEvents = {};
-
-			exports.event = null;
-
-			if (typeof document !== "undefined") {
-			  var element$1 = document.documentElement;
-			  if (!("onmouseenter" in element$1)) {
-				filterEvents = {mouseenter: "mouseover", mouseleave: "mouseout"};
-			  }
-			}
-
-			function filterContextListener(listener, index, group) {
-			  listener = contextListener(listener, index, group);
-			  return function(event) {
-				var related = event.relatedTarget;
-				if (!related || (related !== this && !(related.compareDocumentPosition(this) & 8))) {
-				  listener.call(this, event);
-				}
-			  };
-			}
-
-			function contextListener(listener, index, group) {
-			  return function(event1) {
-				var event0 = exports.event; // Events can be reentrant (e.g., focus).
-				exports.event = event1;
-				try {
-				  listener.call(this, this.__data__, index, group);
-				} finally {
-				  exports.event = event0;
-				}
-			  };
-			}
-
-			function parseTypenames$1(typenames) {
-			  return typenames.trim().split(/^|\s+/).map(function(t) {
-				var name = "", i = t.indexOf(".");
-				if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);
-				return {type: t, name: name};
-			  });
-			}
-
-			function onRemove(typename) {
-			  return function() {
-				var on = this.__on;
-				if (!on) return;
-				for (var j = 0, i = -1, m = on.length, o; j < m; ++j) {
-				  if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) {
-					this.removeEventListener(o.type, o.listener, o.capture);
-				  } else {
-					on[++i] = o;
-				  }
-				}
-				if (++i) on.length = i;
-				else delete this.__on;
-			  };
-			}
-
-			function onAdd(typename, value, capture) {
-			  var wrap = filterEvents.hasOwnProperty(typename.type) ? filterContextListener : contextListener;
-			  return function(d, i, group) {
-				var on = this.__on, o, listener = wrap(value, i, group);
-				if (on) for (var j = 0, m = on.length; j < m; ++j) {
-				  if ((o = on[j]).type === typename.type && o.name === typename.name) {
-					this.removeEventListener(o.type, o.listener, o.capture);
-					this.addEventListener(o.type, o.listener = listener, o.capture = capture);
-					o.value = value;
-					return;
-				  }
-				}
-				this.addEventListener(typename.type, listener, capture);
-				o = {type: typename.type, name: typename.name, value: value, listener: listener, capture: capture};
-				if (!on) this.__on = [o];
-				else on.push(o);
-			  };
-			}
-
-			var selection_on = function(typename, value, capture) {
-			  var typenames = parseTypenames$1(typename + ""), i, n = typenames.length, t;
-
-			  if (arguments.length < 2) {
-				var on = this.node().__on;
-				if (on) for (var j = 0, m = on.length, o; j < m; ++j) {
-				  for (i = 0, o = on[j]; i < n; ++i) {
-					if ((t = typenames[i]).type === o.type && t.name === o.name) {
-					  return o.value;
-					}
-				  }
-				}
-				return;
-			  }
-
-			  on = value ? onAdd : onRemove;
-			  if (capture == null) capture = false;
-			  for (i = 0; i < n; ++i) this.each(on(typenames[i], value, capture));
-			  return this;
-			};
-
-			function customEvent(event1, listener, that, args) {
-			  var event0 = exports.event;
-			  event1.sourceEvent = exports.event;
-			  exports.event = event1;
-			  try {
-				return listener.apply(that, args);
-			  } finally {
-				exports.event = event0;
-			  }
-			}
-
-			var sourceEvent = function() {
-			  var current = exports.event, source;
-			  while (source = current.sourceEvent) current = source;
-			  return current;
-			};
-
-			var point$5 = function(node, event) {
-			  var svg = node.ownerSVGElement || node;
-
-			  if (svg.createSVGPoint) {
-				var point = svg.createSVGPoint();
-				point.x = event.clientX, point.y = event.clientY;
-				point = point.matrixTransform(node.getScreenCTM().inverse());
-				return [point.x, point.y];
-			  }
-
-			  var rect = node.getBoundingClientRect();
-			  return [event.clientX - rect.left - node.clientLeft, event.clientY - rect.top - node.clientTop];
-			};
-
-			var mouse = function(node) {
-			  var event = sourceEvent();
-			  if (event.changedTouches) event = event.changedTouches[0];
-			  return point$5(node, event);
-			};
-
-			function none$2() {}
-
-			var selector = function(selector) {
-			  return selector == null ? none$2 : function() {
-				return this.querySelector(selector);
-			  };
-			};
-
-			var selection_select = function(select) {
-			  if (typeof select !== "function") select = selector(select);
-
-			  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
-				for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {
-				  if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {
-					if ("__data__" in node) subnode.__data__ = node.__data__;
-					subgroup[i] = subnode;
-				  }
-				}
-			  }
-
-			  return new Selection(subgroups, this._parents);
-			};
-
-			function empty() {
-			  return [];
-			}
-
-			var selectorAll = function(selector) {
-			  return selector == null ? empty : function() {
-				return this.querySelectorAll(selector);
-			  };
-			};
-
-			var selection_selectAll = function(select) {
-			  if (typeof select !== "function") select = selectorAll(select);
-
-			  for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {
-				for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
-				  if (node = group[i]) {
-					subgroups.push(select.call(node, node.__data__, i, group));
-					parents.push(node);
-				  }
-				}
-			  }
-
-			  return new Selection(subgroups, parents);
-			};
-
-			var selection_filter = function(match) {
-			  if (typeof match !== "function") match = matcher$1(match);
-
-			  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
-				for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {
-				  if ((node = group[i]) && match.call(node, node.__data__, i, group)) {
-					subgroup.push(node);
-				  }
-				}
-			  }
-
-			  return new Selection(subgroups, this._parents);
-			};
-
-			var sparse = function(update) {
-			  return new Array(update.length);
-			};
-
-			var selection_enter = function() {
-			  return new Selection(this._enter || this._groups.map(sparse), this._parents);
-			};
-
-			function EnterNode(parent, datum) {
-			  this.ownerDocument = parent.ownerDocument;
-			  this.namespaceURI = parent.namespaceURI;
-			  this._next = null;
-			  this._parent = parent;
-			  this.__data__ = datum;
-			}
-
-			EnterNode.prototype = {
-			  constructor: EnterNode,
-			  appendChild: function(child) { return this._parent.insertBefore(child, this._next); },
-			  insertBefore: function(child, next) { return this._parent.insertBefore(child, next); },
-			  querySelector: function(selector) { return this._parent.querySelector(selector); },
-			  querySelectorAll: function(selector) { return this._parent.querySelectorAll(selector); }
-			};
-
-			var constant$5 = function(x) {
-			  return function() {
-				return x;
-			  };
-			};
-
-			var keyPrefix = "$"; // Protect against keys like “__proto__”.
-
-			function bindIndex(parent, group, enter, update, exit, data) {
-			  var i = 0,
-				  node,
-				  groupLength = group.length,
-				  dataLength = data.length;
-
-			  // Put any non-null nodes that fit into update.
-			  // Put any null nodes into enter.
-			  // Put any remaining data into enter.
-			  for (; i < dataLength; ++i) {
-				if (node = group[i]) {
-				  node.__data__ = data[i];
-				  update[i] = node;
-				} else {
-				  enter[i] = new EnterNode(parent, data[i]);
-				}
-			  }
-
-			  // Put any non-null nodes that don’t fit into exit.
-			  for (; i < groupLength; ++i) {
-				if (node = group[i]) {
-				  exit[i] = node;
-				}
-			  }
-			}
-
-			function bindKey(parent, group, enter, update, exit, data, key) {
-			  var i,
-				  node,
-				  nodeByKeyValue = {},
-				  groupLength = group.length,
-				  dataLength = data.length,
-				  keyValues = new Array(groupLength),
-				  keyValue;
-
-			  // Compute the key for each node.
-			  // If multiple nodes have the same key, the duplicates are added to exit.
-			  for (i = 0; i < groupLength; ++i) {
-				if (node = group[i]) {
-				  keyValues[i] = keyValue = keyPrefix + key.call(node, node.__data__, i, group);
-				  if (keyValue in nodeByKeyValue) {
-					exit[i] = node;
-				  } else {
-					nodeByKeyValue[keyValue] = node;
-				  }
-				}
-			  }
-
-			  // Compute the key for each datum.
-			  // If there a node associated with this key, join and add it to update.
-			  // If there is not (or the key is a duplicate), add it to enter.
-			  for (i = 0; i < dataLength; ++i) {
-				keyValue = keyPrefix + key.call(parent, data[i], i, data);
-				if (node = nodeByKeyValue[keyValue]) {
-				  update[i] = node;
-				  node.__data__ = data[i];
-				  nodeByKeyValue[keyValue] = null;
-				} else {
-				  enter[i] = new EnterNode(parent, data[i]);
-				}
-			  }
-
-			  // Add any remaining nodes that were not bound to data to exit.
-			  for (i = 0; i < groupLength; ++i) {
-				if ((node = group[i]) && (nodeByKeyValue[keyValues[i]] === node)) {
-				  exit[i] = node;
-				}
-			  }
-			}
-
-			var selection_data = function(value, key) {
-			  if (!value) {
-				data = new Array(this.size()), j = -1;
-				this.each(function(d) { data[++j] = d; });
-				return data;
-			  }
-
-			  var bind = key ? bindKey : bindIndex,
-				  parents = this._parents,
-				  groups = this._groups;
-
-			  if (typeof value !== "function") value = constant$5(value);
-
-			  for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) {
-				var parent = parents[j],
-					group = groups[j],
-					groupLength = group.length,
-					data = value.call(parent, parent && parent.__data__, j, parents),
-					dataLength = data.length,
-					enterGroup = enter[j] = new Array(dataLength),
-					updateGroup = update[j] = new Array(dataLength),
-					exitGroup = exit[j] = new Array(groupLength);
-
-				bind(parent, group, enterGroup, updateGroup, exitGroup, data, key);
-
-				// Now connect the enter nodes to their following update node, such that
-				// appendChild can insert the materialized enter node before this node,
-				// rather than at the end of the parent node.
-				for (var i0 = 0, i1 = 0, previous, next; i0 < dataLength; ++i0) {
-				  if (previous = enterGroup[i0]) {
-					if (i0 >= i1) i1 = i0 + 1;
-					while (!(next = updateGroup[i1]) && ++i1 < dataLength);
-					previous._next = next || null;
-				  }
-				}
-			  }
-
-			  update = new Selection(update, parents);
-			  update._enter = enter;
-			  update._exit = exit;
-			  return update;
-			};
-
-			var selection_exit = function() {
-			  return new Selection(this._exit || this._groups.map(sparse), this._parents);
-			};
-
-			var selection_merge = function(selection) {
-
-			  for (var groups0 = this._groups, groups1 = selection._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {
-				for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {
-				  if (node = group0[i] || group1[i]) {
-					merge[i] = node;
-				  }
-				}
-			  }
-
-			  for (; j < m0; ++j) {
-				merges[j] = groups0[j];
-			  }
-
-			  return new Selection(merges, this._parents);
-			};
-
-			var selection_order = function() {
-
-			  for (var groups = this._groups, j = -1, m = groups.length; ++j < m;) {
-				for (var group = groups[j], i = group.length - 1, next = group[i], node; --i >= 0;) {
-				  if (node = group[i]) {
-					if (next && next !== node.nextSibling) next.parentNode.insertBefore(node, next);
-					next = node;
-				  }
-				}
-			  }
-
-			  return this;
-			};
-
-			var selection_sort = function(compare) {
-			  if (!compare) compare = ascending$2;
-
-			  function compareNode(a, b) {
-				return a && b ? compare(a.__data__, b.__data__) : !a - !b;
-			  }
-
-			  for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) {
-				for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node, i = 0; i < n; ++i) {
-				  if (node = group[i]) {
-					sortgroup[i] = node;
-				  }
-				}
-				sortgroup.sort(compareNode);
-			  }
-
-			  return new Selection(sortgroups, this._parents).order();
-			};
-
-			function ascending$2(a, b) {
-			  return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
-			}
-
-			var selection_call = function() {
-			  var callback = arguments[0];
-			  arguments[0] = this;
-			  callback.apply(null, arguments);
-			  return this;
-			};
-
-			var selection_nodes = function() {
-			  var nodes = new Array(this.size()), i = -1;
-			  this.each(function() { nodes[++i] = this; });
-			  return nodes;
-			};
-
-			var selection_node = function() {
-
-			  for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {
-				for (var group = groups[j], i = 0, n = group.length; i < n; ++i) {
-				  var node = group[i];
-				  if (node) return node;
-				}
-			  }
-
-			  return null;
-			};
-
-			var selection_size = function() {
-			  var size = 0;
-			  this.each(function() { ++size; });
-			  return size;
-			};
-
-			var selection_empty = function() {
-			  return !this.node();
-			};
-
-			var selection_each = function(callback) {
-
-			  for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {
-				for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {
-				  if (node = group[i]) callback.call(node, node.__data__, i, group);
-				}
-			  }
-
-			  return this;
-			};
-
-			function attrRemove(name) {
-			  return function() {
-				this.removeAttribute(name);
-			  };
-			}
-
-			function attrRemoveNS(fullname) {
-			  return function() {
-				this.removeAttributeNS(fullname.space, fullname.local);
-			  };
-			}
-
-			function attrConstant(name, value) {
-			  return function() {
-				this.setAttribute(name, value);
-			  };
-			}
-
-			function attrConstantNS(fullname, value) {
-			  return function() {
-				this.setAttributeNS(fullname.space, fullname.local, value);
-			  };
-			}
-
-			function attrFunction(name, value) {
-			  return function() {
-				var v = value.apply(this, arguments);
-				if (v == null) this.removeAttribute(name);
-				else this.setAttribute(name, v);
-			  };
-			}
-
-			function attrFunctionNS(fullname, value) {
-			  return function() {
-				var v = value.apply(this, arguments);
-				if (v == null) this.removeAttributeNS(fullname.space, fullname.local);
-				else this.setAttributeNS(fullname.space, fullname.local, v);
-			  };
-			}
-
-			var selection_attr = function(name, value) {
-			  var fullname = namespace(name);
-
-			  if (arguments.length < 2) {
-				var node = this.node();
-				return fullname.local
-					? node.getAttributeNS(fullname.space, fullname.local)
-					: node.getAttribute(fullname);
-			  }
-
-			  return this.each((value == null
-				  ? (fullname.local ? attrRemoveNS : attrRemove) : (typeof value === "function"
-				  ? (fullname.local ? attrFunctionNS : attrFunction)
-				  : (fullname.local ? attrConstantNS : attrConstant)))(fullname, value));
-			};
-
-			var window = function(node) {
-			  return (node.ownerDocument && node.ownerDocument.defaultView) // node is a Node
-				  || (node.document && node) // node is a Window
-				  || node.defaultView; // node is a Document
-			};
-
-			function styleRemove(name) {
-			  return function() {
-				this.style.removeProperty(name);
-			  };
-			}
-
-			function styleConstant(name, value, priority) {
-			  return function() {
-				this.style.setProperty(name, value, priority);
-			  };
-			}
-
-			function styleFunction(name, value, priority) {
-			  return function() {
-				var v = value.apply(this, arguments);
-				if (v == null) this.style.removeProperty(name);
-				else this.style.setProperty(name, v, priority);
-			  };
-			}
-
-			var selection_style = function(name, value, priority) {
-			  var node;
-			  return arguments.length > 1
-				  ? this.each((value == null
-						? styleRemove : typeof value === "function"
-						? styleFunction
-						: styleConstant)(name, value, priority == null ? "" : priority))
-				  : window(node = this.node())
-					  .getComputedStyle(node, null)
-					  .getPropertyValue(name);
-			};
-
-			function propertyRemove(name) {
-			  return function() {
-				delete this[name];
-			  };
-			}
-
-			function propertyConstant(name, value) {
-			  return function() {
-				this[name] = value;
-			  };
-			}
-
-			function propertyFunction(name, value) {
-			  return function() {
-				var v = value.apply(this, arguments);
-				if (v == null) delete this[name];
-				else this[name] = v;
-			  };
-			}
-
-			var selection_property = function(name, value) {
-			  return arguments.length > 1
-				  ? this.each((value == null
-					  ? propertyRemove : typeof value === "function"
-					  ? propertyFunction
-					  : propertyConstant)(name, value))
-				  : this.node()[name];
-			};
-
-			function classArray(string) {
-			  return string.trim().split(/^|\s+/);
-			}
-
-			function classList(node) {
-			  return node.classList || new ClassList(node);
-			}
-
-			function ClassList(node) {
-			  this._node = node;
-			  this._names = classArray(node.getAttribute("class") || "");
-			}
-
-			ClassList.prototype = {
-			  add: function(name) {
-				var i = this._names.indexOf(name);
-				if (i < 0) {
-				  this._names.push(name);
-				  this._node.setAttribute("class", this._names.join(" "));
-				}
-			  },
-			  remove: function(name) {
-				var i = this._names.indexOf(name);
-				if (i >= 0) {
-				  this._names.splice(i, 1);
-				  this._node.setAttribute("class", this._names.join(" "));
-				}
-			  },
-			  contains: function(name) {
-				return this._names.indexOf(name) >= 0;
-			  }
-			};
-
-			function classedAdd(node, names) {
-			  var list = classList(node), i = -1, n = names.length;
-			  while (++i < n) list.add(names[i]);
-			}
-
-			function classedRemove(node, names) {
-			  var list = classList(node), i = -1, n = names.length;
-			  while (++i < n) list.remove(names[i]);
-			}
-
-			function classedTrue(names) {
-			  return function() {
-				classedAdd(this, names);
-			  };
-			}
-
-			function classedFalse(names) {
-			  return function() {
-				classedRemove(this, names);
-			  };
-			}
-
-			function classedFunction(names, value) {
-			  return function() {
-				(value.apply(this, arguments) ? classedAdd : classedRemove)(this, names);
-			  };
-			}
-
-			var selection_classed = function(name, value) {
-			  var names = classArray(name + "");
-
-			  if (arguments.length < 2) {
-				var list = classList(this.node()), i = -1, n = names.length;
-				while (++i < n) if (!list.contains(names[i])) return false;
-				return true;
-			  }
-
-			  return this.each((typeof value === "function"
-				  ? classedFunction : value
-				  ? classedTrue
-				  : classedFalse)(names, value));
-			};
-
-			function textRemove() {
-			  this.textContent = "";
-			}
-
-			function textConstant(value) {
-			  return function() {
-				this.textContent = value;
-			  };
-			}
-
-			function textFunction(value) {
-			  return function() {
-				var v = value.apply(this, arguments);
-				this.textContent = v == null ? "" : v;
-			  };
-			}
-
-			var selection_text = function(value) {
-			  return arguments.length
-				  ? this.each(value == null
-					  ? textRemove : (typeof value === "function"
-					  ? textFunction
-					  : textConstant)(value))
-				  : this.node().textContent;
-			};
-
-			function htmlRemove() {
-			  this.innerHTML = "";
-			}
-
-			function htmlConstant(value) {
-			  return function() {
-				this.innerHTML = value;
-			  };
-			}
-
-			function htmlFunction(value) {
-			  return function() {
-				var v = value.apply(this, arguments);
-				this.innerHTML = v == null ? "" : v;
-			  };
-			}
-
-			var selection_html = function(value) {
-			  return arguments.length
-				  ? this.each(value == null
-					  ? htmlRemove : (typeof value === "function"
-					  ? htmlFunction
-					  : htmlConstant)(value))
-				  : this.node().innerHTML;
-			};
-
-			function raise$1() {
-			  if (this.nextSibling) this.parentNode.appendChild(this);
-			}
-
-			var selection_raise = function() {
-			  return this.each(raise$1);
-			};
-
-			function lower() {
-			  if (this.previousSibling) this.parentNode.insertBefore(this, this.parentNode.firstChild);
-			}
-
-			var selection_lower = function() {
-			  return this.each(lower);
-			};
-
-			var selection_append = function(name) {
-			  var create = typeof name === "function" ? name : creator(name);
-			  return this.select(function() {
-				return this.appendChild(create.apply(this, arguments));
-			  });
-			};
-
-			function constantNull() {
-			  return null;
-			}
-
-			var selection_insert = function(name, before) {
-			  var create = typeof name === "function" ? name : creator(name),
-				  select = before == null ? constantNull : typeof before === "function" ? before : selector(before);
-			  return this.select(function() {
-				return this.insertBefore(create.apply(this, arguments), select.apply(this, arguments) || null);
-			  });
-			};
-
-			function remove() {
-			  var parent = this.parentNode;
-			  if (parent) parent.removeChild(this);
-			}
-
-			var selection_remove = function() {
-			  return this.each(remove);
-			};
-
-			var selection_datum = function(value) {
-			  return arguments.length
-				  ? this.property("__data__", value)
-				  : this.node().__data__;
-			};
-
-			function dispatchEvent(node, type, params) {
-			  var window$$1 = window(node),
-				  event = window$$1.CustomEvent;
-
-			  if (event) {
-				event = new event(type, params);
-			  } else {
-				event = window$$1.document.createEvent("Event");
-				if (params) event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail;
-				else event.initEvent(type, false, false);
-			  }
-
-			  node.dispatchEvent(event);
-			}
-
-			function dispatchConstant(type, params) {
-			  return function() {
-				return dispatchEvent(this, type, params);
-			  };
-			}
-
-			function dispatchFunction(type, params) {
-			  return function() {
-				return dispatchEvent(this, type, params.apply(this, arguments));
-			  };
-			}
-
-			var selection_dispatch = function(type, params) {
-			  return this.each((typeof params === "function"
-				  ? dispatchFunction
-				  : dispatchConstant)(type, params));
-			};
-
-			var root = [null];
-
-			function Selection(groups, parents) {
-			  this._groups = groups;
-			  this._parents = parents;
-			}
-
-			function selection() {
-			  return new Selection([[document.documentElement]], root);
-			}
-
-			Selection.prototype = selection.prototype = {
-			  constructor: Selection,
-			  select: selection_select,
-			  selectAll: selection_selectAll,
-			  filter: selection_filter,
-			  data: selection_data,
-			  enter: selection_enter,
-			  exit: selection_exit,
-			  merge: selection_merge,
-			  order: selection_order,
-			  sort: selection_sort,
-			  call: selection_call,
-			  nodes: selection_nodes,
-			  node: selection_node,
-			  size: selection_size,
-			  empty: selection_empty,
-			  each: selection_each,
-			  attr: selection_attr,
-			  style: selection_style,
-			  property: selection_property,
-			  classed: selection_classed,
-			  text: selection_text,
-			  html: selection_html,
-			  raise: selection_raise,
-			  lower: selection_lower,
-			  append: selection_append,
-			  insert: selection_insert,
-			  remove: selection_remove,
-			  datum: selection_datum,
-			  on: selection_on,
-			  dispatch: selection_dispatch
-			};
-
-			var select = function(selector) {
-			  return typeof selector === "string"
-				  ? new Selection([[document.querySelector(selector)]], [document.documentElement])
-				  : new Selection([[selector]], root);
-			};
-
-			var selectAll = function(selector) {
-			  return typeof selector === "string"
-				  ? new Selection([document.querySelectorAll(selector)], [document.documentElement])
-				  : new Selection([selector == null ? [] : selector], root);
-			};
-
-			var touch = function(node, touches, identifier) {
-			  if (arguments.length < 3) identifier = touches, touches = sourceEvent().changedTouches;
-
-			  for (var i = 0, n = touches ? touches.length : 0, touch; i < n; ++i) {
-				if ((touch = touches[i]).identifier === identifier) {
-				  return point$5(node, touch);
-				}
-			  }
-
-			  return null;
-			};
-
-			var touches = function(node, touches) {
-			  if (touches == null) touches = sourceEvent().touches;
-
-			  for (var i = 0, n = touches ? touches.length : 0, points = new Array(n); i < n; ++i) {
-				points[i] = point$5(node, touches[i]);
-			  }
-
-			  return points;
-			};
-
-			var emptyOn = dispatch("start", "end", "interrupt");
-			var emptyTween = [];
-
-			var CREATED = 0;
-			var SCHEDULED = 1;
-			var STARTING = 2;
-			var STARTED = 3;
-			var RUNNING = 4;
-			var ENDING = 5;
-			var ENDED = 6;
-
-			var schedule = function(node, name, id, index, group, timing) {
-			  var schedules = node.__transition;
-			  if (!schedules) node.__transition = {};
-			  else if (id in schedules) return;
-			  create(node, id, {
-				name: name,
-				index: index, // For context during callback.
-				group: group, // For context during callback.
-				on: emptyOn,
-				tween: emptyTween,
-				time: timing.time,
-				delay: timing.delay,
-				duration: timing.duration,
-				ease: timing.ease,
-				timer: null,
-				state: CREATED
-			  });
-			};
-
-			function init(node, id) {
-			  var schedule = node.__transition;
-			  if (!schedule || !(schedule = schedule[id]) || schedule.state > CREATED) throw new Error("too late");
-			  return schedule;
-			}
-
-			function set$3(node, id) {
-			  var schedule = node.__transition;
-			  if (!schedule || !(schedule = schedule[id]) || schedule.state > STARTING) throw new Error("too late");
-			  return schedule;
-			}
-
-			function get$1(node, id) {
-			  var schedule = node.__transition;
-			  if (!schedule || !(schedule = schedule[id])) throw new Error("too late");
-			  return schedule;
-			}
-
-			function create(node, id, self) {
-			  var schedules = node.__transition,
-				  tween;
-
-			  // Initialize the self timer when the transition is created.
-			  // Note the actual delay is not known until the first callback!
-			  schedules[id] = self;
-			  self.timer = timer(schedule, 0, self.time);
-
-			  function schedule(elapsed) {
-				self.state = SCHEDULED;
-				self.timer.restart(start, self.delay, self.time);
-
-				// If the elapsed delay is less than our first sleep, start immediately.
-				if (self.delay <= elapsed) start(elapsed - self.delay);
-			  }
-
-			  function start(elapsed) {
-				var i, j, n, o;
-
-				// If the state is not SCHEDULED, then we previously errored on start.
-				if (self.state !== SCHEDULED) return stop();
-
-				for (i in schedules) {
-				  o = schedules[i];
-				  if (o.name !== self.name) continue;
-
-				  // While this element already has a starting transition during this frame,
-				  // defer starting an interrupting transition until that transition has a
-				  // chance to tick (and possibly end); see d3/d3-transition#54!
-				  if (o.state === STARTED) return timeout$1(start);
-
-				  // Interrupt the active transition, if any.
-				  // Dispatch the interrupt event.
-				  if (o.state === RUNNING) {
-					o.state = ENDED;
-					o.timer.stop();
-					o.on.call("interrupt", node, node.__data__, o.index, o.group);
-					delete schedules[i];
-				  }
-
-				  // Cancel any pre-empted transitions. No interrupt event is dispatched
-				  // because the cancelled transitions never started. Note that this also
-				  // removes this transition from the pending list!
-				  else if (+i < id) {
-					o.state = ENDED;
-					o.timer.stop();
-					delete schedules[i];
-				  }
-				}
-
-				// Defer the first tick to end of the current frame; see d3/d3#1576.
-				// Note the transition may be canceled after start and before the first tick!
-				// Note this must be scheduled before the start event; see d3/d3-transition#16!
-				// Assuming this is successful, subsequent callbacks go straight to tick.
-				timeout$1(function() {
-				  if (self.state === STARTED) {
-					self.state = RUNNING;
-					self.timer.restart(tick, self.delay, self.time);
-					tick(elapsed);
-				  }
-				});
-
-				// Dispatch the start event.
-				// Note this must be done before the tween are initialized.
-				self.state = STARTING;
-				self.on.call("start", node, node.__data__, self.index, self.group);
-				if (self.state !== STARTING) return; // interrupted
-				self.state = STARTED;
-
-				// Initialize the tween, deleting null tween.
-				tween = new Array(n = self.tween.length);
-				for (i = 0, j = -1; i < n; ++i) {
-				  if (o = self.tween[i].value.call(node, node.__data__, self.index, self.group)) {
-					tween[++j] = o;
-				  }
-				}
-				tween.length = j + 1;
-			  }
-
-			  function tick(elapsed) {
-				var t = elapsed < self.duration ? self.ease.call(null, elapsed / self.duration) : (self.timer.restart(stop), self.state = ENDING, 1),
-					i = -1,
-					n = tween.length;
-
-				while (++i < n) {
-				  tween[i].call(null, t);
-				}
-
-				// Dispatch the end event.
-				if (self.state === ENDING) {
-				  self.on.call("end", node, node.__data__, self.index, self.group);
-				  stop();
-				}
-			  }
-
-			  function stop() {
-				self.state = ENDED;
-				self.timer.stop();
-				delete schedules[id];
-				for (var i in schedules) return; // eslint-disable-line no-unused-vars
-				delete node.__transition;
-			  }
-			}
-
-			var interrupt = function(node, name) {
-			  var schedules = node.__transition,
-				  schedule,
-				  active,
-				  empty = true,
-				  i;
-
-			  if (!schedules) return;
-
-			  name = name == null ? null : name + "";
-
-			  for (i in schedules) {
-				if ((schedule = schedules[i]).name !== name) { empty = false; continue; }
-				active = schedule.state > STARTING && schedule.state < ENDING;
-				schedule.state = ENDED;
-				schedule.timer.stop();
-				if (active) schedule.on.call("interrupt", node, node.__data__, schedule.index, schedule.group);
-				delete schedules[i];
-			  }
-
-			  if (empty) delete node.__transition;
-			};
-
-			var selection_interrupt = function(name) {
-			  return this.each(function() {
-				interrupt(this, name);
-			  });
-			};
-
-			function tweenRemove(id, name) {
-			  var tween0, tween1;
-			  return function() {
-				var schedule = set$3(this, id),
-					tween = schedule.tween;
-
-				// If this node shared tween with the previous node,
-				// just assign the updated shared tween and we’re done!
-				// Otherwise, copy-on-write.
-				if (tween !== tween0) {
-				  tween1 = tween0 = tween;
-				  for (var i = 0, n = tween1.length; i < n; ++i) {
-					if (tween1[i].name === name) {
-					  tween1 = tween1.slice();
-					  tween1.splice(i, 1);
-					  break;
-					}
-				  }
-				}
-
-				schedule.tween = tween1;
-			  };
-			}
-
-			function tweenFunction(id, name, value) {
-			  var tween0, tween1;
-			  if (typeof value !== "function") throw new Error;
-			  return function() {
-				var schedule = set$3(this, id),
-					tween = schedule.tween;
-
-				// If this node shared tween with the previous node,
-				// just assign the updated shared tween and we’re done!
-				// Otherwise, copy-on-write.
-				if (tween !== tween0) {
-				  tween1 = (tween0 = tween).slice();
-				  for (var t = {name: name, value: value}, i = 0, n = tween1.length; i < n; ++i) {
-					if (tween1[i].name === name) {
-					  tween1[i] = t;
-					  break;
-					}
-				  }
-				  if (i === n) tween1.push(t);
-				}
-
-				schedule.tween = tween1;
-			  };
-			}
-
-			var transition_tween = function(name, value) {
-			  var id = this._id;
-
-			  name += "";
-
-			  if (arguments.length < 2) {
-				var tween = get$1(this.node(), id).tween;
-				for (var i = 0, n = tween.length, t; i < n; ++i) {
-				  if ((t = tween[i]).name === name) {
-					return t.value;
-				  }
-				}
-				return null;
-			  }
-
-			  return this.each((value == null ? tweenRemove : tweenFunction)(id, name, value));
-			};
-
-			function tweenValue(transition, name, value) {
-			  var id = transition._id;
-
-			  transition.each(function() {
-				var schedule = set$3(this, id);
-				(schedule.value || (schedule.value = {}))[name] = value.apply(this, arguments);
-			  });
-
-			  return function(node) {
-				return get$1(node, id).value[name];
-			  };
-			}
-
-			var interpolate$1 = function(a, b) {
-			  var c;
-			  return (typeof b === "number" ? interpolateNumber
-				  : b instanceof color ? interpolateRgb
-				  : (c = color(b)) ? (b = c, interpolateRgb)
-				  : interpolateString)(a, b);
-			};
-
-			function attrRemove$1(name) {
-			  return function() {
-				this.removeAttribute(name);
-			  };
-			}
-
-			function attrRemoveNS$1(fullname) {
-			  return function() {
-				this.removeAttributeNS(fullname.space, fullname.local);
-			  };
-			}
-
-			function attrConstant$1(name, interpolate$$1, value1) {
-			  var value00,
-				  interpolate0;
-			  return function() {
-				var value0 = this.getAttribute(name);
-				return value0 === value1 ? null
-					: value0 === value00 ? interpolate0
-					: interpolate0 = interpolate$$1(value00 = value0, value1);
-			  };
-			}
-
-			function attrConstantNS$1(fullname, interpolate$$1, value1) {
-			  var value00,
-				  interpolate0;
-			  return function() {
-				var value0 = this.getAttributeNS(fullname.space, fullname.local);
-				return value0 === value1 ? null
-					: value0 === value00 ? interpolate0
-					: interpolate0 = interpolate$$1(value00 = value0, value1);
-			  };
-			}
-
-			function attrFunction$1(name, interpolate$$1, value) {
-			  var value00,
-				  value10,
-				  interpolate0;
-			  return function() {
-				var value0, value1 = value(this);
-				if (value1 == null) return void this.removeAttribute(name);
-				value0 = this.getAttribute(name);
-				return value0 === value1 ? null
-					: value0 === value00 && value1 === value10 ? interpolate0
-					: interpolate0 = interpolate$$1(value00 = value0, value10 = value1);
-			  };
-			}
-
-			function attrFunctionNS$1(fullname, interpolate$$1, value) {
-			  var value00,
-				  value10,
-				  interpolate0;
-			  return function() {
-				var value0, value1 = value(this);
-				if (value1 == null) return void this.removeAttributeNS(fullname.space, fullname.local);
-				value0 = this.getAttributeNS(fullname.space, fullname.local);
-				return value0 === value1 ? null
-					: value0 === value00 && value1 === value10 ? interpolate0
-					: interpolate0 = interpolate$$1(value00 = value0, value10 = value1);
-			  };
-			}
-
-			var transition_attr = function(name, value) {
-			  var fullname = namespace(name), i = fullname === "transform" ? interpolateTransformSvg : interpolate$1;
-			  return this.attrTween(name, typeof value === "function"
-				  ? (fullname.local ? attrFunctionNS$1 : attrFunction$1)(fullname, i, tweenValue(this, "attr." + name, value))
-				  : value == null ? (fullname.local ? attrRemoveNS$1 : attrRemove$1)(fullname)
-				  : (fullname.local ? attrConstantNS$1 : attrConstant$1)(fullname, i, value));
-			};
-
-			function attrTweenNS(fullname, value) {
-			  function tween() {
-				var node = this, i = value.apply(node, arguments);
-				return i && function(t) {
-				  node.setAttributeNS(fullname.space, fullname.local, i(t));
-				};
-			  }
-			  tween._value = value;
-			  return tween;
-			}
-
-			function attrTween(name, value) {
-			  function tween() {
-				var node = this, i = value.apply(node, arguments);
-				return i && function(t) {
-				  node.setAttribute(name, i(t));
-				};
-			  }
-			  tween._value = value;
-			  return tween;
-			}
-
-			var transition_attrTween = function(name, value) {
-			  var key = "attr." + name;
-			  if (arguments.length < 2) return (key = this.tween(key)) && key._value;
-			  if (value == null) return this.tween(key, null);
-			  if (typeof value !== "function") throw new Error;
-			  var fullname = namespace(name);
-			  return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value));
-			};
-
-			function delayFunction(id, value) {
-			  return function() {
-				init(this, id).delay = +value.apply(this, arguments);
-			  };
-			}
-
-			function delayConstant(id, value) {
-			  return value = +value, function() {
-				init(this, id).delay = value;
-			  };
-			}
-
-			var transition_delay = function(value) {
-			  var id = this._id;
-
-			  return arguments.length
-				  ? this.each((typeof value === "function"
-					  ? delayFunction
-					  : delayConstant)(id, value))
-				  : get$1(this.node(), id).delay;
-			};
-
-			function durationFunction(id, value) {
-			  return function() {
-				set$3(this, id).duration = +value.apply(this, arguments);
-			  };
-			}
-
-			function durationConstant(id, value) {
-			  return value = +value, function() {
-				set$3(this, id).duration = value;
-			  };
-			}
-
-			var transition_duration = function(value) {
-			  var id = this._id;
-
-			  return arguments.length
-				  ? this.each((typeof value === "function"
-					  ? durationFunction
-					  : durationConstant)(id, value))
-				  : get$1(this.node(), id).duration;
-			};
-
-			function easeConstant(id, value) {
-			  if (typeof value !== "function") throw new Error;
-			  return function() {
-				set$3(this, id).ease = value;
-			  };
-			}
-
-			var transition_ease = function(value) {
-			  var id = this._id;
-
-			  return arguments.length
-				  ? this.each(easeConstant(id, value))
-				  : get$1(this.node(), id).ease;
-			};
-
-			var transition_filter = function(match) {
-			  if (typeof match !== "function") match = matcher$1(match);
-
-			  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
-				for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {
-				  if ((node = group[i]) && match.call(node, node.__data__, i, group)) {
-					subgroup.push(node);
-				  }
-				}
-			  }
-
-			  return new Transition(subgroups, this._parents, this._name, this._id);
-			};
-
-			var transition_merge = function(transition) {
-			  if (transition._id !== this._id) throw new Error;
-
-			  for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {
-				for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {
-				  if (node = group0[i] || group1[i]) {
-					merge[i] = node;
-				  }
-				}
-			  }
-
-			  for (; j < m0; ++j) {
-				merges[j] = groups0[j];
-			  }
-
-			  return new Transition(merges, this._parents, this._name, this._id);
-			};
-
-			function start$1(name) {
-			  return (name + "").trim().split(/^|\s+/).every(function(t) {
-				var i = t.indexOf(".");
-				if (i >= 0) t = t.slice(0, i);
-				return !t || t === "start";
-			  });
-			}
-
-			function onFunction(id, name, listener) {
-			  var on0, on1, sit = start$1(name) ? init : set$3;
-			  return function() {
-				var schedule = sit(this, id),
-					on = schedule.on;
-
-				// If this node shared a dispatch with the previous node,
-				// just assign the updated shared dispatch and we’re done!
-				// Otherwise, copy-on-write.
-				if (on !== on0) (on1 = (on0 = on).copy()).on(name, listener);
-
-				schedule.on = on1;
-			  };
-			}
-
-			var transition_on = function(name, listener) {
-			  var id = this._id;
-
-			  return arguments.length < 2
-				  ? get$1(this.node(), id).on.on(name)
-				  : this.each(onFunction(id, name, listener));
-			};
-
-			function removeFunction(id) {
-			  return function() {
-				var parent = this.parentNode;
-				for (var i in this.__transition) if (+i !== id) return;
-				if (parent) parent.removeChild(this);
-			  };
-			}
-
-			var transition_remove = function() {
-			  return this.on("end.remove", removeFunction(this._id));
-			};
-
-			var transition_select = function(select$$1) {
-			  var name = this._name,
-				  id = this._id;
-
-			  if (typeof select$$1 !== "function") select$$1 = selector(select$$1);
-
-			  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
-				for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {
-				  if ((node = group[i]) && (subnode = select$$1.call(node, node.__data__, i, group))) {
-					if ("__data__" in node) subnode.__data__ = node.__data__;
-					subgroup[i] = subnode;
-					schedule(subgroup[i], name, id, i, subgroup, get$1(node, id));
-				  }
-				}
-			  }
-
-			  return new Transition(subgroups, this._parents, name, id);
-			};
-
-			var transition_selectAll = function(select$$1) {
-			  var name = this._name,
-				  id = this._id;
-
-			  if (typeof select$$1 !== "function") select$$1 = selectorAll(select$$1);
-
-			  for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {
-				for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
-				  if (node = group[i]) {
-					for (var children = select$$1.call(node, node.__data__, i, group), child, inherit = get$1(node, id), k = 0, l = children.length; k < l; ++k) {
-					  if (child = children[k]) {
-						schedule(child, name, id, k, children, inherit);
-					  }
-					}
-					subgroups.push(children);
-					parents.push(node);
-				  }
-				}
-			  }
-
-			  return new Transition(subgroups, parents, name, id);
-			};
-
-			var Selection$1 = selection.prototype.constructor;
-
-			var transition_selection = function() {
-			  return new Selection$1(this._groups, this._parents);
-			};
-
-			function styleRemove$1(name, interpolate$$1) {
-			  var value00,
-				  value10,
-				  interpolate0;
-			  return function() {
-				var style = window(this).getComputedStyle(this, null),
-					value0 = style.getPropertyValue(name),
-					value1 = (this.style.removeProperty(name), style.getPropertyValue(name));
-				return value0 === value1 ? null
-					: value0 === value00 && value1 === value10 ? interpolate0
-					: interpolate0 = interpolate$$1(value00 = value0, value10 = value1);
-			  };
-			}
-
-			function styleRemoveEnd(name) {
-			  return function() {
-				this.style.removeProperty(name);
-			  };
-			}
-
-			function styleConstant$1(name, interpolate$$1, value1) {
-			  var value00,
-				  interpolate0;
-			  return function() {
-				var value0 = window(this).getComputedStyle(this, null).getPropertyValue(name);
-				return value0 === value1 ? null
-					: value0 === value00 ? interpolate0
-					: interpolate0 = interpolate$$1(value00 = value0, value1);
-			  };
-			}
-
-			function styleFunction$1(name, interpolate$$1, value) {
-			  var value00,
-				  value10,
-				  interpolate0;
-			  return function() {
-				var style = window(this).getComputedStyle(this, null),
-					value0 = style.getPropertyValue(name),
-					value1 = value(this);
-				if (value1 == null) value1 = (this.style.removeProperty(name), style.getPropertyValue(name));
-				return value0 === value1 ? null
-					: value0 === value00 && value1 === value10 ? interpolate0
-					: interpolate0 = interpolate$$1(value00 = value0, value10 = value1);
-			  };
-			}
-
-			var transition_style = function(name, value, priority) {
-			  var i = (name += "") === "transform" ? interpolateTransformCss : interpolate$1;
-			  return value == null ? this
-					  .styleTween(name, styleRemove$1(name, i))
-					  .on("end.style." + name, styleRemoveEnd(name))
-				  : this.styleTween(name, typeof value === "function"
-					  ? styleFunction$1(name, i, tweenValue(this, "style." + name, value))
-					  : styleConstant$1(name, i, value), priority);
-			};
-
-			function styleTween(name, value, priority) {
-			  function tween() {
-				var node = this, i = value.apply(node, arguments);
-				return i && function(t) {
-				  node.style.setProperty(name, i(t), priority);
-				};
-			  }
-			  tween._value = value;
-			  return tween;
-			}
-
-			var transition_styleTween = function(name, value, priority) {
-			  var key = "style." + (name += "");
-			  if (arguments.length < 2) return (key = this.tween(key)) && key._value;
-			  if (value == null) return this.tween(key, null);
-			  if (typeof value !== "function") throw new Error;
-			  return this.tween(key, styleTween(name, value, priority == null ? "" : priority));
-			};
-
-			function textConstant$1(value) {
-			  return function() {
-				this.textContent = value;
-			  };
-			}
-
-			function textFunction$1(value) {
-			  return function() {
-				var value1 = value(this);
-				this.textContent = value1 == null ? "" : value1;
-			  };
-			}
-
-			var transition_text = function(value) {
-			  return this.tween("text", typeof value === "function"
-				  ? textFunction$1(tweenValue(this, "text", value))
-				  : textConstant$1(value == null ? "" : value + ""));
-			};
-
-			var transition_transition = function() {
-			  var name = this._name,
-				  id0 = this._id,
-				  id1 = newId();
-
-			  for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {
-				for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
-				  if (node = group[i]) {
-					var inherit = get$1(node, id0);
-					schedule(node, name, id1, i, group, {
-					  time: inherit.time + inherit.delay + inherit.duration,
-					  delay: 0,
-					  duration: inherit.duration,
-					  ease: inherit.ease
-					});
-				  }
-				}
-			  }
-
-			  return new Transition(groups, this._parents, name, id1);
-			};
-
-			var id = 0;
-
-			function Transition(groups, parents, name, id) {
-			  this._groups = groups;
-			  this._parents = parents;
-			  this._name = name;
-			  this._id = id;
-			}
-
-			function transition(name) {
-			  return selection().transition(name);
-			}
-
-			function newId() {
-			  return ++id;
-			}
-
-			var selection_prototype = selection.prototype;
-
-			Transition.prototype = transition.prototype = {
-			  constructor: Transition,
-			  select: transition_select,
-			  selectAll: transition_selectAll,
-			  filter: transition_filter,
-			  merge: transition_merge,
-			  selection: transition_selection,
-			  transition: transition_transition,
-			  call: selection_prototype.call,
-			  nodes: selection_prototype.nodes,
-			  node: selection_prototype.node,
-			  size: selection_prototype.size,
-			  empty: selection_prototype.empty,
-			  each: selection_prototype.each,
-			  on: transition_on,
-			  attr: transition_attr,
-			  attrTween: transition_attrTween,
-			  style: transition_style,
-			  styleTween: transition_styleTween,
-			  text: transition_text,
-			  remove: transition_remove,
-			  tween: transition_tween,
-			  delay: transition_delay,
-			  duration: transition_duration,
-			  ease: transition_ease
-			};
-
-			var defaultTiming = {
-			  time: null, // Set on use.
-			  delay: 0,
-			  duration: 250,
-			  ease: cubicInOut
-			};
-
-			function inherit(node, id) {
-			  var timing;
-			  while (!(timing = node.__transition) || !(timing = timing[id])) {
-				if (!(node = node.parentNode)) {
-				  return defaultTiming.time = now(), defaultTiming;
-				}
-			  }
-			  return timing;
-			}
-
-			var selection_transition = function(name) {
-			  var id,
-				  timing;
-
-			  if (name instanceof Transition) {
-				id = name._id, name = name._name;
-			  } else {
-				id = newId(), (timing = defaultTiming).time = now(), name = name == null ? null : name + "";
-			  }
-
-			  for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {
-				for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
-				  if (node = group[i]) {
-					schedule(node, name, id, i, group, timing || inherit(node, id));
-				  }
-				}
-			  }
-
-			  return new Transition(groups, this._parents, name, id);
-			};
-
-			selection.prototype.interrupt = selection_interrupt;
-			selection.prototype.transition = selection_transition;
-
-			var root$1 = [null];
-
-			var active = function(node, name) {
-			  var schedules = node.__transition,
-				  schedule,
-				  i;
-
-			  if (schedules) {
-				name = name == null ? null : name + "";
-				for (i in schedules) {
-				  if ((schedule = schedules[i]).state > SCHEDULED && schedule.name === name) {
-					return new Transition([[node]], root$1, name, +i);
-				  }
-				}
-			  }
-
-			  return null;
-			};
-
-			var slice$4 = Array.prototype.slice;
-
-			var identity$5 = function(x) {
-			  return x;
-			};
-
-			var top = 1;
-			var right = 2;
-			var bottom = 3;
-			var left = 4;
-			var epsilon$2 = 1e-6;
-
-			function translateX(scale0, scale1, d) {
-			  var x = scale0(d);
-			  return "translate(" + (isFinite(x) ? x : scale1(d)) + ",0)";
-			}
-
-			function translateY(scale0, scale1, d) {
-			  var y = scale0(d);
-			  return "translate(0," + (isFinite(y) ? y : scale1(d)) + ")";
-			}
-
-			function center(scale) {
-			  var offset = scale.bandwidth() / 2;
-			  if (scale.round()) offset = Math.round(offset);
-			  return function(d) {
-				return scale(d) + offset;
-			  };
-			}
-
-			function entering() {
-			  return !this.__axis;
-			}
-
-			function axis(orient, scale) {
-			  var tickArguments = [],
-				  tickValues = null,
-				  tickFormat = null,
-				  tickSizeInner = 6,
-				  tickSizeOuter = 6,
-				  tickPadding = 3;
-
-			  function axis(context) {
-				var values = tickValues == null ? (scale.ticks ? scale.ticks.apply(scale, tickArguments) : scale.domain()) : tickValues,
-					format = tickFormat == null ? (scale.tickFormat ? scale.tickFormat.apply(scale, tickArguments) : identity$5) : tickFormat,
-					spacing = Math.max(tickSizeInner, 0) + tickPadding,
-					transform = orient === top || orient === bottom ? translateX : translateY,
-					range = scale.range(),
-					range0 = range[0] + 0.5,
-					range1 = range[range.length - 1] + 0.5,
-					position = (scale.bandwidth ? center : identity$5)(scale.copy()),
-					selection = context.selection ? context.selection() : context,
-					path = selection.selectAll(".domain").data([null]),
-					tick = selection.selectAll(".tick").data(values, scale).order(),
-					tickExit = tick.exit(),
-					tickEnter = tick.enter().append("g").attr("class", "tick"),
-					line = tick.select("line"),
-					text = tick.select("text"),
-					k = orient === top || orient === left ? -1 : 1,
-					x, y = orient === left || orient === right ? (x = "x", "y") : (x = "y", "x");
-
-				path = path.merge(path.enter().insert("path", ".tick")
-					.attr("class", "domain")
-					.attr("stroke", "#000"));
-
-				tick = tick.merge(tickEnter);
-
-				line = line.merge(tickEnter.append("line")
-					.attr("stroke", "#000")
-					.attr(x + "2", k * tickSizeInner)
-					.attr(y + "1", 0.5)
-					.attr(y + "2", 0.5));
-
-				text = text.merge(tickEnter.append("text")
-					.attr("fill", "#000")
-					.attr(x, k * spacing)
-					.attr(y, 0.5)
-					.attr("dy", orient === top ? "0em" : orient === bottom ? "0.71em" : "0.32em"));
-
-				if (context !== selection) {
-				  path = path.transition(context);
-				  tick = tick.transition(context);
-				  line = line.transition(context);
-				  text = text.transition(context);
-
-				  tickExit = tickExit.transition(context)
-					  .attr("opacity", epsilon$2)
-					  .attr("transform", function(d) { return transform(position, this.parentNode.__axis || position, d); });
-
-				  tickEnter
-					  .attr("opacity", epsilon$2)
-					  .attr("transform", function(d) { return transform(this.parentNode.__axis || position, position, d); });
-				}
-
-				tickExit.remove();
-
-				path
-					.attr("d", orient === left || orient == right
-						? "M" + k * tickSizeOuter + "," + range0 + "H0.5V" + range1 + "H" + k * tickSizeOuter
-						: "M" + range0 + "," + k * tickSizeOuter + "V0.5H" + range1 + "V" + k * tickSizeOuter);
-
-				tick
-					.attr("opacity", 1)
-					.attr("transform", function(d) { return transform(position, position, d); });
-
-				line
-					.attr(x + "2", k * tickSizeInner);
-
-				text
-					.attr(x, k * spacing)
-					.text(format);
-
-				selection.filter(entering)
-					.attr("fill", "none")
-					.attr("font-size", 10)
-					.attr("font-family", "sans-serif")
-					.attr("text-anchor", orient === right ? "start" : orient === left ? "end" : "middle");
-
-				selection
-					.each(function() { this.__axis = position; });
-			  }
-
-			  axis.scale = function(_) {
-				return arguments.length ? (scale = _, axis) : scale;
-			  };
-
-			  axis.ticks = function() {
-				return tickArguments = slice$4.call(arguments), axis;
-			  };
-
-			  axis.tickArguments = function(_) {
-				return arguments.length ? (tickArguments = _ == null ? [] : slice$4.call(_), axis) : tickArguments.slice();
-			  };
-
-			  axis.tickValues = function(_) {
-				return arguments.length ? (tickValues = _ == null ? null : slice$4.call(_), axis) : tickValues && tickValues.slice();
-			  };
-
-			  axis.tickFormat = function(_) {
-				return arguments.length ? (tickFormat = _, axis) : tickFormat;
-			  };
-
-			  axis.tickSize = function(_) {
-				return arguments.length ? (tickSizeInner = tickSizeOuter = +_, axis) : tickSizeInner;
-			  };
-
-			  axis.tickSizeInner = function(_) {
-				return arguments.length ? (tickSizeInner = +_, axis) : tickSizeInner;
-			  };
-
-			  axis.tickSizeOuter = function(_) {
-				return arguments.length ? (tickSizeOuter = +_, axis) : tickSizeOuter;
-			  };
-
-			  axis.tickPadding = function(_) {
-				return arguments.length ? (tickPadding = +_, axis) : tickPadding;
-			  };
-
-			  return axis;
-			}
-
-			function axisTop(scale) {
-			  return axis(top, scale);
-			}
-
-			function axisRight(scale) {
-			  return axis(right, scale);
-			}
-
-			function axisBottom(scale) {
-			  return axis(bottom, scale);
-			}
-
-			function axisLeft(scale) {
-			  return axis(left, scale);
-			}
-
-			function defaultSeparation(a, b) {
-			  return a.parent === b.parent ? 1 : 2;
-			}
-
-			function meanX(children) {
-			  return children.reduce(meanXReduce, 0) / children.length;
-			}
-
-			function meanXReduce(x, c) {
-			  return x + c.x;
-			}
-
-			function maxY(children) {
-			  return 1 + children.reduce(maxYReduce, 0);
-			}
-
-			function maxYReduce(y, c) {
-			  return Math.max(y, c.y);
-			}
-
-			function leafLeft(node) {
-			  var children;
-			  while (children = node.children) node = children[0];
-			  return node;
-			}
-
-			function leafRight(node) {
-			  var children;
-			  while (children = node.children) node = children[children.length - 1];
-			  return node;
-			}
-
-			var cluster = function() {
-			  var separation = defaultSeparation,
-				  dx = 1,
-				  dy = 1,
-				  nodeSize = false;
-
-			  function cluster(root) {
-				var previousNode,
-					x = 0;
-
-				// First walk, computing the initial x & y values.
-				root.eachAfter(function(node) {
-				  var children = node.children;
-				  if (children) {
-					node.x = meanX(children);
-					node.y = maxY(children);
-				  } else {
-					node.x = previousNode ? x += separation(node, previousNode) : 0;
-					node.y = 0;
-					previousNode = node;
-				  }
-				});
-
-				var left = leafLeft(root),
-					right = leafRight(root),
-					x0 = left.x - separation(left, right) / 2,
-					x1 = right.x + separation(right, left) / 2;
-
-				// Second walk, normalizing x & y to the desired size.
-				return root.eachAfter(nodeSize ? function(node) {
-				  node.x = (node.x - root.x) * dx;
-				  node.y = (root.y - node.y) * dy;
-				} : function(node) {
-				  node.x = (node.x - x0) / (x1 - x0) * dx;
-				  node.y = (1 - (root.y ? node.y / root.y : 1)) * dy;
-				});
-			  }
-
-			  cluster.separation = function(x) {
-				return arguments.length ? (separation = x, cluster) : separation;
-			  };
-
-			  cluster.size = function(x) {
-				return arguments.length ? (nodeSize = false, dx = +x[0], dy = +x[1], cluster) : (nodeSize ? null : [dx, dy]);
-			  };
-
-			  cluster.nodeSize = function(x) {
-				return arguments.length ? (nodeSize = true, dx = +x[0], dy = +x[1], cluster) : (nodeSize ? [dx, dy] : null);
-			  };
-
-			  return cluster;
-			};
-
-			var node_each = function(callback) {
-			  var node = this, current, next = [node], children, i, n;
-			  do {
-				current = next.reverse(), next = [];
-				while (node = current.pop()) {
-				  callback(node), children = node.children;
-				  if (children) for (i = 0, n = children.length; i < n; ++i) {
-					next.push(children[i]);
-				  }
-				}
-			  } while (next.length);
-			  return this;
-			};
-
-			var node_eachBefore = function(callback) {
-			  var node = this, nodes = [node], children, i;
-			  while (node = nodes.pop()) {
-				callback(node), children = node.children;
-				if (children) for (i = children.length - 1; i >= 0; --i) {
-				  nodes.push(children[i]);
-				}
-			  }
-			  return this;
-			};
-
-			var node_eachAfter = function(callback) {
-			  var node = this, nodes = [node], next = [], children, i, n;
-			  while (node = nodes.pop()) {
-				next.push(node), children = node.children;
-				if (children) for (i = 0, n = children.length; i < n; ++i) {
-				  nodes.push(children[i]);
-				}
-			  }
-			  while (node = next.pop()) {
-				callback(node);
-			  }
-			  return this;
-			};
-
-			var node_sum = function(value) {
-			  return this.eachAfter(function(node) {
-				var sum = +value(node.data) || 0,
-					children = node.children,
-					i = children && children.length;
-				while (--i >= 0) sum += children[i].value;
-				node.value = sum;
-			  });
-			};
-
-			var node_sort = function(compare) {
-			  return this.eachBefore(function(node) {
-				if (node.children) {
-				  node.children.sort(compare);
-				}
-			  });
-			};
-
-			var node_path = function(end) {
-			  var start = this,
-				  ancestor = leastCommonAncestor(start, end),
-				  nodes = [start];
-			  while (start !== ancestor) {
-				start = start.parent;
-				nodes.push(start);
-			  }
-			  var k = nodes.length;
-			  while (end !== ancestor) {
-				nodes.splice(k, 0, end);
-				end = end.parent;
-			  }
-			  return nodes;
-			};
-
-			function leastCommonAncestor(a, b) {
-			  if (a === b) return a;
-			  var aNodes = a.ancestors(),
-				  bNodes = b.ancestors(),
-				  c = null;
-			  a = aNodes.pop();
-			  b = bNodes.pop();
-			  while (a === b) {
-				c = a;
-				a = aNodes.pop();
-				b = bNodes.pop();
-			  }
-			  return c;
-			}
-
-			var node_ancestors = function() {
-			  var node = this, nodes = [node];
-			  while (node = node.parent) {
-				nodes.push(node);
-			  }
-			  return nodes;
-			};
-
-			var node_descendants = function() {
-			  var nodes = [];
-			  this.each(function(node) {
-				nodes.push(node);
-			  });
-			  return nodes;
-			};
-
-			var node_leaves = function() {
-			  var leaves = [];
-			  this.eachBefore(function(node) {
-				if (!node.children) {
-				  leaves.push(node);
-				}
-			  });
-			  return leaves;
-			};
-
-			var node_links = function() {
-			  var root = this, links = [];
-			  root.each(function(node) {
-				if (node !== root) { // Don’t include the root’s parent, if any.
-				  links.push({source: node.parent, target: node});
-				}
-			  });
-			  return links;
-			};
-
-			function hierarchy(data, children) {
-			  var root = new Node(data),
-				  valued = +data.value && (root.value = data.value),
-				  node,
-				  nodes = [root],
-				  child,
-				  childs,
-				  i,
-				  n;
-
-			  if (children == null) children = defaultChildren;
-
-			  while (node = nodes.pop()) {
-				if (valued) node.value = +node.data.value;
-				if ((childs = children(node.data)) && (n = childs.length)) {
-				  node.children = new Array(n);
-				  for (i = n - 1; i >= 0; --i) {
-					nodes.push(child = node.children[i] = new Node(childs[i]));
-					child.parent = node;
-					child.depth = node.depth + 1;
-				  }
-				}
-			  }
-
-			  return root.eachBefore(computeHeight);
-			}
-
-			function node_copy() {
-			  return hierarchy(this).eachBefore(copyData);
-			}
-
-			function defaultChildren(d) {
-			  return d.children;
-			}
-
-			function copyData(node) {
-			  node.data = node.data.data;
-			}
-
-			function computeHeight(node) {
-			  var height = 0;
-			  do node.height = height;
-			  while ((node = node.parent) && (node.height < ++height));
-			}
-
-			function Node(data) {
-			  this.data = data;
-			  this.depth =
-			  this.height = 0;
-			  this.parent = null;
-			}
-
-			Node.prototype = hierarchy.prototype = {
-			  constructor: Node,
-			  each: node_each,
-			  eachAfter: node_eachAfter,
-			  eachBefore: node_eachBefore,
-			  sum: node_sum,
-			  sort: node_sort,
-			  path: node_path,
-			  ancestors: node_ancestors,
-			  descendants: node_descendants,
-			  leaves: node_leaves,
-			  links: node_links,
-			  copy: node_copy
-			};
-
-			function Node$2(value) {
-			  this._ = value;
-			  this.next = null;
-			}
-
-			var shuffle$1 = function(array) {
-			  var i,
-				  n = (array = array.slice()).length,
-				  head = null,
-				  node = head;
-
-			  while (n) {
-				var next = new Node$2(array[n - 1]);
-				if (node) node = node.next = next;
-				else node = head = next;
-				array[i] = array[--n];
-			  }
-
-			  return {
-				head: head,
-				tail: node
-			  };
-			};
-
-			var enclose = function(circles) {
-			  return encloseN(shuffle$1(circles), []);
-			};
-
-			function encloses(a, b) {
-			  var dx = b.x - a.x,
-				  dy = b.y - a.y,
-				  dr = a.r - b.r;
-			  return dr * dr + 1e-6 > dx * dx + dy * dy;
-			}
-
-			// Returns the smallest circle that contains circles L and intersects circles B.
-			function encloseN(L, B) {
-			  var circle,
-				  l0 = null,
-				  l1 = L.head,
-				  l2,
-				  p1;
-
-			  switch (B.length) {
-				case 1: circle = enclose1(B[0]); break;
-				case 2: circle = enclose2(B[0], B[1]); break;
-				case 3: circle = enclose3(B[0], B[1], B[2]); break;
-			  }
-
-			  while (l1) {
-				p1 = l1._, l2 = l1.next;
-				if (!circle || !encloses(circle, p1)) {
-
-				  // Temporarily truncate L before l1.
-				  if (l0) L.tail = l0, l0.next = null;
-				  else L.head = L.tail = null;
-
-				  B.push(p1);
-				  circle = encloseN(L, B); // Note: reorders L!
-				  B.pop();
-
-				  // Move l1 to the front of L and reconnect the truncated list L.
-				  if (L.head) l1.next = L.head, L.head = l1;
-				  else l1.next = null, L.head = L.tail = l1;
-				  l0 = L.tail, l0.next = l2;
-
-				} else {
-				  l0 = l1;
-				}
-				l1 = l2;
-			  }
-
-			  L.tail = l0;
-			  return circle;
-			}
-
-			function enclose1(a) {
-			  return {
-				x: a.x,
-				y: a.y,
-				r: a.r
-			  };
-			}
-
-			function enclose2(a, b) {
-			  var x1 = a.x, y1 = a.y, r1 = a.r,
-				  x2 = b.x, y2 = b.y, r2 = b.r,
-				  x21 = x2 - x1, y21 = y2 - y1, r21 = r2 - r1,
-				  l = Math.sqrt(x21 * x21 + y21 * y21);
-			  return {
-				x: (x1 + x2 + x21 / l * r21) / 2,
-				y: (y1 + y2 + y21 / l * r21) / 2,
-				r: (l + r1 + r2) / 2
-			  };
-			}
-
-			function enclose3(a, b, c) {
-			  var x1 = a.x, y1 = a.y, r1 = a.r,
-				  x2 = b.x, y2 = b.y, r2 = b.r,
-				  x3 = c.x, y3 = c.y, r3 = c.r,
-				  a2 = 2 * (x1 - x2),
-				  b2 = 2 * (y1 - y2),
-				  c2 = 2 * (r2 - r1),
-				  d2 = x1 * x1 + y1 * y1 - r1 * r1 - x2 * x2 - y2 * y2 + r2 * r2,
-				  a3 = 2 * (x1 - x3),
-				  b3 = 2 * (y1 - y3),
-				  c3 = 2 * (r3 - r1),
-				  d3 = x1 * x1 + y1 * y1 - r1 * r1 - x3 * x3 - y3 * y3 + r3 * r3,
-				  ab = a3 * b2 - a2 * b3,
-				  xa = (b2 * d3 - b3 * d2) / ab - x1,
-				  xb = (b3 * c2 - b2 * c3) / ab,
-				  ya = (a3 * d2 - a2 * d3) / ab - y1,
-				  yb = (a2 * c3 - a3 * c2) / ab,
-				  A = xb * xb + yb * yb - 1,
-				  B = 2 * (xa * xb + ya * yb + r1),
-				  C = xa * xa + ya * ya - r1 * r1,
-				  r = (-B - Math.sqrt(B * B - 4 * A * C)) / (2 * A);
-			  return {
-				x: xa + xb * r + x1,
-				y: ya + yb * r + y1,
-				r: r
-			  };
-			}
-
-			function place(a, b, c) {
-			  var ax = a.x,
-				  ay = a.y,
-				  da = b.r + c.r,
-				  db = a.r + c.r,
-				  dx = b.x - ax,
-				  dy = b.y - ay,
-				  dc = dx * dx + dy * dy;
-			  if (dc) {
-				var x = 0.5 + ((db *= db) - (da *= da)) / (2 * dc),
-					y = Math.sqrt(Math.max(0, 2 * da * (db + dc) - (db -= dc) * db - da * da)) / (2 * dc);
-				c.x = ax + x * dx + y * dy;
-				c.y = ay + x * dy - y * dx;
-			  } else {
-				c.x = ax + db;
-				c.y = ay;
-			  }
-			}
-
-			function intersects(a, b) {
-			  var dx = b.x - a.x,
-				  dy = b.y - a.y,
-				  dr = a.r + b.r;
-			  return dr * dr > dx * dx + dy * dy;
-			}
-
-			function distance2(circle, x, y) {
-			  var dx = circle.x - x,
-				  dy = circle.y - y;
-			  return dx * dx + dy * dy;
-			}
-
-			function Node$1(circle) {
-			  this._ = circle;
-			  this.next = null;
-			  this.previous = null;
-			}
-
-			function packEnclose(circles) {
-			  if (!(n = circles.length)) return 0;
-
-			  var a, b, c, n;
-
-			  // Place the first circle.
-			  a = circles[0], a.x = 0, a.y = 0;
-			  if (!(n > 1)) return a.r;
-
-			  // Place the second circle.
-			  b = circles[1], a.x = -b.r, b.x = a.r, b.y = 0;
-			  if (!(n > 2)) return a.r + b.r;
-
-			  // Place the third circle.
-			  place(b, a, c = circles[2]);
-
-			  // Initialize the weighted centroid.
-			  var aa = a.r * a.r,
-				  ba = b.r * b.r,
-				  ca = c.r * c.r,
-				  oa = aa + ba + ca,
-				  ox = aa * a.x + ba * b.x + ca * c.x,
-				  oy = aa * a.y + ba * b.y + ca * c.y,
-				  cx, cy, i, j, k, sj, sk;
-
-			  // Initialize the front-chain using the first three circles a, b and c.
-			  a = new Node$1(a), b = new Node$1(b), c = new Node$1(c);
-			  a.next = c.previous = b;
-			  b.next = a.previous = c;
-			  c.next = b.previous = a;
-
-			  // Attempt to place each remaining circle…
-			  pack: for (i = 3; i < n; ++i) {
-				place(a._, b._, c = circles[i]), c = new Node$1(c);
-
-				// If there are only three elements in the front-chain…
-				if ((k = a.previous) === (j = b.next)) {
-				  // If the new circle intersects the third circle,
-				  // rotate the front chain to try the next position.
-				  if (intersects(j._, c._)) {
-					a = b, b = j, --i;
-					continue pack;
-				  }
-				}
-
-				// Find the closest intersecting circle on the front-chain, if any.
-				else {
-				  sj = j._.r, sk = k._.r;
-				  do {
-					if (sj <= sk) {
-					  if (intersects(j._, c._)) {
-						b = j, a.next = b, b.previous = a, --i;
-						continue pack;
-					  }
-					  j = j.next, sj += j._.r;
-					} else {
-					  if (intersects(k._, c._)) {
-						a = k, a.next = b, b.previous = a, --i;
-						continue pack;
-					  }
-					  k = k.previous, sk += k._.r;
-					}
-				  } while (j !== k.next);
-				}
-
-				// Success! Insert the new circle c between a and b.
-				c.previous = a, c.next = b, a.next = b.previous = b = c;
-
-				// Update the weighted centroid.
-				oa += ca = c._.r * c._.r;
-				ox += ca * c._.x;
-				oy += ca * c._.y;
-
-				// Compute the new closest circle a to centroid.
-				aa = distance2(a._, cx = ox / oa, cy = oy / oa);
-				while ((c = c.next) !== b) {
-				  if ((ca = distance2(c._, cx, cy)) < aa) {
-					a = c, aa = ca;
-				  }
-				}
-				b = a.next;
-			  }
-
-			  // Compute the enclosing circle of the front chain.
-			  a = [b._], c = b; while ((c = c.next) !== b) a.push(c._); c = enclose(a);
-
-			  // Translate the circles to put the enclosing circle around the origin.
-			  for (i = 0; i < n; ++i) a = circles[i], a.x -= c.x, a.y -= c.y;
-
-			  return c.r;
-			}
-
-			var siblings = function(circles) {
-			  packEnclose(circles);
-			  return circles;
-			};
-
-			function optional(f) {
-			  return f == null ? null : required(f);
-			}
-
-			function required(f) {
-			  if (typeof f !== "function") throw new Error;
-			  return f;
-			}
-
-			function constantZero() {
-			  return 0;
-			}
-
-			var constant$6 = function(x) {
-			  return function() {
-				return x;
-			  };
-			};
-
-			function defaultRadius(d) {
-			  return Math.sqrt(d.value);
-			}
-
-			var index = function() {
-			  var radius = null,
-				  dx = 1,
-				  dy = 1,
-				  padding = constantZero;
-
-			  function pack(root) {
-				root.x = dx / 2, root.y = dy / 2;
-				if (radius) {
-				  root.eachBefore(radiusLeaf(radius))
-					  .eachAfter(packChildren(padding, 0.5))
-					  .eachBefore(translateChild(1));
-				} else {
-				  root.eachBefore(radiusLeaf(defaultRadius))
-					  .eachAfter(packChildren(constantZero, 1))
-					  .eachAfter(packChildren(padding, root.r / Math.min(dx, dy)))
-					  .eachBefore(translateChild(Math.min(dx, dy) / (2 * root.r)));
-				}
-				return root;
-			  }
-
-			  pack.radius = function(x) {
-				return arguments.length ? (radius = optional(x), pack) : radius;
-			  };
-
-			  pack.size = function(x) {
-				return arguments.length ? (dx = +x[0], dy = +x[1], pack) : [dx, dy];
-			  };
-
-			  pack.padding = function(x) {
-				return arguments.length ? (padding = typeof x === "function" ? x : constant$6(+x), pack) : padding;
-			  };
-
-			  return pack;
-			};
-
-			function radiusLeaf(radius) {
-			  return function(node) {
-				if (!node.children) {
-				  node.r = Math.max(0, +radius(node) || 0);
-				}
-			  };
-			}
-
-			function packChildren(padding, k) {
-			  return function(node) {
-				if (children = node.children) {
-				  var children,
-					  i,
-					  n = children.length,
-					  r = padding(node) * k || 0,
-					  e;
-
-				  if (r) for (i = 0; i < n; ++i) children[i].r += r;
-				  e = packEnclose(children);
-				  if (r) for (i = 0; i < n; ++i) children[i].r -= r;
-				  node.r = e + r;
-				}
-			  };
-			}
-
-			function translateChild(k) {
-			  return function(node) {
-				var parent = node.parent;
-				node.r *= k;
-				if (parent) {
-				  node.x = parent.x + k * node.x;
-				  node.y = parent.y + k * node.y;
-				}
-			  };
-			}
-
-			var roundNode = function(node) {
-			  node.x0 = Math.round(node.x0);
-			  node.y0 = Math.round(node.y0);
-			  node.x1 = Math.round(node.x1);
-			  node.y1 = Math.round(node.y1);
-			};
-
-			var treemapDice = function(parent, x0, y0, x1, y1) {
-			  var nodes = parent.children,
-				  node,
-				  i = -1,
-				  n = nodes.length,
-				  k = parent.value && (x1 - x0) / parent.value;
-
-			  while (++i < n) {
-				node = nodes[i], node.y0 = y0, node.y1 = y1;
-				node.x0 = x0, node.x1 = x0 += node.value * k;
-			  }
-			};
-
-			var partition = function() {
-			  var dx = 1,
-				  dy = 1,
-				  padding = 0,
-				  round = false;
-
-			  function partition(root) {
-				var n = root.height + 1;
-				root.x0 =
-				root.y0 = padding;
-				root.x1 = dx;
-				root.y1 = dy / n;
-				root.eachBefore(positionNode(dy, n));
-				if (round) root.eachBefore(roundNode);
-				return root;
-			  }
-
-			  function positionNode(dy, n) {
-				return function(node) {
-				  if (node.children) {
-					treemapDice(node, node.x0, dy * (node.depth + 1) / n, node.x1, dy * (node.depth + 2) / n);
-				  }
-				  var x0 = node.x0,
-					  y0 = node.y0,
-					  x1 = node.x1 - padding,
-					  y1 = node.y1 - padding;
-				  if (x1 < x0) x0 = x1 = (x0 + x1) / 2;
-				  if (y1 < y0) y0 = y1 = (y0 + y1) / 2;
-				  node.x0 = x0;
-				  node.y0 = y0;
-				  node.x1 = x1;
-				  node.y1 = y1;
-				};
-			  }
-
-			  partition.round = function(x) {
-				return arguments.length ? (round = !!x, partition) : round;
-			  };
-
-			  partition.size = function(x) {
-				return arguments.length ? (dx = +x[0], dy = +x[1], partition) : [dx, dy];
-			  };
-
-			  partition.padding = function(x) {
-				return arguments.length ? (padding = +x, partition) : padding;
-			  };
-
-			  return partition;
-			};
-
-			var keyPrefix$1 = "$";
-			var preroot = {depth: -1};
-			var ambiguous = {};
-
-			function defaultId(d) {
-			  return d.id;
-			}
-
-			function defaultParentId(d) {
-			  return d.parentId;
-			}
-
-			var stratify = function() {
-			  var id = defaultId,
-				  parentId = defaultParentId;
-
-			  function stratify(data) {
-				var d,
-					i,
-					n = data.length,
-					root,
-					parent,
-					node,
-					nodes = new Array(n),
-					nodeId,
-					nodeKey,
-					nodeByKey = {};
-
-				for (i = 0; i < n; ++i) {
-				  d = data[i], node = nodes[i] = new Node(d);
-				  if ((nodeId = id(d, i, data)) != null && (nodeId += "")) {
-					nodeKey = keyPrefix$1 + (node.id = nodeId);
-					nodeByKey[nodeKey] = nodeKey in nodeByKey ? ambiguous : node;
-				  }
-				}
-
-				for (i = 0; i < n; ++i) {
-				  node = nodes[i], nodeId = parentId(data[i], i, data);
-				  if (nodeId == null || !(nodeId += "")) {
-					if (root) throw new Error("multiple roots");
-					root = node;
-				  } else {
-					parent = nodeByKey[keyPrefix$1 + nodeId];
-					if (!parent) throw new Error("missing: " + nodeId);
-					if (parent === ambiguous) throw new Error("ambiguous: " + nodeId);
-					if (parent.children) parent.children.push(node);
-					else parent.children = [node];
-					node.parent = parent;
-				  }
-				}
-
-				if (!root) throw new Error("no root");
-				root.parent = preroot;
-				root.eachBefore(function(node) { node.depth = node.parent.depth + 1; --n; }).eachBefore(computeHeight);
-				root.parent = null;
-				if (n > 0) throw new Error("cycle");
-
-				return root;
-			  }
-
-			  stratify.id = function(x) {
-				return arguments.length ? (id = required(x), stratify) : id;
-			  };
-
-			  stratify.parentId = function(x) {
-				return arguments.length ? (parentId = required(x), stratify) : parentId;
-			  };
-
-			  return stratify;
-			};
-
-			function defaultSeparation$1(a, b) {
-			  return a.parent === b.parent ? 1 : 2;
-			}
-
-			// function radialSeparation(a, b) {
-			//   return (a.parent === b.parent ? 1 : 2) / a.depth;
-			// }
-
-			// This function is used to traverse the left contour of a subtree (or
-			// subforest). It returns the successor of v on this contour. This successor is
-			// either given by the leftmost child of v or by the thread of v. The function
-			// returns null if and only if v is on the highest level of its subtree.
-			function nextLeft(v) {
-			  var children = v.children;
-			  return children ? children[0] : v.t;
-			}
-
-			// This function works analogously to nextLeft.
-			function nextRight(v) {
-			  var children = v.children;
-			  return children ? children[children.length - 1] : v.t;
-			}
-
-			// Shifts the current subtree rooted at w+. This is done by increasing
-			// prelim(w+) and mod(w+) by shift.
-			function moveSubtree(wm, wp, shift) {
-			  var change = shift / (wp.i - wm.i);
-			  wp.c -= change;
-			  wp.s += shift;
-			  wm.c += change;
-			  wp.z += shift;
-			  wp.m += shift;
-			}
-
-			// All other shifts, applied to the smaller subtrees between w- and w+, are
-			// performed by this function. To prepare the shifts, we have to adjust
-			// change(w+), shift(w+), and change(w-).
-			function executeShifts(v) {
-			  var shift = 0,
-				  change = 0,
-				  children = v.children,
-				  i = children.length,
-				  w;
-			  while (--i >= 0) {
-				w = children[i];
-				w.z += shift;
-				w.m += shift;
-				shift += w.s + (change += w.c);
-			  }
-			}
-
-			// If vi-’s ancestor is a sibling of v, returns vi-’s ancestor. Otherwise,
-			// returns the specified (default) ancestor.
-			function nextAncestor(vim, v, ancestor) {
-			  return vim.a.parent === v.parent ? vim.a : ancestor;
-			}
-
-			function TreeNode(node, i) {
-			  this._ = node;
-			  this.parent = null;
-			  this.children = null;
-			  this.A = null; // default ancestor
-			  this.a = this; // ancestor
-			  this.z = 0; // prelim
-			  this.m = 0; // mod
-			  this.c = 0; // change
-			  this.s = 0; // shift
-			  this.t = null; // thread
-			  this.i = i; // number
-			}
-
-			TreeNode.prototype = Object.create(Node.prototype);
-
-			function treeRoot(root) {
-			  var tree = new TreeNode(root, 0),
-				  node,
-				  nodes = [tree],
-				  child,
-				  children,
-				  i,
-				  n;
-
-			  while (node = nodes.pop()) {
-				if (children = node._.children) {
-				  node.children = new Array(n = children.length);
-				  for (i = n - 1; i >= 0; --i) {
-					nodes.push(child = node.children[i] = new TreeNode(children[i], i));
-					child.parent = node;
-				  }
-				}
-			  }
-
-			  (tree.parent = new TreeNode(null, 0)).children = [tree];
-			  return tree;
-			}
-
-			// Node-link tree diagram using the Reingold-Tilford "tidy" algorithm
-			var tree = function() {
-			  var separation = defaultSeparation$1,
-				  dx = 1,
-				  dy = 1,
-				  nodeSize = null;
-
-			  function tree(root) {
-				var t = treeRoot(root);
-
-				// Compute the layout using Buchheim et al.’s algorithm.
-				t.eachAfter(firstWalk), t.parent.m = -t.z;
-				t.eachBefore(secondWalk);
-
-				// If a fixed node size is specified, scale x and y.
-				if (nodeSize) root.eachBefore(sizeNode);
-
-				// If a fixed tree size is specified, scale x and y based on the extent.
-				// Compute the left-most, right-most, and depth-most nodes for extents.
-				else {
-				  var left = root,
-					  right = root,
-					  bottom = root;
-				  root.eachBefore(function(node) {
-					if (node.x < left.x) left = node;
-					if (node.x > right.x) right = node;
-					if (node.depth > bottom.depth) bottom = node;
-				  });
-				  var s = left === right ? 1 : separation(left, right) / 2,
-					  tx = s - left.x,
-					  kx = dx / (right.x + s + tx),
-					  ky = dy / (bottom.depth || 1);
-				  root.eachBefore(function(node) {
-					node.x = (node.x + tx) * kx;
-					node.y = node.depth * ky;
-				  });
-				}
-
-				return root;
-			  }
-
-			  // Computes a preliminary x-coordinate for v. Before that, FIRST WALK is
-			  // applied recursively to the children of v, as well as the function
-			  // APPORTION. After spacing out the children by calling EXECUTE SHIFTS, the
-			  // node v is placed to the midpoint of its outermost children.
-			  function firstWalk(v) {
-				var children = v.children,
-					siblings = v.parent.children,
-					w = v.i ? siblings[v.i - 1] : null;
-				if (children) {
-				  executeShifts(v);
-				  var midpoint = (children[0].z + children[children.length - 1].z) / 2;
-				  if (w) {
-					v.z = w.z + separation(v._, w._);
-					v.m = v.z - midpoint;
-				  } else {
-					v.z = midpoint;
-				  }
-				} else if (w) {
-				  v.z = w.z + separation(v._, w._);
-				}
-				v.parent.A = apportion(v, w, v.parent.A || siblings[0]);
-			  }
-
-			  // Computes all real x-coordinates by summing up the modifiers recursively.
-			  function secondWalk(v) {
-				v._.x = v.z + v.parent.m;
-				v.m += v.parent.m;
-			  }
-
-			  // The core of the algorithm. Here, a new subtree is combined with the
-			  // previous subtrees. Threads are used to traverse the inside and outside
-			  // contours of the left and right subtree up to the highest common level. The
-			  // vertices used for the traversals are vi+, vi-, vo-, and vo+, where the
-			  // superscript o means outside and i means inside, the subscript - means left
-			  // subtree and + means right subtree. For summing up the modifiers along the
-			  // contour, we use respective variables si+, si-, so-, and so+. Whenever two
-			  // nodes of the inside contours conflict, we compute the left one of the
-			  // greatest uncommon ancestors using the function ANCESTOR and call MOVE
-			  // SUBTREE to shift the subtree and prepare the shifts of smaller subtrees.
-			  // Finally, we add a new thread (if necessary).
-			  function apportion(v, w, ancestor) {
-				if (w) {
-				  var vip = v,
-					  vop = v,
-					  vim = w,
-					  vom = vip.parent.children[0],
-					  sip = vip.m,
-					  sop = vop.m,
-					  sim = vim.m,
-					  som = vom.m,
-					  shift;
-				  while (vim = nextRight(vim), vip = nextLeft(vip), vim && vip) {
-					vom = nextLeft(vom);
-					vop = nextRight(vop);
-					vop.a = v;
-					shift = vim.z + sim - vip.z - sip + separation(vim._, vip._);
-					if (shift > 0) {
-					  moveSubtree(nextAncestor(vim, v, ancestor), v, shift);
-					  sip += shift;
-					  sop += shift;
-					}
-					sim += vim.m;
-					sip += vip.m;
-					som += vom.m;
-					sop += vop.m;
-				  }
-				  if (vim && !nextRight(vop)) {
-					vop.t = vim;
-					vop.m += sim - sop;
-				  }
-				  if (vip && !nextLeft(vom)) {
-					vom.t = vip;
-					vom.m += sip - som;
-					ancestor = v;
-				  }
-				}
-				return ancestor;
-			  }
-
-			  function sizeNode(node) {
-				node.x *= dx;
-				node.y = node.depth * dy;
-			  }
-
-			  tree.separation = function(x) {
-				return arguments.length ? (separation = x, tree) : separation;
-			  };
-
-			  tree.size = function(x) {
-				return arguments.length ? (nodeSize = false, dx = +x[0], dy = +x[1], tree) : (nodeSize ? null : [dx, dy]);
-			  };
-
-			  tree.nodeSize = function(x) {
-				return arguments.length ? (nodeSize = true, dx = +x[0], dy = +x[1], tree) : (nodeSize ? [dx, dy] : null);
-			  };
-
-			  return tree;
-			};
-
-			var treemapSlice = function(parent, x0, y0, x1, y1) {
-			  var nodes = parent.children,
-				  node,
-				  i = -1,
-				  n = nodes.length,
-				  k = parent.value && (y1 - y0) / parent.value;
-
-			  while (++i < n) {
-				node = nodes[i], node.x0 = x0, node.x1 = x1;
-				node.y0 = y0, node.y1 = y0 += node.value * k;
-			  }
-			};
-
-			var phi = (1 + Math.sqrt(5)) / 2;
-
-			function squarifyRatio(ratio, parent, x0, y0, x1, y1) {
-			  var rows = [],
-				  nodes = parent.children,
-				  row,
-				  nodeValue,
-				  i0 = 0,
-				  i1,
-				  n = nodes.length,
-				  dx, dy,
-				  value = parent.value,
-				  sumValue,
-				  minValue,
-				  maxValue,
-				  newRatio,
-				  minRatio,
-				  alpha,
-				  beta;
-
-			  while (i0 < n) {
-				dx = x1 - x0, dy = y1 - y0;
-				minValue = maxValue = sumValue = nodes[i0].value;
-				alpha = Math.max(dy / dx, dx / dy) / (value * ratio);
-				beta = sumValue * sumValue * alpha;
-				minRatio = Math.max(maxValue / beta, beta / minValue);
-
-				// Keep adding nodes while the aspect ratio maintains or improves.
-				for (i1 = i0 + 1; i1 < n; ++i1) {
-				  sumValue += nodeValue = nodes[i1].value;
-				  if (nodeValue < minValue) minValue = nodeValue;
-				  if (nodeValue > maxValue) maxValue = nodeValue;
-				  beta = sumValue * sumValue * alpha;
-				  newRatio = Math.max(maxValue / beta, beta / minValue);
-				  if (newRatio > minRatio) { sumValue -= nodeValue; break; }
-				  minRatio = newRatio;
-				}
-
-				// Position and record the row orientation.
-				rows.push(row = {value: sumValue, dice: dx < dy, children: nodes.slice(i0, i1)});
-				if (row.dice) treemapDice(row, x0, y0, x1, value ? y0 += dy * sumValue / value : y1);
-				else treemapSlice(row, x0, y0, value ? x0 += dx * sumValue / value : x1, y1);
-				value -= sumValue, i0 = i1;
-			  }
-
-			  return rows;
-			}
-
-			var squarify = (function custom(ratio) {
-
-			  function squarify(parent, x0, y0, x1, y1) {
-				squarifyRatio(ratio, parent, x0, y0, x1, y1);
-			  }
-
-			  squarify.ratio = function(x) {
-				return custom((x = +x) > 1 ? x : 1);
-			  };
-
-			  return squarify;
-			})(phi);
-
-			var index$1 = function() {
-			  var tile = squarify,
-				  round = false,
-				  dx = 1,
-				  dy = 1,
-				  paddingStack = [0],
-				  paddingInner = constantZero,
-				  paddingTop = constantZero,
-				  paddingRight = constantZero,
-				  paddingBottom = constantZero,
-				  paddingLeft = constantZero;
-
-			  function treemap(root) {
-				root.x0 =
-				root.y0 = 0;
-				root.x1 = dx;
-				root.y1 = dy;
-				root.eachBefore(positionNode);
-				paddingStack = [0];
-				if (round) root.eachBefore(roundNode);
-				return root;
-			  }
-
-			  function positionNode(node) {
-				var p = paddingStack[node.depth],
-					x0 = node.x0 + p,
-					y0 = node.y0 + p,
-					x1 = node.x1 - p,
-					y1 = node.y1 - p;
-				if (x1 < x0) x0 = x1 = (x0 + x1) / 2;
-				if (y1 < y0) y0 = y1 = (y0 + y1) / 2;
-				node.x0 = x0;
-				node.y0 = y0;
-				node.x1 = x1;
-				node.y1 = y1;
-				if (node.children) {
-				  p = paddingStack[node.depth + 1] = paddingInner(node) / 2;
-				  x0 += paddingLeft(node) - p;
-				  y0 += paddingTop(node) - p;
-				  x1 -= paddingRight(node) - p;
-				  y1 -= paddingBottom(node) - p;
-				  if (x1 < x0) x0 = x1 = (x0 + x1) / 2;
-				  if (y1 < y0) y0 = y1 = (y0 + y1) / 2;
-				  tile(node, x0, y0, x1, y1);
-				}
-			  }
-
-			  treemap.round = function(x) {
-				return arguments.length ? (round = !!x, treemap) : round;
-			  };
-
-			  treemap.size = function(x) {
-				return arguments.length ? (dx = +x[0], dy = +x[1], treemap) : [dx, dy];
-			  };
-
-			  treemap.tile = function(x) {
-				return arguments.length ? (tile = required(x), treemap) : tile;
-			  };
-
-			  treemap.padding = function(x) {
-				return arguments.length ? treemap.paddingInner(x).paddingOuter(x) : treemap.paddingInner();
-			  };
-
-			  treemap.paddingInner = function(x) {
-				return arguments.length ? (paddingInner = typeof x === "function" ? x : constant$6(+x), treemap) : paddingInner;
-			  };
-
-			  treemap.paddingOuter = function(x) {
-				return arguments.length ? treemap.paddingTop(x).paddingRight(x).paddingBottom(x).paddingLeft(x) : treemap.paddingTop();
-			  };
-
-			  treemap.paddingTop = function(x) {
-				return arguments.length ? (paddingTop = typeof x === "function" ? x : constant$6(+x), treemap) : paddingTop;
-			  };
-
-			  treemap.paddingRight = function(x) {
-				return arguments.length ? (paddingRight = typeof x === "function" ? x : constant$6(+x), treemap) : paddingRight;
-			  };
-
-			  treemap.paddingBottom = function(x) {
-				return arguments.length ? (paddingBottom = typeof x === "function" ? x : constant$6(+x), treemap) : paddingBottom;
-			  };
-
-			  treemap.paddingLeft = function(x) {
-				return arguments.length ? (paddingLeft = typeof x === "function" ? x : constant$6(+x), treemap) : paddingLeft;
-			  };
-
-			  return treemap;
-			};
-
-			var binary = function(parent, x0, y0, x1, y1) {
-			  var nodes = parent.children,
-				  i, n = nodes.length,
-				  sum, sums = new Array(n + 1);
-
-			  for (sums[0] = sum = i = 0; i < n; ++i) {
-				sums[i + 1] = sum += nodes[i].value;
-			  }
-
-			  partition(0, n, parent.value, x0, y0, x1, y1);
-
-			  function partition(i, j, value, x0, y0, x1, y1) {
-				if (i >= j - 1) {
-				  var node = nodes[i];
-				  node.x0 = x0, node.y0 = y0;
-				  node.x1 = x1, node.y1 = y1;
-				  return;
-				}
-
-				var valueOffset = sums[i],
-					valueTarget = (value / 2) + valueOffset,
-					k = i + 1,
-					hi = j - 1;
-
-				while (k < hi) {
-				  var mid = k + hi >>> 1;
-				  if (sums[mid] < valueTarget) k = mid + 1;
-				  else hi = mid;
-				}
-
-				var valueLeft = sums[k] - valueOffset,
-					valueRight = value - valueLeft;
-
-				if ((y1 - y0) > (x1 - x0)) {
-				  var yk = (y0 * valueRight + y1 * valueLeft) / value;
-				  partition(i, k, valueLeft, x0, y0, x1, yk);
-				  partition(k, j, valueRight, x0, yk, x1, y1);
-				} else {
-				  var xk = (x0 * valueRight + x1 * valueLeft) / value;
-				  partition(i, k, valueLeft, x0, y0, xk, y1);
-				  partition(k, j, valueRight, xk, y0, x1, y1);
-				}
-			  }
-			};
-
-			var sliceDice = function(parent, x0, y0, x1, y1) {
-			  (parent.depth & 1 ? treemapSlice : treemapDice)(parent, x0, y0, x1, y1);
-			};
-
-			var resquarify = (function custom(ratio) {
-
-			  function resquarify(parent, x0, y0, x1, y1) {
-				if ((rows = parent._squarify) && (rows.ratio === ratio)) {
-				  var rows,
-					  row,
-					  nodes,
-					  i,
-					  j = -1,
-					  n,
-					  m = rows.length,
-					  value = parent.value;
-
-				  while (++j < m) {
-					row = rows[j], nodes = row.children;
-					for (i = row.value = 0, n = nodes.length; i < n; ++i) row.value += nodes[i].value;
-					if (row.dice) treemapDice(row, x0, y0, x1, y0 += (y1 - y0) * row.value / value);
-					else treemapSlice(row, x0, y0, x0 += (x1 - x0) * row.value / value, y1);
-					value -= row.value;
-				  }
-				} else {
-				  parent._squarify = rows = squarifyRatio(ratio, parent, x0, y0, x1, y1);
-				  rows.ratio = ratio;
-				}
-			  }
-
-			  resquarify.ratio = function(x) {
-				return custom((x = +x) > 1 ? x : 1);
-			  };
-
-			  return resquarify;
-			})(phi);
-
-			var center$1 = function(x, y) {
-			  var nodes;
-
-			  if (x == null) x = 0;
-			  if (y == null) y = 0;
-
-			  function force() {
-				var i,
-					n = nodes.length,
-					node,
-					sx = 0,
-					sy = 0;
-
-				for (i = 0; i < n; ++i) {
-				  node = nodes[i], sx += node.x, sy += node.y;
-				}
-
-				for (sx = sx / n - x, sy = sy / n - y, i = 0; i < n; ++i) {
-				  node = nodes[i], node.x -= sx, node.y -= sy;
-				}
-			  }
-
-			  force.initialize = function(_) {
-				nodes = _;
-			  };
-
-			  force.x = function(_) {
-				return arguments.length ? (x = +_, force) : x;
-			  };
-
-			  force.y = function(_) {
-				return arguments.length ? (y = +_, force) : y;
-			  };
-
-			  return force;
-			};
-
-			var constant$7 = function(x) {
-			  return function() {
-				return x;
-			  };
-			};
-
-			var jiggle = function() {
-			  return (Math.random() - 0.5) * 1e-6;
-			};
-
-			function x$1(d) {
-			  return d.x + d.vx;
-			}
-
-			function y$1(d) {
-			  return d.y + d.vy;
-			}
-
-			var collide = function(radius) {
-			  var nodes,
-				  radii,
-				  strength = 1,
-				  iterations = 1;
-
-			  if (typeof radius !== "function") radius = constant$7(radius == null ? 1 : +radius);
-
-			  function force() {
-				var i, n = nodes.length,
-					tree,
-					node,
-					xi,
-					yi,
-					ri,
-					ri2;
-
-				for (var k = 0; k < iterations; ++k) {
-				  tree = quadtree(nodes, x$1, y$1).visitAfter(prepare);
-				  for (i = 0; i < n; ++i) {
-					node = nodes[i];
-					ri = radii[i], ri2 = ri * ri;
-					xi = node.x + node.vx;
-					yi = node.y + node.vy;
-					tree.visit(apply);
-				  }
-				}
-
-				function apply(quad, x0, y0, x1, y1) {
-				  var data = quad.data, rj = quad.r, r = ri + rj;
-				  if (data) {
-					if (data.index > i) {
-					  var x = xi - data.x - data.vx,
-						  y = yi - data.y - data.vy,
-						  l = x * x + y * y;
-					  if (l < r * r) {
-						if (x === 0) x = jiggle(), l += x * x;
-						if (y === 0) y = jiggle(), l += y * y;
-						l = (r - (l = Math.sqrt(l))) / l * strength;
-						node.vx += (x *= l) * (r = (rj *= rj) / (ri2 + rj));
-						node.vy += (y *= l) * r;
-						data.vx -= x * (r = 1 - r);
-						data.vy -= y * r;
-					  }
-					}
-					return;
-				  }
-				  return x0 > xi + r || x1 < xi - r || y0 > yi + r || y1 < yi - r;
-				}
-			  }
-
-			  function prepare(quad) {
-				if (quad.data) return quad.r = radii[quad.data.index];
-				for (var i = quad.r = 0; i < 4; ++i) {
-				  if (quad[i] && quad[i].r > quad.r) {
-					quad.r = quad[i].r;
-				  }
-				}
-			  }
-
-			  function initialize() {
-				if (!nodes) return;
-				var i, n = nodes.length;
-				radii = new Array(n);
-				for (i = 0; i < n; ++i) radii[i] = +radius(nodes[i], i, nodes);
-			  }
-
-			  force.initialize = function(_) {
-				nodes = _;
-				initialize();
-			  };
-
-			  force.iterations = function(_) {
-				return arguments.length ? (iterations = +_, force) : iterations;
-			  };
-
-			  force.strength = function(_) {
-				return arguments.length ? (strength = +_, force) : strength;
-			  };
-
-			  force.radius = function(_) {
-				return arguments.length ? (radius = typeof _ === "function" ? _ : constant$7(+_), initialize(), force) : radius;
-			  };
-
-			  return force;
-			};
-
-			function index$2(d, i) {
-			  return i;
-			}
-
-			function find(nodeById, nodeId) {
-			  var node = nodeById.get(nodeId);
-			  if (!node) throw new Error("missing: " + nodeId);
-			  return node;
-			}
-
-			var link = function(links) {
-			  var id = index$2,
-				  strength = defaultStrength,
-				  strengths,
-				  distance = constant$7(30),
-				  distances,
-				  nodes,
-				  count,
-				  bias,
-				  iterations = 1;
-
-			  if (links == null) links = [];
-
-			  function defaultStrength(link) {
-				return 1 / Math.min(count[link.source.index], count[link.target.index]);
-			  }
-
-			  function force(alpha) {
-				for (var k = 0, n = links.length; k < iterations; ++k) {
-				  for (var i = 0, link, source, target, x, y, l, b; i < n; ++i) {
-					link = links[i], source = link.source, target = link.target;
-					x = target.x + target.vx - source.x - source.vx || jiggle();
-					y = target.y + target.vy - source.y - source.vy || jiggle();
-					l = Math.sqrt(x * x + y * y);
-					l = (l - distances[i]) / l * alpha * strengths[i];
-					x *= l, y *= l;
-					target.vx -= x * (b = bias[i]);
-					target.vy -= y * b;
-					source.vx += x * (b = 1 - b);
-					source.vy += y * b;
-				  }
-				}
-			  }
-
-			  function initialize() {
-				if (!nodes) return;
-
-				var i,
-					n = nodes.length,
-					m = links.length,
-					nodeById = map$1(nodes, id),
-					link;
-
-				for (i = 0, count = new Array(n); i < n; ++i) {
-				  count[i] = 0;
-				}
-
-				for (i = 0; i < m; ++i) {
-				  link = links[i], link.index = i;
-				  if (typeof link.source !== "object") link.source = find(nodeById, link.source);
-				  if (typeof link.target !== "object") link.target = find(nodeById, link.target);
-				  ++count[link.source.index], ++count[link.target.index];
-				}
-
-				for (i = 0, bias = new Array(m); i < m; ++i) {
-				  link = links[i], bias[i] = count[link.source.index] / (count[link.source.index] + count[link.target.index]);
-				}
-
-				strengths = new Array(m), initializeStrength();
-				distances = new Array(m), initializeDistance();
-			  }
-
-			  function initializeStrength() {
-				if (!nodes) return;
-
-				for (var i = 0, n = links.length; i < n; ++i) {
-				  strengths[i] = +strength(links[i], i, links);
-				}
-			  }
-
-			  function initializeDistance() {
-				if (!nodes) return;
-
-				for (var i = 0, n = links.length; i < n; ++i) {
-				  distances[i] = +distance(links[i], i, links);
-				}
-			  }
-
-			  force.initialize = function(_) {
-				nodes = _;
-				initialize();
-			  };
-
-			  force.links = function(_) {
-				return arguments.length ? (links = _, initialize(), force) : links;
-			  };
-
-			  force.id = function(_) {
-				return arguments.length ? (id = _, force) : id;
-			  };
-
-			  force.iterations = function(_) {
-				return arguments.length ? (iterations = +_, force) : iterations;
-			  };
-
-			  force.strength = function(_) {
-				return arguments.length ? (strength = typeof _ === "function" ? _ : constant$7(+_), initializeStrength(), force) : strength;
-			  };
-
-			  force.distance = function(_) {
-				return arguments.length ? (distance = typeof _ === "function" ? _ : constant$7(+_), initializeDistance(), force) : distance;
-			  };
-
-			  return force;
-			};
-
-			function x$2(d) {
-			  return d.x;
-			}
-
-			function y$2(d) {
-			  return d.y;
-			}
-
-			var initialRadius = 10;
-			var initialAngle = Math.PI * (3 - Math.sqrt(5));
-
-			var simulation = function(nodes) {
-			  var simulation,
-				  alpha = 1,
-				  alphaMin = 0.001,
-				  alphaDecay = 1 - Math.pow(alphaMin, 1 / 300),
-				  alphaTarget = 0,
-				  velocityDecay = 0.6,
-				  forces = map$1(),
-				  stepper = timer(step),
-				  event = dispatch("tick", "end");
-
-			  if (nodes == null) nodes = [];
-
-			  function step() {
-				tick();
-				event.call("tick", simulation);
-				if (alpha < alphaMin) {
-				  stepper.stop();
-				  event.call("end", simulation);
-				}
-			  }
-
-			  function tick() {
-				var i, n = nodes.length, node;
-
-				alpha += (alphaTarget - alpha) * alphaDecay;
-
-				forces.each(function(force) {
-				  force(alpha);
-				});
-
-				for (i = 0; i < n; ++i) {
-				  node = nodes[i];
-				  if (node.fx == null) node.x += node.vx *= velocityDecay;
-				  else node.x = node.fx, node.vx = 0;
-				  if (node.fy == null) node.y += node.vy *= velocityDecay;
-				  else node.y = node.fy, node.vy = 0;
-				}
-			  }
-
-			  function initializeNodes() {
-				for (var i = 0, n = nodes.length, node; i < n; ++i) {
-				  node = nodes[i], node.index = i;
-				  if (isNaN(node.x) || isNaN(node.y)) {
-					var radius = initialRadius * Math.sqrt(i), angle = i * initialAngle;
-					node.x = radius * Math.cos(angle);
-					node.y = radius * Math.sin(angle);
-				  }
-				  if (isNaN(node.vx) || isNaN(node.vy)) {
-					node.vx = node.vy = 0;
-				  }
-				}
-			  }
-
-			  function initializeForce(force) {
-				if (force.initialize) force.initialize(nodes);
-				return force;
-			  }
-
-			  initializeNodes();
-
-			  return simulation = {
-				tick: tick,
-
-				restart: function() {
-				  return stepper.restart(step), simulation;
-				},
-
-				stop: function() {
-				  return stepper.stop(), simulation;
-				},
-
-				nodes: function(_) {
-				  return arguments.length ? (nodes = _, initializeNodes(), forces.each(initializeForce), simulation) : nodes;
-				},
-
-				alpha: function(_) {
-				  return arguments.length ? (alpha = +_, simulation) : alpha;
-				},
-
-				alphaMin: function(_) {
-				  return arguments.length ? (alphaMin = +_, simulation) : alphaMin;
-				},
-
-				alphaDecay: function(_) {
-				  return arguments.length ? (alphaDecay = +_, simulation) : +alphaDecay;
-				},
-
-				alphaTarget: function(_) {
-				  return arguments.length ? (alphaTarget = +_, simulation) : alphaTarget;
-				},
-
-				velocityDecay: function(_) {
-				  return arguments.length ? (velocityDecay = 1 - _, simulation) : 1 - velocityDecay;
-				},
-
-				force: function(name, _) {
-				  return arguments.length > 1 ? ((_ == null ? forces.remove(name) : forces.set(name, initializeForce(_))), simulation) : forces.get(name);
-				},
-
-				find: function(x, y, radius) {
-				  var i = 0,
-					  n = nodes.length,
-					  dx,
-					  dy,
-					  d2,
-					  node,
-					  closest;
-
-				  if (radius == null) radius = Infinity;
-				  else radius *= radius;
-
-				  for (i = 0; i < n; ++i) {
-					node = nodes[i];
-					dx = x - node.x;
-					dy = y - node.y;
-					d2 = dx * dx + dy * dy;
-					if (d2 < radius) closest = node, radius = d2;
-				  }
-
-				  return closest;
-				},
-
-				on: function(name, _) {
-				  return arguments.length > 1 ? (event.on(name, _), simulation) : event.on(name);
-				}
-			  };
-			};
-
-			var manyBody = function() {
-			  var nodes,
-				  node,
-				  alpha,
-				  strength = constant$7(-30),
-				  strengths,
-				  distanceMin2 = 1,
-				  distanceMax2 = Infinity,
-				  theta2 = 0.81;
-
-			  function force(_) {
-				var i, n = nodes.length, tree = quadtree(nodes, x$2, y$2).visitAfter(accumulate);
-				for (alpha = _, i = 0; i < n; ++i) node = nodes[i], tree.visit(apply);
-			  }
-
-			  function initialize() {
-				if (!nodes) return;
-				var i, n = nodes.length;
-				strengths = new Array(n);
-				for (i = 0; i < n; ++i) strengths[i] = +strength(nodes[i], i, nodes);
-			  }
-
-			  function accumulate(quad) {
-				var strength = 0, q, c, x$$1, y$$1, i;
-
-				// For internal nodes, accumulate forces from child quadrants.
-				if (quad.length) {
-				  for (x$$1 = y$$1 = i = 0; i < 4; ++i) {
-					if ((q = quad[i]) && (c = q.value)) {
-					  strength += c, x$$1 += c * q.x, y$$1 += c * q.y;
-					}
-				  }
-				  quad.x = x$$1 / strength;
-				  quad.y = y$$1 / strength;
-				}
-
-				// For leaf nodes, accumulate forces from coincident quadrants.
-				else {
-				  q = quad;
-				  q.x = q.data.x;
-				  q.y = q.data.y;
-				  do strength += strengths[q.data.index];
-				  while (q = q.next);
-				}
-
-				quad.value = strength;
-			  }
-
-			  function apply(quad, x1, _, x2) {
-				if (!quad.value) return true;
-
-				var x$$1 = quad.x - node.x,
-					y$$1 = quad.y - node.y,
-					w = x2 - x1,
-					l = x$$1 * x$$1 + y$$1 * y$$1;
-
-				// Apply the Barnes-Hut approximation if possible.
-				// Limit forces for very close nodes; randomize direction if coincident.
-				if (w * w / theta2 < l) {
-				  if (l < distanceMax2) {
-					if (x$$1 === 0) x$$1 = jiggle(), l += x$$1 * x$$1;
-					if (y$$1 === 0) y$$1 = jiggle(), l += y$$1 * y$$1;
-					if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);
-					node.vx += x$$1 * quad.value * alpha / l;
-					node.vy += y$$1 * quad.value * alpha / l;
-				  }
-				  return true;
-				}
-
-				// Otherwise, process points directly.
-				else if (quad.length || l >= distanceMax2) return;
-
-				// Limit forces for very close nodes; randomize direction if coincident.
-				if (quad.data !== node || quad.next) {
-				  if (x$$1 === 0) x$$1 = jiggle(), l += x$$1 * x$$1;
-				  if (y$$1 === 0) y$$1 = jiggle(), l += y$$1 * y$$1;
-				  if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);
-				}
-
-				do if (quad.data !== node) {
-				  w = strengths[quad.data.index] * alpha / l;
-				  node.vx += x$$1 * w;
-				  node.vy += y$$1 * w;
-				} while (quad = quad.next);
-			  }
-
-			  force.initialize = function(_) {
-				nodes = _;
-				initialize();
-			  };
-
-			  force.strength = function(_) {
-				return arguments.length ? (strength = typeof _ === "function" ? _ : constant$7(+_), initialize(), force) : strength;
-			  };
-
-			  force.distanceMin = function(_) {
-				return arguments.length ? (distanceMin2 = _ * _, force) : Math.sqrt(distanceMin2);
-			  };
-
-			  force.distanceMax = function(_) {
-				return arguments.length ? (distanceMax2 = _ * _, force) : Math.sqrt(distanceMax2);
-			  };
-
-			  force.theta = function(_) {
-				return arguments.length ? (theta2 = _ * _, force) : Math.sqrt(theta2);
-			  };
-
-			  return force;
-			};
-
-			var x$3 = function(x) {
-			  var strength = constant$7(0.1),
-				  nodes,
-				  strengths,
-				  xz;
-
-			  if (typeof x !== "function") x = constant$7(x == null ? 0 : +x);
-
-			  function force(alpha) {
-				for (var i = 0, n = nodes.length, node; i < n; ++i) {
-				  node = nodes[i], node.vx += (xz[i] - node.x) * strengths[i] * alpha;
-				}
-			  }
-
-			  function initialize() {
-				if (!nodes) return;
-				var i, n = nodes.length;
-				strengths = new Array(n);
-				xz = new Array(n);
-				for (i = 0; i < n; ++i) {
-				  strengths[i] = isNaN(xz[i] = +x(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);
-				}
-			  }
-
-			  force.initialize = function(_) {
-				nodes = _;
-				initialize();
-			  };
-
-			  force.strength = function(_) {
-				return arguments.length ? (strength = typeof _ === "function" ? _ : constant$7(+_), initialize(), force) : strength;
-			  };
-
-			  force.x = function(_) {
-				return arguments.length ? (x = typeof _ === "function" ? _ : constant$7(+_), initialize(), force) : x;
-			  };
-
-			  return force;
-			};
-
-			var y$3 = function(y) {
-			  var strength = constant$7(0.1),
-				  nodes,
-				  strengths,
-				  yz;
-
-			  if (typeof y !== "function") y = constant$7(y == null ? 0 : +y);
-
-			  function force(alpha) {
-				for (var i = 0, n = nodes.length, node; i < n; ++i) {
-				  node = nodes[i], node.vy += (yz[i] - node.y) * strengths[i] * alpha;
-				}
-			  }
-
-			  function initialize() {
-				if (!nodes) return;
-				var i, n = nodes.length;
-				strengths = new Array(n);
-				yz = new Array(n);
-				for (i = 0; i < n; ++i) {
-				  strengths[i] = isNaN(yz[i] = +y(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);
-				}
-			  }
-
-			  force.initialize = function(_) {
-				nodes = _;
-				initialize();
-			  };
-
-			  force.strength = function(_) {
-				return arguments.length ? (strength = typeof _ === "function" ? _ : constant$7(+_), initialize(), force) : strength;
-			  };
-
-			  force.y = function(_) {
-				return arguments.length ? (y = typeof _ === "function" ? _ : constant$7(+_), initialize(), force) : y;
-			  };
-
-			  return force;
-			};
-
-			function nopropagation() {
-			  exports.event.stopImmediatePropagation();
-			}
-
-			var noevent = function() {
-			  exports.event.preventDefault();
-			  exports.event.stopImmediatePropagation();
-			};
-
-			var dragDisable = function(view) {
-			  var root = view.document.documentElement,
-				  selection$$1 = select(view).on("dragstart.drag", noevent, true);
-			  if ("onselectstart" in root) {
-				selection$$1.on("selectstart.drag", noevent, true);
-			  } else {
-				root.__noselect = root.style.MozUserSelect;
-				root.style.MozUserSelect = "none";
-			  }
-			};
-
-			function yesdrag(view, noclick) {
-			  var root = view.document.documentElement,
-				  selection$$1 = select(view).on("dragstart.drag", null);
-			  if (noclick) {
-				selection$$1.on("click.drag", noevent, true);
-				setTimeout(function() { selection$$1.on("click.drag", null); }, 0);
-			  }
-			  if ("onselectstart" in root) {
-				selection$$1.on("selectstart.drag", null);
-			  } else {
-				root.style.MozUserSelect = root.__noselect;
-				delete root.__noselect;
-			  }
-			}
-
-			var constant$8 = function(x) {
-			  return function() {
-				return x;
-			  };
-			};
-
-			function DragEvent(target, type, subject, id, active, x, y, dx, dy, dispatch) {
-			  this.target = target;
-			  this.type = type;
-			  this.subject = subject;
-			  this.identifier = id;
-			  this.active = active;
-			  this.x = x;
-			  this.y = y;
-			  this.dx = dx;
-			  this.dy = dy;
-			  this._ = dispatch;
-			}
-
-			DragEvent.prototype.on = function() {
-			  var value = this._.on.apply(this._, arguments);
-			  return value === this._ ? this : value;
-			};
-
-			// Ignore right-click, since that should open the context menu.
-			function defaultFilter() {
-			  return !exports.event.button;
-			}
-
-			function defaultContainer() {
-			  return this.parentNode;
-			}
-
-			function defaultSubject(d) {
-			  return d == null ? {x: exports.event.x, y: exports.event.y} : d;
-			}
-
-			var drag = function() {
-			  var filter = defaultFilter,
-				  container = defaultContainer,
-				  subject = defaultSubject,
-				  gestures = {},
-				  listeners = dispatch("start", "drag", "end"),
-				  active = 0,
-				  mousemoving,
-				  touchending;
-
-			  function drag(selection$$1) {
-				selection$$1
-					.on("mousedown.drag", mousedowned)
-					.on("touchstart.drag", touchstarted)
-					.on("touchmove.drag", touchmoved)
-					.on("touchend.drag touchcancel.drag", touchended)
-					.style("-webkit-tap-highlight-color", "rgba(0,0,0,0)");
-			  }
-
-			  function mousedowned() {
-				if (touchending || !filter.apply(this, arguments)) return;
-				var gesture = beforestart("mouse", container.apply(this, arguments), mouse, this, arguments);
-				if (!gesture) return;
-				select(exports.event.view).on("mousemove.drag", mousemoved, true).on("mouseup.drag", mouseupped, true);
-				dragDisable(exports.event.view);
-				nopropagation();
-				mousemoving = false;
-				gesture("start");
-			  }
-
-			  function mousemoved() {
-				noevent();
-				mousemoving = true;
-				gestures.mouse("drag");
-			  }
-
-			  function mouseupped() {
-				select(exports.event.view).on("mousemove.drag mouseup.drag", null);
-				yesdrag(exports.event.view, mousemoving);
-				noevent();
-				gestures.mouse("end");
-			  }
-
-			  function touchstarted() {
-				if (!filter.apply(this, arguments)) return;
-				var touches$$1 = exports.event.changedTouches,
-					c = container.apply(this, arguments),
-					n = touches$$1.length, i, gesture;
-
-				for (i = 0; i < n; ++i) {
-				  if (gesture = beforestart(touches$$1[i].identifier, c, touch, this, arguments)) {
-					nopropagation();
-					gesture("start");
-				  }
-				}
-			  }
-
-			  function touchmoved() {
-				var touches$$1 = exports.event.changedTouches,
-					n = touches$$1.length, i, gesture;
-
-				for (i = 0; i < n; ++i) {
-				  if (gesture = gestures[touches$$1[i].identifier]) {
-					noevent();
-					gesture("drag");
-				  }
-				}
-			  }
-
-			  function touchended() {
-				var touches$$1 = exports.event.changedTouches,
-					n = touches$$1.length, i, gesture;
-
-				if (touchending) clearTimeout(touchending);
-				touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!
-				for (i = 0; i < n; ++i) {
-				  if (gesture = gestures[touches$$1[i].identifier]) {
-					nopropagation();
-					gesture("end");
-				  }
-				}
-			  }
-
-			  function beforestart(id, container, point, that, args) {
-				var p = point(container, id), s, dx, dy,
-					sublisteners = listeners.copy();
-
-				if (!customEvent(new DragEvent(drag, "beforestart", s, id, active, p[0], p[1], 0, 0, sublisteners), function() {
-				  if ((exports.event.subject = s = subject.apply(that, args)) == null) return false;
-				  dx = s.x - p[0] || 0;
-				  dy = s.y - p[1] || 0;
-				  return true;
-				})) return;
-
-				return function gesture(type) {
-				  var p0 = p, n;
-				  switch (type) {
-					case "start": gestures[id] = gesture, n = active++; break;
-					case "end": delete gestures[id], --active; // nobreak
-					case "drag": p = point(container, id), n = active; break;
-				  }
-				  customEvent(new DragEvent(drag, type, s, id, n, p[0] + dx, p[1] + dy, p[0] - p0[0], p[1] - p0[1], sublisteners), sublisteners.apply, sublisteners, [type, that, args]);
-				};
-			  }
-
-			  drag.filter = function(_) {
-				return arguments.length ? (filter = typeof _ === "function" ? _ : constant$8(!!_), drag) : filter;
-			  };
-
-			  drag.container = function(_) {
-				return arguments.length ? (container = typeof _ === "function" ? _ : constant$8(_), drag) : container;
-			  };
-
-			  drag.subject = function(_) {
-				return arguments.length ? (subject = typeof _ === "function" ? _ : constant$8(_), drag) : subject;
-			  };
-
-			  drag.on = function() {
-				var value = listeners.on.apply(listeners, arguments);
-				return value === listeners ? drag : value;
-			  };
-
-			  return drag;
-			};
-
-			var constant$9 = function(x) {
-			  return function() {
-				return x;
-			  };
-			};
-
-			function x$4(d) {
-			  return d[0];
-			}
-
-			function y$4(d) {
-			  return d[1];
-			}
-
-			function RedBlackTree() {
-			  this._ = null; // root node
-			}
-
-			function RedBlackNode(node) {
-			  node.U = // parent node
-			  node.C = // color - true for red, false for black
-			  node.L = // left node
-			  node.R = // right node
-			  node.P = // previous node
-			  node.N = null; // next node
-			}
-
-			RedBlackTree.prototype = {
-			  constructor: RedBlackTree,
-
-			  insert: function(after, node) {
-				var parent, grandpa, uncle;
-
-				if (after) {
-				  node.P = after;
-				  node.N = after.N;
-				  if (after.N) after.N.P = node;
-				  after.N = node;
-				  if (after.R) {
-					after = after.R;
-					while (after.L) after = after.L;
-					after.L = node;
-				  } else {
-					after.R = node;
-				  }
-				  parent = after;
-				} else if (this._) {
-				  after = RedBlackFirst(this._);
-				  node.P = null;
-				  node.N = after;
-				  after.P = after.L = node;
-				  parent = after;
-				} else {
-				  node.P = node.N = null;
-				  this._ = node;
-				  parent = null;
-				}
-				node.L = node.R = null;
-				node.U = parent;
-				node.C = true;
-
-				after = node;
-				while (parent && parent.C) {
-				  grandpa = parent.U;
-				  if (parent === grandpa.L) {
-					uncle = grandpa.R;
-					if (uncle && uncle.C) {
-					  parent.C = uncle.C = false;
-					  grandpa.C = true;
-					  after = grandpa;
-					} else {
-					  if (after === parent.R) {
-						RedBlackRotateLeft(this, parent);
-						after = parent;
-						parent = after.U;
-					  }
-					  parent.C = false;
-					  grandpa.C = true;
-					  RedBlackRotateRight(this, grandpa);
-					}
-				  } else {
-					uncle = grandpa.L;
-					if (uncle && uncle.C) {
-					  parent.C = uncle.C = false;
-					  grandpa.C = true;
-					  after = grandpa;
-					} else {
-					  if (after === parent.L) {
-						RedBlackRotateRight(this, parent);
-						after = parent;
-						parent = after.U;
-					  }
-					  parent.C = false;
-					  grandpa.C = true;
-					  RedBlackRotateLeft(this, grandpa);
-					}
-				  }
-				  parent = after.U;
-				}
-				this._.C = false;
-			  },
-
-			  remove: function(node) {
-				if (node.N) node.N.P = node.P;
-				if (node.P) node.P.N = node.N;
-				node.N = node.P = null;
-
-				var parent = node.U,
-					sibling,
-					left = node.L,
-					right = node.R,
-					next,
-					red;
-
-				if (!left) next = right;
-				else if (!right) next = left;
-				else next = RedBlackFirst(right);
-
-				if (parent) {
-				  if (parent.L === node) parent.L = next;
-				  else parent.R = next;
-				} else {
-				  this._ = next;
-				}
-
-				if (left && right) {
-				  red = next.C;
-				  next.C = node.C;
-				  next.L = left;
-				  left.U = next;
-				  if (next !== right) {
-					parent = next.U;
-					next.U = node.U;
-					node = next.R;
-					parent.L = node;
-					next.R = right;
-					right.U = next;
-				  } else {
-					next.U = parent;
-					parent = next;
-					node = next.R;
-				  }
-				} else {
-				  red = node.C;
-				  node = next;
-				}
-
-				if (node) node.U = parent;
-				if (red) return;
-				if (node && node.C) { node.C = false; return; }
-
-				do {
-				  if (node === this._) break;
-				  if (node === parent.L) {
-					sibling = parent.R;
-					if (sibling.C) {
-					  sibling.C = false;
-					  parent.C = true;
-					  RedBlackRotateLeft(this, parent);
-					  sibling = parent.R;
-					}
-					if ((sibling.L && sibling.L.C)
-						|| (sibling.R && sibling.R.C)) {
-					  if (!sibling.R || !sibling.R.C) {
-						sibling.L.C = false;
-						sibling.C = true;
-						RedBlackRotateRight(this, sibling);
-						sibling = parent.R;
-					  }
-					  sibling.C = parent.C;
-					  parent.C = sibling.R.C = false;
-					  RedBlackRotateLeft(this, parent);
-					  node = this._;
-					  break;
-					}
-				  } else {
-					sibling = parent.L;
-					if (sibling.C) {
-					  sibling.C = false;
-					  parent.C = true;
-					  RedBlackRotateRight(this, parent);
-					  sibling = parent.L;
-					}
-					if ((sibling.L && sibling.L.C)
-					  || (sibling.R && sibling.R.C)) {
-					  if (!sibling.L || !sibling.L.C) {
-						sibling.R.C = false;
-						sibling.C = true;
-						RedBlackRotateLeft(this, sibling);
-						sibling = parent.L;
-					  }
-					  sibling.C = parent.C;
-					  parent.C = sibling.L.C = false;
-					  RedBlackRotateRight(this, parent);
-					  node = this._;
-					  break;
-					}
-				  }
-				  sibling.C = true;
-				  node = parent;
-				  parent = parent.U;
-				} while (!node.C);
-
-				if (node) node.C = false;
-			  }
-			};
-
-			function RedBlackRotateLeft(tree, node) {
-			  var p = node,
-				  q = node.R,
-				  parent = p.U;
-
-			  if (parent) {
-				if (parent.L === p) parent.L = q;
-				else parent.R = q;
-			  } else {
-				tree._ = q;
-			  }
-
-			  q.U = parent;
-			  p.U = q;
-			  p.R = q.L;
-			  if (p.R) p.R.U = p;
-			  q.L = p;
-			}
-
-			function RedBlackRotateRight(tree, node) {
-			  var p = node,
-				  q = node.L,
-				  parent = p.U;
-
-			  if (parent) {
-				if (parent.L === p) parent.L = q;
-				else parent.R = q;
-			  } else {
-				tree._ = q;
-			  }
-
-			  q.U = parent;
-			  p.U = q;
-			  p.L = q.R;
-			  if (p.L) p.L.U = p;
-			  q.R = p;
-			}
-
-			function RedBlackFirst(node) {
-			  while (node.L) node = node.L;
-			  return node;
-			}
-
-			function createEdge(left, right, v0, v1) {
-			  var edge = [null, null],
-				  index = edges.push(edge) - 1;
-			  edge.left = left;
-			  edge.right = right;
-			  if (v0) setEdgeEnd(edge, left, right, v0);
-			  if (v1) setEdgeEnd(edge, right, left, v1);
-			  cells[left.index].halfedges.push(index);
-			  cells[right.index].halfedges.push(index);
-			  return edge;
-			}
-
-			function createBorderEdge(left, v0, v1) {
-			  var edge = [v0, v1];
-			  edge.left = left;
-			  return edge;
-			}
-
-			function setEdgeEnd(edge, left, right, vertex) {
-			  if (!edge[0] && !edge[1]) {
-				edge[0] = vertex;
-				edge.left = left;
-				edge.right = right;
-			  } else if (edge.left === right) {
-				edge[1] = vertex;
-			  } else {
-				edge[0] = vertex;
-			  }
-			}
-
-			// Liang–Barsky line clipping.
-			function clipEdge(edge, x0, y0, x1, y1) {
-			  var a = edge[0],
-				  b = edge[1],
-				  ax = a[0],
-				  ay = a[1],
-				  bx = b[0],
-				  by = b[1],
-				  t0 = 0,
-				  t1 = 1,
-				  dx = bx - ax,
-				  dy = by - ay,
-				  r;
-
-			  r = x0 - ax;
-			  if (!dx && r > 0) return;
-			  r /= dx;
-			  if (dx < 0) {
-				if (r < t0) return;
-				if (r < t1) t1 = r;
-			  } else if (dx > 0) {
-				if (r > t1) return;
-				if (r > t0) t0 = r;
-			  }
-
-			  r = x1 - ax;
-			  if (!dx && r < 0) return;
-			  r /= dx;
-			  if (dx < 0) {
-				if (r > t1) return;
-				if (r > t0) t0 = r;
-			  } else if (dx > 0) {
-				if (r < t0) return;
-				if (r < t1) t1 = r;
-			  }
-
-			  r = y0 - ay;
-			  if (!dy && r > 0) return;
-			  r /= dy;
-			  if (dy < 0) {
-				if (r < t0) return;
-				if (r < t1) t1 = r;
-			  } else if (dy > 0) {
-				if (r > t1) return;
-				if (r > t0) t0 = r;
-			  }
-
-			  r = y1 - ay;
-			  if (!dy && r < 0) return;
-			  r /= dy;
-			  if (dy < 0) {
-				if (r > t1) return;
-				if (r > t0) t0 = r;
-			  } else if (dy > 0) {
-				if (r < t0) return;
-				if (r < t1) t1 = r;
-			  }
-
-			  if (!(t0 > 0) && !(t1 < 1)) return true; // TODO Better check?
-
-			  if (t0 > 0) edge[0] = [ax + t0 * dx, ay + t0 * dy];
-			  if (t1 < 1) edge[1] = [ax + t1 * dx, ay + t1 * dy];
-			  return true;
-			}
-
-			function connectEdge(edge, x0, y0, x1, y1) {
-			  var v1 = edge[1];
-			  if (v1) return true;
-
-			  var v0 = edge[0],
-				  left = edge.left,
-				  right = edge.right,
-				  lx = left[0],
-				  ly = left[1],
-				  rx = right[0],
-				  ry = right[1],
-				  fx = (lx + rx) / 2,
-				  fy = (ly + ry) / 2,
-				  fm,
-				  fb;
-
-			  if (ry === ly) {
-				if (fx < x0 || fx >= x1) return;
-				if (lx > rx) {
-				  if (!v0) v0 = [fx, y0];
-				  else if (v0[1] >= y1) return;
-				  v1 = [fx, y1];
-				} else {
-				  if (!v0) v0 = [fx, y1];
-				  else if (v0[1] < y0) return;
-				  v1 = [fx, y0];
-				}
-			  } else {
-				fm = (lx - rx) / (ry - ly);
-				fb = fy - fm * fx;
-				if (fm < -1 || fm > 1) {
-				  if (lx > rx) {
-					if (!v0) v0 = [(y0 - fb) / fm, y0];
-					else if (v0[1] >= y1) return;
-					v1 = [(y1 - fb) / fm, y1];
-				  } else {
-					if (!v0) v0 = [(y1 - fb) / fm, y1];
-					else if (v0[1] < y0) return;
-					v1 = [(y0 - fb) / fm, y0];
-				  }
-				} else {
-				  if (ly < ry) {
-					if (!v0) v0 = [x0, fm * x0 + fb];
-					else if (v0[0] >= x1) return;
-					v1 = [x1, fm * x1 + fb];
-				  } else {
-					if (!v0) v0 = [x1, fm * x1 + fb];
-					else if (v0[0] < x0) return;
-					v1 = [x0, fm * x0 + fb];
-				  }
-				}
-			  }
-
-			  edge[0] = v0;
-			  edge[1] = v1;
-			  return true;
-			}
-
-			function clipEdges(x0, y0, x1, y1) {
-			  var i = edges.length,
-				  edge;
-
-			  while (i--) {
-				if (!connectEdge(edge = edges[i], x0, y0, x1, y1)
-					|| !clipEdge(edge, x0, y0, x1, y1)
-					|| !(Math.abs(edge[0][0] - edge[1][0]) > epsilon$3
-						|| Math.abs(edge[0][1] - edge[1][1]) > epsilon$3)) {
-				  delete edges[i];
-				}
-			  }
-			}
-
-			function createCell(site) {
-			  return cells[site.index] = {
-				site: site,
-				halfedges: []
-			  };
-			}
-
-			function cellHalfedgeAngle(cell, edge) {
-			  var site = cell.site,
-				  va = edge.left,
-				  vb = edge.right;
-			  if (site === vb) vb = va, va = site;
-			  if (vb) return Math.atan2(vb[1] - va[1], vb[0] - va[0]);
-			  if (site === va) va = edge[1], vb = edge[0];
-			  else va = edge[0], vb = edge[1];
-			  return Math.atan2(va[0] - vb[0], vb[1] - va[1]);
-			}
-
-			function cellHalfedgeStart(cell, edge) {
-			  return edge[+(edge.left !== cell.site)];
-			}
-
-			function cellHalfedgeEnd(cell, edge) {
-			  return edge[+(edge.left === cell.site)];
-			}
-
-			function sortCellHalfedges() {
-			  for (var i = 0, n = cells.length, cell, halfedges, j, m; i < n; ++i) {
-				if ((cell = cells[i]) && (m = (halfedges = cell.halfedges).length)) {
-				  var index = new Array(m),
-					  array = new Array(m);
-				  for (j = 0; j < m; ++j) index[j] = j, array[j] = cellHalfedgeAngle(cell, edges[halfedges[j]]);
-				  index.sort(function(i, j) { return array[j] - array[i]; });
-				  for (j = 0; j < m; ++j) array[j] = halfedges[index[j]];
-				  for (j = 0; j < m; ++j) halfedges[j] = array[j];
-				}
-			  }
-			}
-
-			function clipCells(x0, y0, x1, y1) {
-			  var nCells = cells.length,
-				  iCell,
-				  cell,
-				  site,
-				  iHalfedge,
-				  halfedges,
-				  nHalfedges,
-				  start,
-				  startX,
-				  startY,
-				  end,
-				  endX,
-				  endY,
-				  cover = true;
-
-			  for (iCell = 0; iCell < nCells; ++iCell) {
-				if (cell = cells[iCell]) {
-				  site = cell.site;
-				  halfedges = cell.halfedges;
-				  iHalfedge = halfedges.length;
-
-				  // Remove any dangling clipped edges.
-				  while (iHalfedge--) {
-					if (!edges[halfedges[iHalfedge]]) {
-					  halfedges.splice(iHalfedge, 1);
-					}
-				  }
-
-				  // Insert any border edges as necessary.
-				  iHalfedge = 0, nHalfedges = halfedges.length;
-				  while (iHalfedge < nHalfedges) {
-					end = cellHalfedgeEnd(cell, edges[halfedges[iHalfedge]]), endX = end[0], endY = end[1];
-					start = cellHalfedgeStart(cell, edges[halfedges[++iHalfedge % nHalfedges]]), startX = start[0], startY = start[1];
-					if (Math.abs(endX - startX) > epsilon$3 || Math.abs(endY - startY) > epsilon$3) {
-					  halfedges.splice(iHalfedge, 0, edges.push(createBorderEdge(site, end,
-						  Math.abs(endX - x0) < epsilon$3 && y1 - endY > epsilon$3 ? [x0, Math.abs(startX - x0) < epsilon$3 ? startY : y1]
-						  : Math.abs(endY - y1) < epsilon$3 && x1 - endX > epsilon$3 ? [Math.abs(startY - y1) < epsilon$3 ? startX : x1, y1]
-						  : Math.abs(endX - x1) < epsilon$3 && endY - y0 > epsilon$3 ? [x1, Math.abs(startX - x1) < epsilon$3 ? startY : y0]
-						  : Math.abs(endY - y0) < epsilon$3 && endX - x0 > epsilon$3 ? [Math.abs(startY - y0) < epsilon$3 ? startX : x0, y0]
-						  : null)) - 1);
-					  ++nHalfedges;
-					}
-				  }
-
-				  if (nHalfedges) cover = false;
-				}
-			  }
-
-			  // If there weren’t any edges, have the closest site cover the extent.
-			  // It doesn’t matter which corner of the extent we measure!
-			  if (cover) {
-				var dx, dy, d2, dc = Infinity;
-
-				for (iCell = 0, cover = null; iCell < nCells; ++iCell) {
-				  if (cell = cells[iCell]) {
-					site = cell.site;
-					dx = site[0] - x0;
-					dy = site[1] - y0;
-					d2 = dx * dx + dy * dy;
-					if (d2 < dc) dc = d2, cover = cell;
-				  }
-				}
-
-				if (cover) {
-				  var v00 = [x0, y0], v01 = [x0, y1], v11 = [x1, y1], v10 = [x1, y0];
-				  cover.halfedges.push(
-					edges.push(createBorderEdge(site = cover.site, v00, v01)) - 1,
-					edges.push(createBorderEdge(site, v01, v11)) - 1,
-					edges.push(createBorderEdge(site, v11, v10)) - 1,
-					edges.push(createBorderEdge(site, v10, v00)) - 1
-				  );
-				}
-			  }
-
-			  // Lastly delete any cells with no edges; these were entirely clipped.
-			  for (iCell = 0; iCell < nCells; ++iCell) {
-				if (cell = cells[iCell]) {
-				  if (!cell.halfedges.length) {
-					delete cells[iCell];
-				  }
-				}
-			  }
-			}
-
-			var circlePool = [];
-
-			var firstCircle;
-
-			function Circle() {
-			  RedBlackNode(this);
-			  this.x =
-			  this.y =
-			  this.arc =
-			  this.site =
-			  this.cy = null;
-			}
-
-			function attachCircle(arc) {
-			  var lArc = arc.P,
-				  rArc = arc.N;
-
-			  if (!lArc || !rArc) return;
-
-			  var lSite = lArc.site,
-				  cSite = arc.site,
-				  rSite = rArc.site;
-
-			  if (lSite === rSite) return;
-
-			  var bx = cSite[0],
-				  by = cSite[1],
-				  ax = lSite[0] - bx,
-				  ay = lSite[1] - by,
-				  cx = rSite[0] - bx,
-				  cy = rSite[1] - by;
-
-			  var d = 2 * (ax * cy - ay * cx);
-			  if (d >= -epsilon2$1) return;
-
-			  var ha = ax * ax + ay * ay,
-				  hc = cx * cx + cy * cy,
-				  x = (cy * ha - ay * hc) / d,
-				  y = (ax * hc - cx * ha) / d;
-
-			  var circle = circlePool.pop() || new Circle;
-			  circle.arc = arc;
-			  circle.site = cSite;
-			  circle.x = x + bx;
-			  circle.y = (circle.cy = y + by) + Math.sqrt(x * x + y * y); // y bottom
-
-			  arc.circle = circle;
-
-			  var before = null,
-				  node = circles._;
-
-			  while (node) {
-				if (circle.y < node.y || (circle.y === node.y && circle.x <= node.x)) {
-				  if (node.L) node = node.L;
-				  else { before = node.P; break; }
-				} else {
-				  if (node.R) node = node.R;
-				  else { before = node; break; }
-				}
-			  }
-
-			  circles.insert(before, circle);
-			  if (!before) firstCircle = circle;
-			}
-
-			function detachCircle(arc) {
-			  var circle = arc.circle;
-			  if (circle) {
-				if (!circle.P) firstCircle = circle.N;
-				circles.remove(circle);
-				circlePool.push(circle);
-				RedBlackNode(circle);
-				arc.circle = null;
-			  }
-			}
-
-			var beachPool = [];
-
-			function Beach() {
-			  RedBlackNode(this);
-			  this.edge =
-			  this.site =
-			  this.circle = null;
-			}
-
-			function createBeach(site) {
-			  var beach = beachPool.pop() || new Beach;
-			  beach.site = site;
-			  return beach;
-			}
-
-			function detachBeach(beach) {
-			  detachCircle(beach);
-			  beaches.remove(beach);
-			  beachPool.push(beach);
-			  RedBlackNode(beach);
-			}
-
-			function removeBeach(beach) {
-			  var circle = beach.circle,
-				  x = circle.x,
-				  y = circle.cy,
-				  vertex = [x, y],
-				  previous = beach.P,
-				  next = beach.N,
-				  disappearing = [beach];
-
-			  detachBeach(beach);
-
-			  var lArc = previous;
-			  while (lArc.circle
-				  && Math.abs(x - lArc.circle.x) < epsilon$3
-				  && Math.abs(y - lArc.circle.cy) < epsilon$3) {
-				previous = lArc.P;
-				disappearing.unshift(lArc);
-				detachBeach(lArc);
-				lArc = previous;
-			  }
-
-			  disappearing.unshift(lArc);
-			  detachCircle(lArc);
-
-			  var rArc = next;
-			  while (rArc.circle
-				  && Math.abs(x - rArc.circle.x) < epsilon$3
-				  && Math.abs(y - rArc.circle.cy) < epsilon$3) {
-				next = rArc.N;
-				disappearing.push(rArc);
-				detachBeach(rArc);
-				rArc = next;
-			  }
-
-			  disappearing.push(rArc);
-			  detachCircle(rArc);
-
-			  var nArcs = disappearing.length,
-				  iArc;
-			  for (iArc = 1; iArc < nArcs; ++iArc) {
-				rArc = disappearing[iArc];
-				lArc = disappearing[iArc - 1];
-				setEdgeEnd(rArc.edge, lArc.site, rArc.site, vertex);
-			  }
-
-			  lArc = disappearing[0];
-			  rArc = disappearing[nArcs - 1];
-			  rArc.edge = createEdge(lArc.site, rArc.site, null, vertex);
-
-			  attachCircle(lArc);
-			  attachCircle(rArc);
-			}
-
-			function addBeach(site) {
-			  var x = site[0],
-				  directrix = site[1],
-				  lArc,
-				  rArc,
-				  dxl,
-				  dxr,
-				  node = beaches._;
-
-			  while (node) {
-				dxl = leftBreakPoint(node, directrix) - x;
-				if (dxl > epsilon$3) node = node.L; else {
-				  dxr = x - rightBreakPoint(node, directrix);
-				  if (dxr > epsilon$3) {
-					if (!node.R) {
-					  lArc = node;
-					  break;
-					}
-					node = node.R;
-				  } else {
-					if (dxl > -epsilon$3) {
-					  lArc = node.P;
-					  rArc = node;
-					} else if (dxr > -epsilon$3) {
-					  lArc = node;
-					  rArc = node.N;
-					} else {
-					  lArc = rArc = node;
-					}
-					break;
-				  }
-				}
-			  }
-
-			  createCell(site);
-			  var newArc = createBeach(site);
-			  beaches.insert(lArc, newArc);
-
-			  if (!lArc && !rArc) return;
-
-			  if (lArc === rArc) {
-				detachCircle(lArc);
-				rArc = createBeach(lArc.site);
-				beaches.insert(newArc, rArc);
-				newArc.edge = rArc.edge = createEdge(lArc.site, newArc.site);
-				attachCircle(lArc);
-				attachCircle(rArc);
-				return;
-			  }
-
-			  if (!rArc) { // && lArc
-				newArc.edge = createEdge(lArc.site, newArc.site);
-				return;
-			  }
-
-			  // else lArc !== rArc
-			  detachCircle(lArc);
-			  detachCircle(rArc);
-
-			  var lSite = lArc.site,
-				  ax = lSite[0],
-				  ay = lSite[1],
-				  bx = site[0] - ax,
-				  by = site[1] - ay,
-				  rSite = rArc.site,
-				  cx = rSite[0] - ax,
-				  cy = rSite[1] - ay,
-				  d = 2 * (bx * cy - by * cx),
-				  hb = bx * bx + by * by,
-				  hc = cx * cx + cy * cy,
-				  vertex = [(cy * hb - by * hc) / d + ax, (bx * hc - cx * hb) / d + ay];
-
-			  setEdgeEnd(rArc.edge, lSite, rSite, vertex);
-			  newArc.edge = createEdge(lSite, site, null, vertex);
-			  rArc.edge = createEdge(site, rSite, null, vertex);
-			  attachCircle(lArc);
-			  attachCircle(rArc);
-			}
-
-			function leftBreakPoint(arc, directrix) {
-			  var site = arc.site,
-				  rfocx = site[0],
-				  rfocy = site[1],
-				  pby2 = rfocy - directrix;
-
-			  if (!pby2) return rfocx;
-
-			  var lArc = arc.P;
-			  if (!lArc) return -Infinity;
-
-			  site = lArc.site;
-			  var lfocx = site[0],
-				  lfocy = site[1],
-				  plby2 = lfocy - directrix;
-
-			  if (!plby2) return lfocx;
-
-			  var hl = lfocx - rfocx,
-				  aby2 = 1 / pby2 - 1 / plby2,
-				  b = hl / plby2;
-
-			  if (aby2) return (-b + Math.sqrt(b * b - 2 * aby2 * (hl * hl / (-2 * plby2) - lfocy + plby2 / 2 + rfocy - pby2 / 2))) / aby2 + rfocx;
-
-			  return (rfocx + lfocx) / 2;
-			}
-
-			function rightBreakPoint(arc, directrix) {
-			  var rArc = arc.N;
-			  if (rArc) return leftBreakPoint(rArc, directrix);
-			  var site = arc.site;
-			  return site[1] === directrix ? site[0] : Infinity;
-			}
-
-			var epsilon$3 = 1e-6;
-			var epsilon2$1 = 1e-12;
-			var beaches;
-			var cells;
-			var circles;
-			var edges;
-
-			function triangleArea(a, b, c) {
-			  return (a[0] - c[0]) * (b[1] - a[1]) - (a[0] - b[0]) * (c[1] - a[1]);
-			}
-
-			function lexicographic(a, b) {
-			  return b[1] - a[1]
-				  || b[0] - a[0];
-			}
-
-			function Diagram(sites, extent) {
-			  var site = sites.sort(lexicographic).pop(),
-				  x,
-				  y,
-				  circle;
-
-			  edges = [];
-			  cells = new Array(sites.length);
-			  beaches = new RedBlackTree;
-			  circles = new RedBlackTree;
-
-			  while (true) {
-				circle = firstCircle;
-				if (site && (!circle || site[1] < circle.y || (site[1] === circle.y && site[0] < circle.x))) {
-				  if (site[0] !== x || site[1] !== y) {
-					addBeach(site);
-					x = site[0], y = site[1];
-				  }
-				  site = sites.pop();
-				} else if (circle) {
-				  removeBeach(circle.arc);
-				} else {
-				  break;
-				}
-			  }
-
-			  sortCellHalfedges();
-
-			  if (extent) {
-				var x0 = +extent[0][0],
-					y0 = +extent[0][1],
-					x1 = +extent[1][0],
-					y1 = +extent[1][1];
-				clipEdges(x0, y0, x1, y1);
-				clipCells(x0, y0, x1, y1);
-			  }
-
-			  this.edges = edges;
-			  this.cells = cells;
-
-			  beaches =
-			  circles =
-			  edges =
-			  cells = null;
-			}
-
-			Diagram.prototype = {
-			  constructor: Diagram,
-
-			  polygons: function() {
-				var edges = this.edges;
-
-				return this.cells.map(function(cell) {
-				  var polygon = cell.halfedges.map(function(i) { return cellHalfedgeStart(cell, edges[i]); });
-				  polygon.data = cell.site.data;
-				  return polygon;
-				});
-			  },
-
-			  triangles: function() {
-				var triangles = [],
-					edges = this.edges;
-
-				this.cells.forEach(function(cell, i) {
-				  var site = cell.site,
-					  halfedges = cell.halfedges,
-					  j = -1,
-					  m = halfedges.length,
-					  s0,
-					  e1 = edges[halfedges[m - 1]],
-					  s1 = e1.left === site ? e1.right : e1.left;
-
-				  while (++j < m) {
-					s0 = s1;
-					e1 = edges[halfedges[j]];
-					s1 = e1.left === site ? e1.right : e1.left;
-					if (s0 && s1 && i < s0.index && i < s1.index && triangleArea(site, s0, s1) < 0) {
-					  triangles.push([site.data, s0.data, s1.data]);
-					}
-				  }
-				});
-
-				return triangles;
-			  },
-
-			  links: function() {
-				return this.edges.filter(function(edge) {
-				  return edge.right;
-				}).map(function(edge) {
-				  return {
-					source: edge.left.data,
-					target: edge.right.data
-				  };
-				});
-			  },
-
-			  find: function(x, y, radius) {
-				var that = this,
-					i0, i1 = that._found || 0,
-					cell = that.cells[i1] || that.cells[i1 = 0],
-					dx = x - cell.site[0],
-					dy = y - cell.site[1],
-					d2 = dx * dx + dy * dy;
-
-				do {
-				  cell = that.cells[i0 = i1], i1 = null;
-				  cell.halfedges.forEach(function(e) {
-					var edge = that.edges[e], v = edge.left;
-					if ((v === cell.site || !v) && !(v = edge.right)) return;
-					var vx = x - v[0],
-						vy = y - v[1],
-						v2 = vx * vx + vy * vy;
-					if (v2 < d2) d2 = v2, i1 = v.index;
-				  });
-				} while (i1 !== null);
-
-				that._found = i0;
-
-				return radius == null || d2 <= radius * radius ? cell.site : null;
-			  }
-			};
-
-			var voronoi = function() {
-			  var x$$1 = x$4,
-				  y$$1 = y$4,
-				  extent = null;
-
-			  function voronoi(data) {
-				return new Diagram(data.map(function(d, i) {
-				  var s = [Math.round(x$$1(d, i, data) / epsilon$3) * epsilon$3, Math.round(y$$1(d, i, data) / epsilon$3) * epsilon$3];
-				  s.index = i;
-				  s.data = d;
-				  return s;
-				}), extent);
-			  }
-
-			  voronoi.polygons = function(data) {
-				return voronoi(data).polygons();
-			  };
-
-			  voronoi.links = function(data) {
-				return voronoi(data).links();
-			  };
-
-			  voronoi.triangles = function(data) {
-				return voronoi(data).triangles();
-			  };
-
-			  voronoi.x = function(_) {
-				return arguments.length ? (x$$1 = typeof _ === "function" ? _ : constant$9(+_), voronoi) : x$$1;
-			  };
-
-			  voronoi.y = function(_) {
-				return arguments.length ? (y$$1 = typeof _ === "function" ? _ : constant$9(+_), voronoi) : y$$1;
-			  };
-
-			  voronoi.extent = function(_) {
-				return arguments.length ? (extent = _ == null ? null : [[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]], voronoi) : extent && [[extent[0][0], extent[0][1]], [extent[1][0], extent[1][1]]];
-			  };
-
-			  voronoi.size = function(_) {
-				return arguments.length ? (extent = _ == null ? null : [[0, 0], [+_[0], +_[1]]], voronoi) : extent && [extent[1][0] - extent[0][0], extent[1][1] - extent[0][1]];
-			  };
-
-			  return voronoi;
-			};
-
-			var constant$10 = function(x) {
-			  return function() {
-				return x;
-			  };
-			};
-
-			function ZoomEvent(target, type, transform) {
-			  this.target = target;
-			  this.type = type;
-			  this.transform = transform;
-			}
-
-			function Transform(k, x, y) {
-			  this.k = k;
-			  this.x = x;
-			  this.y = y;
-			}
-
-			Transform.prototype = {
-			  constructor: Transform,
-			  scale: function(k) {
-				return k === 1 ? this : new Transform(this.k * k, this.x, this.y);
-			  },
-			  translate: function(x, y) {
-				return x === 0 & y === 0 ? this : new Transform(this.k, this.x + this.k * x, this.y + this.k * y);
-			  },
-			  apply: function(point) {
-				return [point[0] * this.k + this.x, point[1] * this.k + this.y];
-			  },
-			  applyX: function(x) {
-				return x * this.k + this.x;
-			  },
-			  applyY: function(y) {
-				return y * this.k + this.y;
-			  },
-			  invert: function(location) {
-				return [(location[0] - this.x) / this.k, (location[1] - this.y) / this.k];
-			  },
-			  invertX: function(x) {
-				return (x - this.x) / this.k;
-			  },
-			  invertY: function(y) {
-				return (y - this.y) / this.k;
-			  },
-			  rescaleX: function(x) {
-				return x.copy().domain(x.range().map(this.invertX, this).map(x.invert, x));
-			  },
-			  rescaleY: function(y) {
-				return y.copy().domain(y.range().map(this.invertY, this).map(y.invert, y));
-			  },
-			  toString: function() {
-				return "translate(" + this.x + "," + this.y + ") scale(" + this.k + ")";
-			  }
-			};
-
-			var identity$6 = new Transform(1, 0, 0);
-
-			transform.prototype = Transform.prototype;
-
-			function transform(node) {
-			  return node.__zoom || identity$6;
-			}
-
-			function nopropagation$1() {
-			  exports.event.stopImmediatePropagation();
-			}
-
-			var noevent$1 = function() {
-			  exports.event.preventDefault();
-			  exports.event.stopImmediatePropagation();
-			};
-
-			// Ignore right-click, since that should open the context menu.
-			function defaultFilter$1() {
-			  return !exports.event.button;
-			}
-
-			function defaultExtent() {
-			  var e = this, w, h;
-			  if (e instanceof SVGElement) {
-				e = e.ownerSVGElement || e;
-				w = e.width.baseVal.value;
-				h = e.height.baseVal.value;
-			  } else {
-				w = e.clientWidth;
-				h = e.clientHeight;
-			  }
-			  return [[0, 0], [w, h]];
-			}
-
-			function defaultTransform() {
-			  return this.__zoom || identity$6;
-			}
-
-			var zoom = function() {
-			  var filter = defaultFilter$1,
-				  extent = defaultExtent,
-				  k0 = 0,
-				  k1 = Infinity,
-				  x0 = -k1,
-				  x1 = k1,
-				  y0 = x0,
-				  y1 = x1,
-				  duration = 250,
-				  gestures = [],
-				  listeners = dispatch("start", "zoom", "end"),
-				  touchstarting,
-				  touchending,
-				  touchDelay = 500,
-				  wheelDelay = 150;
-
-			  function zoom(selection$$1) {
-				selection$$1
-					.on("wheel.zoom", wheeled)
-					.on("mousedown.zoom", mousedowned)
-					.on("dblclick.zoom", dblclicked)
-					.on("touchstart.zoom", touchstarted)
-					.on("touchmove.zoom", touchmoved)
-					.on("touchend.zoom touchcancel.zoom", touchended)
-					.style("-webkit-tap-highlight-color", "rgba(0,0,0,0)")
-					.property("__zoom", defaultTransform);
-			  }
-
-			  zoom.transform = function(collection, transform) {
-				var selection$$1 = collection.selection ? collection.selection() : collection;
-				selection$$1.property("__zoom", defaultTransform);
-				if (collection !== selection$$1) {
-				  schedule(collection, transform);
-				} else {
-				  selection$$1.interrupt().each(function() {
-					gesture(this, arguments)
-						.start()
-						.zoom(null, typeof transform === "function" ? transform.apply(this, arguments) : transform)
-						.end();
-				  });
-				}
-			  };
-
-			  zoom.scaleBy = function(selection$$1, k) {
-				zoom.scaleTo(selection$$1, function() {
-				  var k0 = this.__zoom.k,
-					  k1 = typeof k === "function" ? k.apply(this, arguments) : k;
-				  return k0 * k1;
-				});
-			  };
-
-			  zoom.scaleTo = function(selection$$1, k) {
-				zoom.transform(selection$$1, function() {
-				  var e = extent.apply(this, arguments),
-					  t0 = this.__zoom,
-					  p0 = centroid(e),
-					  p1 = t0.invert(p0),
-					  k1 = typeof k === "function" ? k.apply(this, arguments) : k;
-				  return constrain(translate(scale(t0, k1), p0, p1), e);
-				});
-			  };
-
-			  zoom.translateBy = function(selection$$1, x, y) {
-				zoom.transform(selection$$1, function() {
-				  return constrain(this.__zoom.translate(
-					typeof x === "function" ? x.apply(this, arguments) : x,
-					typeof y === "function" ? y.apply(this, arguments) : y
-				  ), extent.apply(this, arguments));
-				});
-			  };
-
-			  function scale(transform, k) {
-				k = Math.max(k0, Math.min(k1, k));
-				return k === transform.k ? transform : new Transform(k, transform.x, transform.y);
-			  }
-
-			  function translate(transform, p0, p1) {
-				var x = p0[0] - p1[0] * transform.k, y = p0[1] - p1[1] * transform.k;
-				return x === transform.x && y === transform.y ? transform : new Transform(transform.k, x, y);
-			  }
-
-			  function constrain(transform, extent) {
-				var dx = Math.min(0, transform.invertX(extent[0][0]) - x0) || Math.max(0, transform.invertX(extent[1][0]) - x1),
-					dy = Math.min(0, transform.invertY(extent[0][1]) - y0) || Math.max(0, transform.invertY(extent[1][1]) - y1);
-				return dx || dy ? transform.translate(dx, dy) : transform;
-			  }
-
-			  function centroid(extent) {
-				return [(+extent[0][0] + +extent[1][0]) / 2, (+extent[0][1] + +extent[1][1]) / 2];
-			  }
-
-			  function schedule(transition$$1, transform, center) {
-				transition$$1
-					.on("start.zoom", function() { gesture(this, arguments).start(); })
-					.on("interrupt.zoom end.zoom", function() { gesture(this, arguments).end(); })
-					.tween("zoom", function() {
-					  var that = this,
-						  args = arguments,
-						  g = gesture(that, args),
-						  e = extent.apply(that, args),
-						  p = center || centroid(e),
-						  w = Math.max(e[1][0] - e[0][0], e[1][1] - e[0][1]),
-						  a = that.__zoom,
-						  b = typeof transform === "function" ? transform.apply(that, args) : transform,
-						  i = interpolateZoom(a.invert(p).concat(w / a.k), b.invert(p).concat(w / b.k));
-					  return function(t) {
-						if (t === 1) t = b; // Avoid rounding error on end.
-						else { var l = i(t), k = w / l[2]; t = new Transform(k, p[0] - l[0] * k, p[1] - l[1] * k); }
-						g.zoom(null, t);
-					  };
-					});
-			  }
-
-			  function gesture(that, args) {
-				for (var i = 0, n = gestures.length, g; i < n; ++i) {
-				  if ((g = gestures[i]).that === that) {
-					return g;
-				  }
-				}
-				return new Gesture(that, args);
-			  }
-
-			  function Gesture(that, args) {
-				this.that = that;
-				this.args = args;
-				this.index = -1;
-				this.active = 0;
-				this.extent = extent.apply(that, args);
-			  }
-
-			  Gesture.prototype = {
-				start: function() {
-				  if (++this.active === 1) {
-					this.index = gestures.push(this) - 1;
-					this.emit("start");
-				  }
-				  return this;
-				},
-				zoom: function(key, transform) {
-				  if (this.mouse && key !== "mouse") this.mouse[1] = transform.invert(this.mouse[0]);
-				  if (this.touch0 && key !== "touch") this.touch0[1] = transform.invert(this.touch0[0]);
-				  if (this.touch1 && key !== "touch") this.touch1[1] = transform.invert(this.touch1[0]);
-				  this.that.__zoom = transform;
-				  this.emit("zoom");
-				  return this;
-				},
-				end: function() {
-				  if (--this.active === 0) {
-					gestures.splice(this.index, 1);
-					this.index = -1;
-					this.emit("end");
-				  }
-				  return this;
-				},
-				emit: function(type) {
-				  customEvent(new ZoomEvent(zoom, type, this.that.__zoom), listeners.apply, listeners, [type, this.that, this.args]);
-				}
-			  };
-
-			  function wheeled() {
-				if (!filter.apply(this, arguments)) return;
-				var g = gesture(this, arguments),
-					t = this.__zoom,
-					k = Math.max(k0, Math.min(k1, t.k * Math.pow(2, -exports.event.deltaY * (exports.event.deltaMode ? 120 : 1) / 500))),
-					p = mouse(this);
-
-				// If the mouse is in the same location as before, reuse it.
-				// If there were recent wheel events, reset the wheel idle timeout.
-				if (g.wheel) {
-				  if (g.mouse[0][0] !== p[0] || g.mouse[0][1] !== p[1]) {
-					g.mouse[1] = t.invert(g.mouse[0] = p);
-				  }
-				  clearTimeout(g.wheel);
-				}
-
-				// If this wheel event won’t trigger a transform change, ignore it.
-				else if (t.k === k) return;
-
-				// Otherwise, capture the mouse point and location at the start.
-				else {
-				  g.mouse = [p, t.invert(p)];
-				  interrupt(this);
-				  g.start();
-				}
-
-				noevent$1();
-				g.wheel = setTimeout(wheelidled, wheelDelay);
-				g.zoom("mouse", constrain(translate(scale(t, k), g.mouse[0], g.mouse[1]), g.extent));
-
-				function wheelidled() {
-				  g.wheel = null;
-				  g.end();
-				}
-			  }
-
-			  function mousedowned() {
-				if (touchending || !filter.apply(this, arguments)) return;
-				var g = gesture(this, arguments),
-					v = select(exports.event.view).on("mousemove.zoom", mousemoved, true).on("mouseup.zoom", mouseupped, true),
-					p = mouse(this);
-
-				dragDisable(exports.event.view);
-				nopropagation$1();
-				g.mouse = [p, this.__zoom.invert(p)];
-				interrupt(this);
-				g.start();
-
-				function mousemoved() {
-				  noevent$1();
-				  g.moved = true;
-				  g.zoom("mouse", constrain(translate(g.that.__zoom, g.mouse[0] = mouse(g.that), g.mouse[1]), g.extent));
-				}
-
-				function mouseupped() {
-				  v.on("mousemove.zoom mouseup.zoom", null);
-				  yesdrag(exports.event.view, g.moved);
-				  noevent$1();
-				  g.end();
-				}
-			  }
-
-			  function dblclicked() {
-				if (!filter.apply(this, arguments)) return;
-				var t0 = this.__zoom,
-					p0 = mouse(this),
-					p1 = t0.invert(p0),
-					k1 = t0.k * (exports.event.shiftKey ? 0.5 : 2),
-					t1 = constrain(translate(scale(t0, k1), p0, p1), extent.apply(this, arguments));
-
-				noevent$1();
-				if (duration > 0) select(this).transition().duration(duration).call(schedule, t1, p0);
-				else select(this).call(zoom.transform, t1);
-			  }
-
-			  function touchstarted() {
-				if (!filter.apply(this, arguments)) return;
-				var g = gesture(this, arguments),
-					touches$$1 = exports.event.changedTouches,
-					n = touches$$1.length, i, t, p;
-
-				nopropagation$1();
-				for (i = 0; i < n; ++i) {
-				  t = touches$$1[i], p = touch(this, touches$$1, t.identifier);
-				  p = [p, this.__zoom.invert(p), t.identifier];
-				  if (!g.touch0) g.touch0 = p;
-				  else if (!g.touch1) g.touch1 = p;
-				}
-				if (touchstarting) {
-				  touchstarting = clearTimeout(touchstarting);
-				  if (!g.touch1) return g.end(), dblclicked.apply(this, arguments);
-				}
-				if (exports.event.touches.length === n) {
-				  touchstarting = setTimeout(function() { touchstarting = null; }, touchDelay);
-				  interrupt(this);
-				  g.start();
-				}
-			  }
-
-			  function touchmoved() {
-				var g = gesture(this, arguments),
-					touches$$1 = exports.event.changedTouches,
-					n = touches$$1.length, i, t, p, l;
-
-				noevent$1();
-				if (touchstarting) touchstarting = clearTimeout(touchstarting);
-				for (i = 0; i < n; ++i) {
-				  t = touches$$1[i], p = touch(this, touches$$1, t.identifier);
-				  if (g.touch0 && g.touch0[2] === t.identifier) g.touch0[0] = p;
-				  else if (g.touch1 && g.touch1[2] === t.identifier) g.touch1[0] = p;
-				}
-				t = g.that.__zoom;
-				if (g.touch1) {
-				  var p0 = g.touch0[0], l0 = g.touch0[1],
-					  p1 = g.touch1[0], l1 = g.touch1[1],
-					  dp = (dp = p1[0] - p0[0]) * dp + (dp = p1[1] - p0[1]) * dp,
-					  dl = (dl = l1[0] - l0[0]) * dl + (dl = l1[1] - l0[1]) * dl;
-				  t = scale(t, Math.sqrt(dp / dl));
-				  p = [(p0[0] + p1[0]) / 2, (p0[1] + p1[1]) / 2];
-				  l = [(l0[0] + l1[0]) / 2, (l0[1] + l1[1]) / 2];
-				}
-				else if (g.touch0) p = g.touch0[0], l = g.touch0[1];
-				else return;
-				g.zoom("touch", constrain(translate(t, p, l), g.extent));
-			  }
-
-			  function touchended() {
-				var g = gesture(this, arguments),
-					touches$$1 = exports.event.changedTouches,
-					n = touches$$1.length, i, t;
-
-				nopropagation$1();
-				if (touchending) clearTimeout(touchending);
-				touchending = setTimeout(function() { touchending = null; }, touchDelay);
-				for (i = 0; i < n; ++i) {
-				  t = touches$$1[i];
-				  if (g.touch0 && g.touch0[2] === t.identifier) delete g.touch0;
-				  else if (g.touch1 && g.touch1[2] === t.identifier) delete g.touch1;
-				}
-				if (g.touch1 && !g.touch0) g.touch0 = g.touch1, delete g.touch1;
-				if (!g.touch0) g.end();
-			  }
-
-			  zoom.filter = function(_) {
-				return arguments.length ? (filter = typeof _ === "function" ? _ : constant$10(!!_), zoom) : filter;
-			  };
-
-			  zoom.extent = function(_) {
-				return arguments.length ? (extent = typeof _ === "function" ? _ : constant$10([[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]]), zoom) : extent;
-			  };
-
-			  zoom.scaleExtent = function(_) {
-				return arguments.length ? (k0 = +_[0], k1 = +_[1], zoom) : [k0, k1];
-			  };
-
-			  zoom.translateExtent = function(_) {
-				return arguments.length ? (x0 = +_[0][0], x1 = +_[1][0], y0 = +_[0][1], y1 = +_[1][1], zoom) : [[x0, y0], [x1, y1]];
-			  };
-
-			  zoom.duration = function(_) {
-				return arguments.length ? (duration = +_, zoom) : duration;
-			  };
-
-			  zoom.on = function() {
-				var value = listeners.on.apply(listeners, arguments);
-				return value === listeners ? zoom : value;
-			  };
-
-			  return zoom;
-			};
-
-			var constant$11 = function(x) {
-			  return function() {
-				return x;
-			  };
-			};
-
-			var BrushEvent = function(target, type, selection) {
-			  this.target = target;
-			  this.type = type;
-			  this.selection = selection;
-			};
-
-			function nopropagation$2() {
-			  exports.event.stopImmediatePropagation();
-			}
-
-			var noevent$2 = function() {
-			  exports.event.preventDefault();
-			  exports.event.stopImmediatePropagation();
-			};
-
-			var MODE_DRAG = {name: "drag"};
-			var MODE_SPACE = {name: "space"};
-			var MODE_HANDLE = {name: "handle"};
-			var MODE_CENTER = {name: "center"};
-
-			var X = {
-			  name: "x",
-			  handles: ["e", "w"].map(type$1),
-			  input: function(x, e) { return x && [[x[0], e[0][1]], [x[1], e[1][1]]]; },
-			  output: function(xy) { return xy && [xy[0][0], xy[1][0]]; }
-			};
-
-			var Y = {
-			  name: "y",
-			  handles: ["n", "s"].map(type$1),
-			  input: function(y, e) { return y && [[e[0][0], y[0]], [e[1][0], y[1]]]; },
-			  output: function(xy) { return xy && [xy[0][1], xy[1][1]]; }
-			};
-
-			var XY = {
-			  name: "xy",
-			  handles: ["n", "e", "s", "w", "nw", "ne", "se", "sw"].map(type$1),
-			  input: function(xy) { return xy; },
-			  output: function(xy) { return xy; }
-			};
-
-			var cursors = {
-			  overlay: "crosshair",
-			  selection: "move",
-			  n: "ns-resize",
-			  e: "ew-resize",
-			  s: "ns-resize",
-			  w: "ew-resize",
-			  nw: "nwse-resize",
-			  ne: "nesw-resize",
-			  se: "nwse-resize",
-			  sw: "nesw-resize"
-			};
-
-			var flipX = {
-			  e: "w",
-			  w: "e",
-			  nw: "ne",
-			  ne: "nw",
-			  se: "sw",
-			  sw: "se"
-			};
-
-			var flipY = {
-			  n: "s",
-			  s: "n",
-			  nw: "sw",
-			  ne: "se",
-			  se: "ne",
-			  sw: "nw"
-			};
-
-			var signsX = {
-			  overlay: +1,
-			  selection: +1,
-			  n: null,
-			  e: +1,
-			  s: null,
-			  w: -1,
-			  nw: -1,
-			  ne: +1,
-			  se: +1,
-			  sw: -1
-			};
-
-			var signsY = {
-			  overlay: +1,
-			  selection: +1,
-			  n: -1,
-			  e: null,
-			  s: +1,
-			  w: null,
-			  nw: -1,
-			  ne: -1,
-			  se: +1,
-			  sw: +1
-			};
-
-			function type$1(t) {
-			  return {type: t};
-			}
-
-			// Ignore right-click, since that should open the context menu.
-			function defaultFilter$2() {
-			  return !exports.event.button;
-			}
-
-			function defaultExtent$1() {
-			  var svg = this.ownerSVGElement || this;
-			  return [[0, 0], [svg.width.baseVal.value, svg.height.baseVal.value]];
-			}
-
-			// Like d3.local, but with the name “__brush” rather than auto-generated.
-			function local$1(node) {
-			  while (!node.__brush) if (!(node = node.parentNode)) return;
-			  return node.__brush;
-			}
-
-			function empty$1(extent) {
-			  return extent[0][0] === extent[1][0]
-				  || extent[0][1] === extent[1][1];
-			}
-
-			function brushSelection(node) {
-			  var state = node.__brush;
-			  return state ? state.dim.output(state.selection) : null;
-			}
-
-			function brushX() {
-			  return brush$1(X);
-			}
-
-			function brushY() {
-			  return brush$1(Y);
-			}
-
-			var brush = function() {
-			  return brush$1(XY);
-			};
-
-			function brush$1(dim) {
-			  var extent = defaultExtent$1,
-				  filter = defaultFilter$2,
-				  listeners = dispatch(brush, "start", "brush", "end"),
-				  handleSize = 6,
-				  touchending;
-
-			  function brush(group) {
-				var overlay = group
-					.property("__brush", initialize)
-				  .selectAll(".overlay")
-				  .data([type$1("overlay")]);
-
-				overlay.enter().append("rect")
-					.attr("class", "overlay")
-					.attr("pointer-events", "all")
-					.attr("cursor", cursors.overlay)
-				  .merge(overlay)
-					.each(function() {
-					  var extent = local$1(this).extent;
-					  select(this)
-						  .attr("x", extent[0][0])
-						  .attr("y", extent[0][1])
-						  .attr("width", extent[1][0] - extent[0][0])
-						  .attr("height", extent[1][1] - extent[0][1]);
-					});
-
-				group.selectAll(".selection")
-				  .data([type$1("selection")])
-				  .enter().append("rect")
-					.attr("class", "selection")
-					.attr("cursor", cursors.selection)
-					.attr("fill", "#777")
-					.attr("fill-opacity", 0.3)
-					.attr("stroke", "#fff")
-					.attr("shape-rendering", "crispEdges");
-
-				var handle = group.selectAll(".handle")
-				  .data(dim.handles, function(d) { return d.type; });
-
-				handle.exit().remove();
-
-				handle.enter().append("rect")
-					.attr("class", function(d) { return "handle handle--" + d.type; })
-					.attr("cursor", function(d) { return cursors[d.type]; });
-
-				group
-					.each(redraw)
-					.attr("fill", "none")
-					.attr("pointer-events", "all")
-					.style("-webkit-tap-highlight-color", "rgba(0,0,0,0)")
-					.on("mousedown.brush touchstart.brush", started);
-			  }
-
-			  brush.move = function(group, selection$$1) {
-				if (group.selection) {
-				  group
-					  .on("start.brush", function() { emitter(this, arguments).beforestart().start(); })
-					  .on("interrupt.brush end.brush", function() { emitter(this, arguments).end(); })
-					  .tween("brush", function() {
-						var that = this,
-							state = that.__brush,
-							emit = emitter(that, arguments),
-							selection0 = state.selection,
-							selection1 = dim.input(typeof selection$$1 === "function" ? selection$$1.apply(this, arguments) : selection$$1, state.extent),
-							i = interpolate(selection0, selection1);
-
-						function tween(t) {
-						  state.selection = t === 1 && empty$1(selection1) ? null : i(t);
-						  redraw.call(that);
-						  emit.brush();
-						}
-
-						return selection0 && selection1 ? tween : tween(1);
-					  });
-				} else {
-				  group
-					  .each(function() {
-						var that = this,
-							args = arguments,
-							state = that.__brush,
-							selection1 = dim.input(typeof selection$$1 === "function" ? selection$$1.apply(that, args) : selection$$1, state.extent),
-							emit = emitter(that, args).beforestart();
-
-						interrupt(that);
-						state.selection = selection1 == null || empty$1(selection1) ? null : selection1;
-						redraw.call(that);
-						emit.start().brush().end();
-					  });
-				}
-			  };
-
-			  function redraw() {
-				var group = select(this),
-					selection$$1 = local$1(this).selection;
-
-				if (selection$$1) {
-				  group.selectAll(".selection")
-					  .style("display", null)
-					  .attr("x", selection$$1[0][0])
-					  .attr("y", selection$$1[0][1])
-					  .attr("width", selection$$1[1][0] - selection$$1[0][0])
-					  .attr("height", selection$$1[1][1] - selection$$1[0][1]);
-
-				  group.selectAll(".handle")
-					  .style("display", null)
-					  .attr("x", function(d) { return d.type[d.type.length - 1] === "e" ? selection$$1[1][0] - handleSize / 2 : selection$$1[0][0] - handleSize / 2; })
-					  .attr("y", function(d) { return d.type[0] === "s" ? selection$$1[1][1] - handleSize / 2 : selection$$1[0][1] - handleSize / 2; })
-					  .attr("width", function(d) { return d.type === "n" || d.type === "s" ? selection$$1[1][0] - selection$$1[0][0] + handleSize : handleSize; })
-					  .attr("height", function(d) { return d.type === "e" || d.type === "w" ? selection$$1[1][1] - selection$$1[0][1] + handleSize : handleSize; });
-				}
-
-				else {
-				  group.selectAll(".selection,.handle")
-					  .style("display", "none")
-					  .attr("x", null)
-					  .attr("y", null)
-					  .attr("width", null)
-					  .attr("height", null);
-				}
-			  }
-
-			  function emitter(that, args) {
-				return that.__brush.emitter || new Emitter(that, args);
-			  }
-
-			  function Emitter(that, args) {
-				this.that = that;
-				this.args = args;
-				this.state = that.__brush;
-				this.active = 0;
-			  }
-
-			  Emitter.prototype = {
-				beforestart: function() {
-				  if (++this.active === 1) this.state.emitter = this, this.starting = true;
-				  return this;
-				},
-				start: function() {
-				  if (this.starting) this.starting = false, this.emit("start");
-				  return this;
-				},
-				brush: function() {
-				  this.emit("brush");
-				  return this;
-				},
-				end: function() {
-				  if (--this.active === 0) delete this.state.emitter, this.emit("end");
-				  return this;
-				},
-				emit: function(type) {
-				  customEvent(new BrushEvent(brush, type, dim.output(this.state.selection)), listeners.apply, listeners, [type, this.that, this.args]);
-				}
-			  };
-
-			  function started() {
-				if (exports.event.touches) { if (exports.event.changedTouches.length < exports.event.touches.length) return noevent$2(); }
-				else if (touchending) return;
-				if (!filter.apply(this, arguments)) return;
-
-				var that = this,
-					type = exports.event.target.__data__.type,
-					mode = (exports.event.metaKey ? type = "overlay" : type) === "selection" ? MODE_DRAG : (exports.event.altKey ? MODE_CENTER : MODE_HANDLE),
-					signX = dim === Y ? null : signsX[type],
-					signY = dim === X ? null : signsY[type],
-					state = local$1(that),
-					extent = state.extent,
-					selection$$1 = state.selection,
-					W = extent[0][0], w0, w1,
-					N = extent[0][1], n0, n1,
-					E = extent[1][0], e0, e1,
-					S = extent[1][1], s0, s1,
-					dx,
-					dy,
-					moving,
-					shifting = signX && signY && exports.event.shiftKey,
-					lockX,
-					lockY,
-					point0 = mouse(that),
-					point = point0,
-					emit = emitter(that, arguments).beforestart();
-
-				if (type === "overlay") {
-				  state.selection = selection$$1 = [
-					[w0 = dim === Y ? W : point0[0], n0 = dim === X ? N : point0[1]],
-					[e0 = dim === Y ? E : w0, s0 = dim === X ? S : n0]
-				  ];
-				} else {
-				  w0 = selection$$1[0][0];
-				  n0 = selection$$1[0][1];
-				  e0 = selection$$1[1][0];
-				  s0 = selection$$1[1][1];
-				}
-
-				w1 = w0;
-				n1 = n0;
-				e1 = e0;
-				s1 = s0;
-
-				var group = select(that)
-					.attr("pointer-events", "none");
-
-				var overlay = group.selectAll(".overlay")
-					.attr("cursor", cursors[type]);
-
-				if (exports.event.touches) {
-				  group
-					  .on("touchmove.brush", moved, true)
-					  .on("touchend.brush touchcancel.brush", ended, true);
-				} else {
-				  var view = select(exports.event.view)
-					  .on("keydown.brush", keydowned, true)
-					  .on("keyup.brush", keyupped, true)
-					  .on("mousemove.brush", moved, true)
-					  .on("mouseup.brush", ended, true);
-
-				  dragDisable(exports.event.view);
-				}
-
-				nopropagation$2();
-				interrupt(that);
-				redraw.call(that);
-				emit.start();
-
-				function moved() {
-				  var point1 = mouse(that);
-				  if (shifting && !lockX && !lockY) {
-					if (Math.abs(point1[0] - point[0]) > Math.abs(point1[1] - point[1])) lockY = true;
-					else lockX = true;
-				  }
-				  point = point1;
-				  moving = true;
-				  noevent$2();
-				  move();
-				}
-
-				function move() {
-				  var t;
-
-				  dx = point[0] - point0[0];
-				  dy = point[1] - point0[1];
-
-				  switch (mode) {
-					case MODE_SPACE:
-					case MODE_DRAG: {
-					  if (signX) dx = Math.max(W - w0, Math.min(E - e0, dx)), w1 = w0 + dx, e1 = e0 + dx;
-					  if (signY) dy = Math.max(N - n0, Math.min(S - s0, dy)), n1 = n0 + dy, s1 = s0 + dy;
-					  break;
-					}
-					case MODE_HANDLE: {
-					  if (signX < 0) dx = Math.max(W - w0, Math.min(E - w0, dx)), w1 = w0 + dx, e1 = e0;
-					  else if (signX > 0) dx = Math.max(W - e0, Math.min(E - e0, dx)), w1 = w0, e1 = e0 + dx;
-					  if (signY < 0) dy = Math.max(N - n0, Math.min(S - n0, dy)), n1 = n0 + dy, s1 = s0;
-					  else if (signY > 0) dy = Math.max(N - s0, Math.min(S - s0, dy)), n1 = n0, s1 = s0 + dy;
-					  break;
-					}
-					case MODE_CENTER: {
-					  if (signX) w1 = Math.max(W, Math.min(E, w0 - dx * signX)), e1 = Math.max(W, Math.min(E, e0 + dx * signX));
-					  if (signY) n1 = Math.max(N, Math.min(S, n0 - dy * signY)), s1 = Math.max(N, Math.min(S, s0 + dy * signY));
-					  break;
-					}
-				  }
-
-				  if (e1 < w1) {
-					signX *= -1;
-					t = w0, w0 = e0, e0 = t;
-					t = w1, w1 = e1, e1 = t;
-					if (type in flipX) overlay.attr("cursor", cursors[type = flipX[type]]);
-				  }
-
-				  if (s1 < n1) {
-					signY *= -1;
-					t = n0, n0 = s0, s0 = t;
-					t = n1, n1 = s1, s1 = t;
-					if (type in flipY) overlay.attr("cursor", cursors[type = flipY[type]]);
-				  }
-
-				  if (state.selection) selection$$1 = state.selection; // May be set by brush.move!
-				  if (lockX) w1 = selection$$1[0][0], e1 = selection$$1[1][0];
-				  if (lockY) n1 = selection$$1[0][1], s1 = selection$$1[1][1];
-
-				  if (selection$$1[0][0] !== w1
-					  || selection$$1[0][1] !== n1
-					  || selection$$1[1][0] !== e1
-					  || selection$$1[1][1] !== s1) {
-					state.selection = [[w1, n1], [e1, s1]];
-					redraw.call(that);
-					emit.brush();
-				  }
-				}
-
-				function ended() {
-				  nopropagation$2();
-				  if (exports.event.touches) {
-					if (exports.event.touches.length) return;
-					if (touchending) clearTimeout(touchending);
-					touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!
-					group.on("touchmove.brush touchend.brush touchcancel.brush", null);
-				  } else {
-					yesdrag(exports.event.view, moving);
-					view.on("keydown.brush keyup.brush mousemove.brush mouseup.brush", null);
-				  }
-				  group.attr("pointer-events", "all");
-				  overlay.attr("cursor", cursors.overlay);
-				  if (state.selection) selection$$1 = state.selection; // May be set by brush.move (on start)!
-				  if (empty$1(selection$$1)) state.selection = null, redraw.call(that);
-				  emit.end();
-				}
-
-				function keydowned() {
-				  switch (exports.event.keyCode) {
-					case 16: { // SHIFT
-					  shifting = signX && signY;
-					  break;
-					}
-					case 18: { // ALT
-					  if (mode === MODE_HANDLE) {
-						if (signX) e0 = e1 - dx * signX, w0 = w1 + dx * signX;
-						if (signY) s0 = s1 - dy * signY, n0 = n1 + dy * signY;
-						mode = MODE_CENTER;
-						move();
-					  }
-					  break;
-					}
-					case 32: { // SPACE; takes priority over ALT
-					  if (mode === MODE_HANDLE || mode === MODE_CENTER) {
-						if (signX < 0) e0 = e1 - dx; else if (signX > 0) w0 = w1 - dx;
-						if (signY < 0) s0 = s1 - dy; else if (signY > 0) n0 = n1 - dy;
-						mode = MODE_SPACE;
-						overlay.attr("cursor", cursors.selection);
-						move();
-					  }
-					  break;
-					}
-					default: return;
-				  }
-				  noevent$2();
-				}
-
-				function keyupped() {
-				  switch (exports.event.keyCode) {
-					case 16: { // SHIFT
-					  if (shifting) {
-						lockX = lockY = shifting = false;
-						move();
-					  }
-					  break;
-					}
-					case 18: { // ALT
-					  if (mode === MODE_CENTER) {
-						if (signX < 0) e0 = e1; else if (signX > 0) w0 = w1;
-						if (signY < 0) s0 = s1; else if (signY > 0) n0 = n1;
-						mode = MODE_HANDLE;
-						move();
-					  }
-					  break;
-					}
-					case 32: { // SPACE
-					  if (mode === MODE_SPACE) {
-						if (exports.event.altKey) {
-						  if (signX) e0 = e1 - dx * signX, w0 = w1 + dx * signX;
-						  if (signY) s0 = s1 - dy * signY, n0 = n1 + dy * signY;
-						  mode = MODE_CENTER;
-						} else {
-						  if (signX < 0) e0 = e1; else if (signX > 0) w0 = w1;
-						  if (signY < 0) s0 = s1; else if (signY > 0) n0 = n1;
-						  mode = MODE_HANDLE;
-						}
-						overlay.attr("cursor", cursors[type]);
-						move();
-					  }
-					  break;
-					}
-					default: return;
-				  }
-				  noevent$2();
-				}
-			  }
-
-			  function initialize() {
-				var state = this.__brush || {selection: null};
-				state.extent = extent.apply(this, arguments);
-				state.dim = dim;
-				return state;
-			  }
-
-			  brush.extent = function(_) {
-				return arguments.length ? (extent = typeof _ === "function" ? _ : constant$11([[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]]), brush) : extent;
-			  };
-
-			  brush.filter = function(_) {
-				return arguments.length ? (filter = typeof _ === "function" ? _ : constant$11(!!_), brush) : filter;
-			  };
-
-			  brush.handleSize = function(_) {
-				return arguments.length ? (handleSize = +_, brush) : handleSize;
-			  };
-
-			  brush.on = function() {
-				var value = listeners.on.apply(listeners, arguments);
-				return value === listeners ? brush : value;
-			  };
-
-			  return brush;
-			}
-
-			var cos = Math.cos;
-			var sin = Math.sin;
-			var pi$3 = Math.PI;
-			var halfPi$2 = pi$3 / 2;
-			var tau$3 = pi$3 * 2;
-			var max$1 = Math.max;
-
-			function compareValue(compare) {
-			  return function(a, b) {
-				return compare(
-				  a.source.value + a.target.value,
-				  b.source.value + b.target.value
-				);
-			  };
-			}
-
-			var chord = function() {
-			  var padAngle = 0,
-				  sortGroups = null,
-				  sortSubgroups = null,
-				  sortChords = null;
-
-			  function chord(matrix) {
-				var n = matrix.length,
-					groupSums = [],
-					groupIndex = range(n),
-					subgroupIndex = [],
-					chords = [],
-					groups = chords.groups = new Array(n),
-					subgroups = new Array(n * n),
-					k,
-					x,
-					x0,
-					dx,
-					i,
-					j;
-
-				// Compute the sum.
-				k = 0, i = -1; while (++i < n) {
-				  x = 0, j = -1; while (++j < n) {
-					x += matrix[i][j];
-				  }
-				  groupSums.push(x);
-				  subgroupIndex.push(range(n));
-				  k += x;
-				}
-
-				// Sort groups…
-				if (sortGroups) groupIndex.sort(function(a, b) {
-				  return sortGroups(groupSums[a], groupSums[b]);
-				});
-
-				// Sort subgroups…
-				if (sortSubgroups) subgroupIndex.forEach(function(d, i) {
-				  d.sort(function(a, b) {
-					return sortSubgroups(matrix[i][a], matrix[i][b]);
-				  });
-				});
-
-				// Convert the sum to scaling factor for [0, 2pi].
-				// TODO Allow start and end angle to be specified?
-				// TODO Allow padding to be specified as percentage?
-				k = max$1(0, tau$3 - padAngle * n) / k;
-				dx = k ? padAngle : tau$3 / n;
-
-				// Compute the start and end angle for each group and subgroup.
-				// Note: Opera has a bug reordering object literal properties!
-				x = 0, i = -1; while (++i < n) {
-				  x0 = x, j = -1; while (++j < n) {
-					var di = groupIndex[i],
-						dj = subgroupIndex[di][j],
-						v = matrix[di][dj],
-						a0 = x,
-						a1 = x += v * k;
-					subgroups[dj * n + di] = {
-					  index: di,
-					  subindex: dj,
-					  startAngle: a0,
-					  endAngle: a1,
-					  value: v
-					};
-				  }
-				  groups[di] = {
-					index: di,
-					startAngle: x0,
-					endAngle: x,
-					value: groupSums[di]
-				  };
-				  x += dx;
-				}
-
-				// Generate chords for each (non-empty) subgroup-subgroup link.
-				i = -1; while (++i < n) {
-				  j = i - 1; while (++j < n) {
-					var source = subgroups[j * n + i],
-						target = subgroups[i * n + j];
-					if (source.value || target.value) {
-					  chords.push(source.value < target.value
-						  ? {source: target, target: source}
-						  : {source: source, target: target});
-					}
-				  }
-				}
-
-				return sortChords ? chords.sort(sortChords) : chords;
-			  }
-
-			  chord.padAngle = function(_) {
-				return arguments.length ? (padAngle = max$1(0, _), chord) : padAngle;
-			  };
-
-			  chord.sortGroups = function(_) {
-				return arguments.length ? (sortGroups = _, chord) : sortGroups;
-			  };
-
-			  chord.sortSubgroups = function(_) {
-				return arguments.length ? (sortSubgroups = _, chord) : sortSubgroups;
-			  };
-
-			  chord.sortChords = function(_) {
-				return arguments.length ? (_ == null ? sortChords = null : (sortChords = compareValue(_))._ = _, chord) : sortChords && sortChords._;
-			  };
-
-			  return chord;
-			};
-
-			var slice$5 = Array.prototype.slice;
-
-			var constant$12 = function(x) {
-			  return function() {
-				return x;
-			  };
-			};
-
-			function defaultSource(d) {
-			  return d.source;
-			}
-
-			function defaultTarget(d) {
-			  return d.target;
-			}
-
-			function defaultRadius$1(d) {
-			  return d.radius;
-			}
-
-			function defaultStartAngle(d) {
-			  return d.startAngle;
-			}
-
-			function defaultEndAngle(d) {
-			  return d.endAngle;
-			}
-
-			var ribbon = function() {
-			  var source = defaultSource,
-				  target = defaultTarget,
-				  radius = defaultRadius$1,
-				  startAngle = defaultStartAngle,
-				  endAngle = defaultEndAngle,
-				  context = null;
-
-			  function ribbon() {
-				var buffer,
-					argv = slice$5.call(arguments),
-					s = source.apply(this, argv),
-					t = target.apply(this, argv),
-					sr = +radius.apply(this, (argv[0] = s, argv)),
-					sa0 = startAngle.apply(this, argv) - halfPi$2,
-					sa1 = endAngle.apply(this, argv) - halfPi$2,
-					sx0 = sr * cos(sa0),
-					sy0 = sr * sin(sa0),
-					tr = +radius.apply(this, (argv[0] = t, argv)),
-					ta0 = startAngle.apply(this, argv) - halfPi$2,
-					ta1 = endAngle.apply(this, argv) - halfPi$2;
-
-				if (!context) context = buffer = path();
-
-				context.moveTo(sx0, sy0);
-				context.arc(0, 0, sr, sa0, sa1);
-				if (sa0 !== ta0 || sa1 !== ta1) { // TODO sr !== tr?
-				  context.quadraticCurveTo(0, 0, tr * cos(ta0), tr * sin(ta0));
-				  context.arc(0, 0, tr, ta0, ta1);
-				}
-				context.quadraticCurveTo(0, 0, sx0, sy0);
-				context.closePath();
-
-				if (buffer) return context = null, buffer + "" || null;
-			  }
-
-			  ribbon.radius = function(_) {
-				return arguments.length ? (radius = typeof _ === "function" ? _ : constant$12(+_), ribbon) : radius;
-			  };
-
-			  ribbon.startAngle = function(_) {
-				return arguments.length ? (startAngle = typeof _ === "function" ? _ : constant$12(+_), ribbon) : startAngle;
-			  };
-
-			  ribbon.endAngle = function(_) {
-				return arguments.length ? (endAngle = typeof _ === "function" ? _ : constant$12(+_), ribbon) : endAngle;
-			  };
-
-			  ribbon.source = function(_) {
-				return arguments.length ? (source = _, ribbon) : source;
-			  };
-
-			  ribbon.target = function(_) {
-				return arguments.length ? (target = _, ribbon) : target;
-			  };
-
-			  ribbon.context = function(_) {
-				return arguments.length ? ((context = _ == null ? null : _), ribbon) : context;
-			  };
-
-			  return ribbon;
-			};
-
-			// Adds floating point numbers with twice the normal precision.
-			// Reference: J. R. Shewchuk, Adaptive Precision Floating-Point Arithmetic and
-			// Fast Robust Geometric Predicates, Discrete & Computational Geometry 18(3)
-			// 305–363 (1997).
-			// Code adapted from GeographicLib by Charles F. F. Karney,
-			// http://geographiclib.sourceforge.net/
-
-			var adder = function() {
-			  return new Adder;
-			};
-
-			function Adder() {
-			  this.reset();
-			}
-
-			Adder.prototype = {
-			  constructor: Adder,
-			  reset: function() {
-				this.s = // rounded value
-				this.t = 0; // exact error
-			  },
-			  add: function(y) {
-				add$1(temp, y, this.t);
-				add$1(this, temp.s, this.s);
-				if (this.s) this.t += temp.t;
-				else this.s = temp.t;
-			  },
-			  valueOf: function() {
-				return this.s;
-			  }
-			};
-
-			var temp = new Adder;
-
-			function add$1(adder, a, b) {
-			  var x = adder.s = a + b,
-				  bv = x - a,
-				  av = x - bv;
-			  adder.t = (a - av) + (b - bv);
-			}
-
-			var epsilon$4 = 1e-6;
-			var epsilon2$2 = 1e-12;
-			var pi$4 = Math.PI;
-			var halfPi$3 = pi$4 / 2;
-			var quarterPi = pi$4 / 4;
-			var tau$4 = pi$4 * 2;
-
-			var degrees$1 = 180 / pi$4;
-			var radians = pi$4 / 180;
-
-			var abs = Math.abs;
-			var atan = Math.atan;
-			var atan2 = Math.atan2;
-			var cos$1 = Math.cos;
-			var ceil = Math.ceil;
-			var exp = Math.exp;
-
-			var log$1 = Math.log;
-			var pow$1 = Math.pow;
-			var sin$1 = Math.sin;
-			var sign$1 = Math.sign || function(x) { return x > 0 ? 1 : x < 0 ? -1 : 0; };
-			var sqrt$1 = Math.sqrt;
-			var tan = Math.tan;
-
-			function acos(x) {
-			  return x > 1 ? 0 : x < -1 ? pi$4 : Math.acos(x);
-			}
-
-			function asin$1(x) {
-			  return x > 1 ? halfPi$3 : x < -1 ? -halfPi$3 : Math.asin(x);
-			}
-
-			function haversin(x) {
-			  return (x = sin$1(x / 2)) * x;
-			}
-
-			function noop$2() {}
-
-			function streamGeometry(geometry, stream) {
-			  if (geometry && streamGeometryType.hasOwnProperty(geometry.type)) {
-				streamGeometryType[geometry.type](geometry, stream);
-			  }
-			}
-
-			var streamObjectType = {
-			  Feature: function(feature, stream) {
-				streamGeometry(feature.geometry, stream);
-			  },
-			  FeatureCollection: function(object, stream) {
-				var features = object.features, i = -1, n = features.length;
-				while (++i < n) streamGeometry(features[i].geometry, stream);
-			  }
-			};
-
-			var streamGeometryType = {
-			  Sphere: function(object, stream) {
-				stream.sphere();
-			  },
-			  Point: function(object, stream) {
-				object = object.coordinates;
-				stream.point(object[0], object[1], object[2]);
-			  },
-			  MultiPoint: function(object, stream) {
-				var coordinates = object.coordinates, i = -1, n = coordinates.length;
-				while (++i < n) object = coordinates[i], stream.point(object[0], object[1], object[2]);
-			  },
-			  LineString: function(object, stream) {
-				streamLine(object.coordinates, stream, 0);
-			  },
-			  MultiLineString: function(object, stream) {
-				var coordinates = object.coordinates, i = -1, n = coordinates.length;
-				while (++i < n) streamLine(coordinates[i], stream, 0);
-			  },
-			  Polygon: function(object, stream) {
-				streamPolygon(object.coordinates, stream);
-			  },
-			  MultiPolygon: function(object, stream) {
-				var coordinates = object.coordinates, i = -1, n = coordinates.length;
-				while (++i < n) streamPolygon(coordinates[i], stream);
-			  },
-			  GeometryCollection: function(object, stream) {
-				var geometries = object.geometries, i = -1, n = geometries.length;
-				while (++i < n) streamGeometry(geometries[i], stream);
-			  }
-			};
-
-			function streamLine(coordinates, stream, closed) {
-			  var i = -1, n = coordinates.length - closed, coordinate;
-			  stream.lineStart();
-			  while (++i < n) coordinate = coordinates[i], stream.point(coordinate[0], coordinate[1], coordinate[2]);
-			  stream.lineEnd();
-			}
-
-			function streamPolygon(coordinates, stream) {
-			  var i = -1, n = coordinates.length;
-			  stream.polygonStart();
-			  while (++i < n) streamLine(coordinates[i], stream, 1);
-			  stream.polygonEnd();
-			}
-
-			var geoStream = function(object, stream) {
-			  if (object && streamObjectType.hasOwnProperty(object.type)) {
-				streamObjectType[object.type](object, stream);
-			  } else {
-				streamGeometry(object, stream);
-			  }
-			};
-
-			var areaRingSum = adder();
-
-			var areaSum = adder();
-			var lambda00;
-			var phi00;
-			var lambda0;
-			var cosPhi0;
-			var sinPhi0;
-
-			var areaStream = {
-			  point: noop$2,
-			  lineStart: noop$2,
-			  lineEnd: noop$2,
-			  polygonStart: function() {
-				areaRingSum.reset();
-				areaStream.lineStart = areaRingStart;
-				areaStream.lineEnd = areaRingEnd;
-			  },
-			  polygonEnd: function() {
-				var areaRing = +areaRingSum;
-				areaSum.add(areaRing < 0 ? tau$4 + areaRing : areaRing);
-				this.lineStart = this.lineEnd = this.point = noop$2;
-			  },
-			  sphere: function() {
-				areaSum.add(tau$4);
-			  }
-			};
-
-			function areaRingStart() {
-			  areaStream.point = areaPointFirst;
-			}
-
-			function areaRingEnd() {
-			  areaPoint(lambda00, phi00);
-			}
-
-			function areaPointFirst(lambda, phi) {
-			  areaStream.point = areaPoint;
-			  lambda00 = lambda, phi00 = phi;
-			  lambda *= radians, phi *= radians;
-			  lambda0 = lambda, cosPhi0 = cos$1(phi = phi / 2 + quarterPi), sinPhi0 = sin$1(phi);
-			}
-
-			function areaPoint(lambda, phi) {
-			  lambda *= radians, phi *= radians;
-			  phi = phi / 2 + quarterPi; // half the angular distance from south pole
-
-			  // Spherical excess E for a spherical triangle with vertices: south pole,
-			  // previous point, current point.  Uses a formula derived from Cagnoli’s
-			  // theorem.  See Todhunter, Spherical Trig. (1871), Sec. 103, Eq. (2).
-			  var dLambda = lambda - lambda0,
-				  sdLambda = dLambda >= 0 ? 1 : -1,
-				  adLambda = sdLambda * dLambda,
-				  cosPhi = cos$1(phi),
-				  sinPhi = sin$1(phi),
-				  k = sinPhi0 * sinPhi,
-				  u = cosPhi0 * cosPhi + k * cos$1(adLambda),
-				  v = k * sdLambda * sin$1(adLambda);
-			  areaRingSum.add(atan2(v, u));
-
-			  // Advance the previous points.
-			  lambda0 = lambda, cosPhi0 = cosPhi, sinPhi0 = sinPhi;
-			}
-
-			var area$2 = function(object) {
-			  areaSum.reset();
-			  geoStream(object, areaStream);
-			  return areaSum * 2;
-			};
-
-			function spherical(cartesian) {
-			  return [atan2(cartesian[1], cartesian[0]), asin$1(cartesian[2])];
-			}
-
-			function cartesian(spherical) {
-			  var lambda = spherical[0], phi = spherical[1], cosPhi = cos$1(phi);
-			  return [cosPhi * cos$1(lambda), cosPhi * sin$1(lambda), sin$1(phi)];
-			}
-
-			function cartesianDot(a, b) {
-			  return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];
-			}
-
-			function cartesianCross(a, b) {
-			  return [a[1] * b[2] - a[2] * b[1], a[2] * b[0] - a[0] * b[2], a[0] * b[1] - a[1] * b[0]];
-			}
-
-			// TODO return a
-			function cartesianAddInPlace(a, b) {
-			  a[0] += b[0], a[1] += b[1], a[2] += b[2];
-			}
-
-			function cartesianScale(vector, k) {
-			  return [vector[0] * k, vector[1] * k, vector[2] * k];
-			}
-
-			// TODO return d
-			function cartesianNormalizeInPlace(d) {
-			  var l = sqrt$1(d[0] * d[0] + d[1] * d[1] + d[2] * d[2]);
-			  d[0] /= l, d[1] /= l, d[2] /= l;
-			}
-
-			var lambda0$1;
-			var phi0;
-			var lambda1;
-			var phi1;
-			var lambda2;
-			var lambda00$1;
-			var phi00$1;
-			var p0;
-			var deltaSum = adder();
-			var ranges;
-			var range$1;
-
-			var boundsStream = {
-			  point: boundsPoint,
-			  lineStart: boundsLineStart,
-			  lineEnd: boundsLineEnd,
-			  polygonStart: function() {
-				boundsStream.point = boundsRingPoint;
-				boundsStream.lineStart = boundsRingStart;
-				boundsStream.lineEnd = boundsRingEnd;
-				deltaSum.reset();
-				areaStream.polygonStart();
-			  },
-			  polygonEnd: function() {
-				areaStream.polygonEnd();
-				boundsStream.point = boundsPoint;
-				boundsStream.lineStart = boundsLineStart;
-				boundsStream.lineEnd = boundsLineEnd;
-				if (areaRingSum < 0) lambda0$1 = -(lambda1 = 180), phi0 = -(phi1 = 90);
-				else if (deltaSum > epsilon$4) phi1 = 90;
-				else if (deltaSum < -epsilon$4) phi0 = -90;
-				range$1[0] = lambda0$1, range$1[1] = lambda1;
-			  }
-			};
-
-			function boundsPoint(lambda, phi) {
-			  ranges.push(range$1 = [lambda0$1 = lambda, lambda1 = lambda]);
-			  if (phi < phi0) phi0 = phi;
-			  if (phi > phi1) phi1 = phi;
-			}
-
-			function linePoint(lambda, phi) {
-			  var p = cartesian([lambda * radians, phi * radians]);
-			  if (p0) {
-				var normal = cartesianCross(p0, p),
-					equatorial = [normal[1], -normal[0], 0],
-					inflection = cartesianCross(equatorial, normal);
-				cartesianNormalizeInPlace(inflection);
-				inflection = spherical(inflection);
-				var delta = lambda - lambda2,
-					sign$$1 = delta > 0 ? 1 : -1,
-					lambdai = inflection[0] * degrees$1 * sign$$1,
-					phii,
-					antimeridian = abs(delta) > 180;
-				if (antimeridian ^ (sign$$1 * lambda2 < lambdai && lambdai < sign$$1 * lambda)) {
-				  phii = inflection[1] * degrees$1;
-				  if (phii > phi1) phi1 = phii;
-				} else if (lambdai = (lambdai + 360) % 360 - 180, antimeridian ^ (sign$$1 * lambda2 < lambdai && lambdai < sign$$1 * lambda)) {
-				  phii = -inflection[1] * degrees$1;
-				  if (phii < phi0) phi0 = phii;
-				} else {
-				  if (phi < phi0) phi0 = phi;
-				  if (phi > phi1) phi1 = phi;
-				}
-				if (antimeridian) {
-				  if (lambda < lambda2) {
-					if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) lambda1 = lambda;
-				  } else {
-					if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) lambda0$1 = lambda;
-				  }
-				} else {
-				  if (lambda1 >= lambda0$1) {
-					if (lambda < lambda0$1) lambda0$1 = lambda;
-					if (lambda > lambda1) lambda1 = lambda;
-				  } else {
-					if (lambda > lambda2) {
-					  if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) lambda1 = lambda;
-					} else {
-					  if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) lambda0$1 = lambda;
-					}
-				  }
-				}
-			  } else {
-				boundsPoint(lambda, phi);
-			  }
-			  p0 = p, lambda2 = lambda;
-			}
-
-			function boundsLineStart() {
-			  boundsStream.point = linePoint;
-			}
-
-			function boundsLineEnd() {
-			  range$1[0] = lambda0$1, range$1[1] = lambda1;
-			  boundsStream.point = boundsPoint;
-			  p0 = null;
-			}
-
-			function boundsRingPoint(lambda, phi) {
-			  if (p0) {
-				var delta = lambda - lambda2;
-				deltaSum.add(abs(delta) > 180 ? delta + (delta > 0 ? 360 : -360) : delta);
-			  } else {
-				lambda00$1 = lambda, phi00$1 = phi;
-			  }
-			  areaStream.point(lambda, phi);
-			  linePoint(lambda, phi);
-			}
-
-			function boundsRingStart() {
-			  areaStream.lineStart();
-			}
-
-			function boundsRingEnd() {
-			  boundsRingPoint(lambda00$1, phi00$1);
-			  areaStream.lineEnd();
-			  if (abs(deltaSum) > epsilon$4) lambda0$1 = -(lambda1 = 180);
-			  range$1[0] = lambda0$1, range$1[1] = lambda1;
-			  p0 = null;
-			}
-
-			// Finds the left-right distance between two longitudes.
-			// This is almost the same as (lambda1 - lambda0 + 360°) % 360°, except that we want
-			// the distance between ±180° to be 360°.
-			function angle(lambda0, lambda1) {
-			  return (lambda1 -= lambda0) < 0 ? lambda1 + 360 : lambda1;
-			}
-
-			function rangeCompare(a, b) {
-			  return a[0] - b[0];
-			}
-
-			function rangeContains(range, x) {
-			  return range[0] <= range[1] ? range[0] <= x && x <= range[1] : x < range[0] || range[1] < x;
-			}
-
-			var bounds = function(feature) {
-			  var i, n, a, b, merged, deltaMax, delta;
-
-			  phi1 = lambda1 = -(lambda0$1 = phi0 = Infinity);
-			  ranges = [];
-			  geoStream(feature, boundsStream);
-
-			  // First, sort ranges by their minimum longitudes.
-			  if (n = ranges.length) {
-				ranges.sort(rangeCompare);
-
-				// Then, merge any ranges that overlap.
-				for (i = 1, a = ranges[0], merged = [a]; i < n; ++i) {
-				  b = ranges[i];
-				  if (rangeContains(a, b[0]) || rangeContains(a, b[1])) {
-					if (angle(a[0], b[1]) > angle(a[0], a[1])) a[1] = b[1];
-					if (angle(b[0], a[1]) > angle(a[0], a[1])) a[0] = b[0];
-				  } else {
-					merged.push(a = b);
-				  }
-				}
-
-				// Finally, find the largest gap between the merged ranges.
-				// The final bounding box will be the inverse of this gap.
-				for (deltaMax = -Infinity, n = merged.length - 1, i = 0, a = merged[n]; i <= n; a = b, ++i) {
-				  b = merged[i];
-				  if ((delta = angle(a[1], b[0])) > deltaMax) deltaMax = delta, lambda0$1 = b[0], lambda1 = a[1];
-				}
-			  }
-
-			  ranges = range$1 = null;
-
-			  return lambda0$1 === Infinity || phi0 === Infinity
-				  ? [[NaN, NaN], [NaN, NaN]]
-				  : [[lambda0$1, phi0], [lambda1, phi1]];
-			};
-
-			var W0;
-			var W1;
-			var X0;
-			var Y0;
-			var Z0;
-			var X1;
-			var Y1;
-			var Z1;
-			var X2;
-			var Y2;
-			var Z2;
-			var lambda00$2;
-			var phi00$2;
-			var x0;
-			var y0;
-			var z0; // previous point
-
-			var centroidStream = {
-			  sphere: noop$2,
-			  point: centroidPoint,
-			  lineStart: centroidLineStart,
-			  lineEnd: centroidLineEnd,
-			  polygonStart: function() {
-				centroidStream.lineStart = centroidRingStart;
-				centroidStream.lineEnd = centroidRingEnd;
-			  },
-			  polygonEnd: function() {
-				centroidStream.lineStart = centroidLineStart;
-				centroidStream.lineEnd = centroidLineEnd;
-			  }
-			};
-
-			// Arithmetic mean of Cartesian vectors.
-			function centroidPoint(lambda, phi) {
-			  lambda *= radians, phi *= radians;
-			  var cosPhi = cos$1(phi);
-			  centroidPointCartesian(cosPhi * cos$1(lambda), cosPhi * sin$1(lambda), sin$1(phi));
-			}
-
-			function centroidPointCartesian(x, y, z) {
-			  ++W0;
-			  X0 += (x - X0) / W0;
-			  Y0 += (y - Y0) / W0;
-			  Z0 += (z - Z0) / W0;
-			}
-
-			function centroidLineStart() {
-			  centroidStream.point = centroidLinePointFirst;
-			}
-
-			function centroidLinePointFirst(lambda, phi) {
-			  lambda *= radians, phi *= radians;
-			  var cosPhi = cos$1(phi);
-			  x0 = cosPhi * cos$1(lambda);
-			  y0 = cosPhi * sin$1(lambda);
-			  z0 = sin$1(phi);
-			  centroidStream.point = centroidLinePoint;
-			  centroidPointCartesian(x0, y0, z0);
-			}
-
-			function centroidLinePoint(lambda, phi) {
-			  lambda *= radians, phi *= radians;
-			  var cosPhi = cos$1(phi),
-				  x = cosPhi * cos$1(lambda),
-				  y = cosPhi * sin$1(lambda),
-				  z = sin$1(phi),
-				  w = atan2(sqrt$1((w = y0 * z - z0 * y) * w + (w = z0 * x - x0 * z) * w + (w = x0 * y - y0 * x) * w), x0 * x + y0 * y + z0 * z);
-			  W1 += w;
-			  X1 += w * (x0 + (x0 = x));
-			  Y1 += w * (y0 + (y0 = y));
-			  Z1 += w * (z0 + (z0 = z));
-			  centroidPointCartesian(x0, y0, z0);
-			}
-
-			function centroidLineEnd() {
-			  centroidStream.point = centroidPoint;
-			}
-
-			// See J. E. Brock, The Inertia Tensor for a Spherical Triangle,
-			// J. Applied Mechanics 42, 239 (1975).
-			function centroidRingStart() {
-			  centroidStream.point = centroidRingPointFirst;
-			}
-
-			function centroidRingEnd() {
-			  centroidRingPoint(lambda00$2, phi00$2);
-			  centroidStream.point = centroidPoint;
-			}
-
-			function centroidRingPointFirst(lambda, phi) {
-			  lambda00$2 = lambda, phi00$2 = phi;
-			  lambda *= radians, phi *= radians;
-			  centroidStream.point = centroidRingPoint;
-			  var cosPhi = cos$1(phi);
-			  x0 = cosPhi * cos$1(lambda);
-			  y0 = cosPhi * sin$1(lambda);
-			  z0 = sin$1(phi);
-			  centroidPointCartesian(x0, y0, z0);
-			}
-
-			function centroidRingPoint(lambda, phi) {
-			  lambda *= radians, phi *= radians;
-			  var cosPhi = cos$1(phi),
-				  x = cosPhi * cos$1(lambda),
-				  y = cosPhi * sin$1(lambda),
-				  z = sin$1(phi),
-				  cx = y0 * z - z0 * y,
-				  cy = z0 * x - x0 * z,
-				  cz = x0 * y - y0 * x,
-				  m = sqrt$1(cx * cx + cy * cy + cz * cz),
-				  u = x0 * x + y0 * y + z0 * z,
-				  v = m && -acos(u) / m, // area weight
-				  w = atan2(m, u); // line weight
-			  X2 += v * cx;
-			  Y2 += v * cy;
-			  Z2 += v * cz;
-			  W1 += w;
-			  X1 += w * (x0 + (x0 = x));
-			  Y1 += w * (y0 + (y0 = y));
-			  Z1 += w * (z0 + (z0 = z));
-			  centroidPointCartesian(x0, y0, z0);
-			}
-
-			var centroid$1 = function(object) {
-			  W0 = W1 =
-			  X0 = Y0 = Z0 =
-			  X1 = Y1 = Z1 =
-			  X2 = Y2 = Z2 = 0;
-			  geoStream(object, centroidStream);
-
-			  var x = X2,
-				  y = Y2,
-				  z = Z2,
-				  m = x * x + y * y + z * z;
-
-			  // If the area-weighted ccentroid is undefined, fall back to length-weighted ccentroid.
-			  if (m < epsilon2$2) {
-				x = X1, y = Y1, z = Z1;
-				// If the feature has zero length, fall back to arithmetic mean of point vectors.
-				if (W1 < epsilon$4) x = X0, y = Y0, z = Z0;
-				m = x * x + y * y + z * z;
-				// If the feature still has an undefined ccentroid, then return.
-				if (m < epsilon2$2) return [NaN, NaN];
-			  }
-
-			  return [atan2(y, x) * degrees$1, asin$1(z / sqrt$1(m)) * degrees$1];
-			};
-
-			var constant$13 = function(x) {
-			  return function() {
-				return x;
-			  };
-			};
-
-			var compose = function(a, b) {
-
-			  function compose(x, y) {
-				return x = a(x, y), b(x[0], x[1]);
-			  }
-
-			  if (a.invert && b.invert) compose.invert = function(x, y) {
-				return x = b.invert(x, y), x && a.invert(x[0], x[1]);
-			  };
-
-			  return compose;
-			};
-
-			function rotationIdentity(lambda, phi) {
-			  return [lambda > pi$4 ? lambda - tau$4 : lambda < -pi$4 ? lambda + tau$4 : lambda, phi];
-			}
-
-			rotationIdentity.invert = rotationIdentity;
-
-			function rotateRadians(deltaLambda, deltaPhi, deltaGamma) {
-			  return (deltaLambda %= tau$4) ? (deltaPhi || deltaGamma ? compose(rotationLambda(deltaLambda), rotationPhiGamma(deltaPhi, deltaGamma))
-				: rotationLambda(deltaLambda))
-				: (deltaPhi || deltaGamma ? rotationPhiGamma(deltaPhi, deltaGamma)
-				: rotationIdentity);
-			}
-
-			function forwardRotationLambda(deltaLambda) {
-			  return function(lambda, phi) {
-				return lambda += deltaLambda, [lambda > pi$4 ? lambda - tau$4 : lambda < -pi$4 ? lambda + tau$4 : lambda, phi];
-			  };
-			}
-
-			function rotationLambda(deltaLambda) {
-			  var rotation = forwardRotationLambda(deltaLambda);
-			  rotation.invert = forwardRotationLambda(-deltaLambda);
-			  return rotation;
-			}
-
-			function rotationPhiGamma(deltaPhi, deltaGamma) {
-			  var cosDeltaPhi = cos$1(deltaPhi),
-				  sinDeltaPhi = sin$1(deltaPhi),
-				  cosDeltaGamma = cos$1(deltaGamma),
-				  sinDeltaGamma = sin$1(deltaGamma);
-
-			  function rotation(lambda, phi) {
-				var cosPhi = cos$1(phi),
-					x = cos$1(lambda) * cosPhi,
-					y = sin$1(lambda) * cosPhi,
-					z = sin$1(phi),
-					k = z * cosDeltaPhi + x * sinDeltaPhi;
-				return [
-				  atan2(y * cosDeltaGamma - k * sinDeltaGamma, x * cosDeltaPhi - z * sinDeltaPhi),
-				  asin$1(k * cosDeltaGamma + y * sinDeltaGamma)
-				];
-			  }
-
-			  rotation.invert = function(lambda, phi) {
-				var cosPhi = cos$1(phi),
-					x = cos$1(lambda) * cosPhi,
-					y = sin$1(lambda) * cosPhi,
-					z = sin$1(phi),
-					k = z * cosDeltaGamma - y * sinDeltaGamma;
-				return [
-				  atan2(y * cosDeltaGamma + z * sinDeltaGamma, x * cosDeltaPhi + k * sinDeltaPhi),
-				  asin$1(k * cosDeltaPhi - x * sinDeltaPhi)
-				];
-			  };
-
-			  return rotation;
-			}
-
-			var rotation = function(rotate) {
-			  rotate = rotateRadians(rotate[0] * radians, rotate[1] * radians, rotate.length > 2 ? rotate[2] * radians : 0);
-
-			  function forward(coordinates) {
-				coordinates = rotate(coordinates[0] * radians, coordinates[1] * radians);
-				return coordinates[0] *= degrees$1, coordinates[1] *= degrees$1, coordinates;
-			  }
-
-			  forward.invert = function(coordinates) {
-				coordinates = rotate.invert(coordinates[0] * radians, coordinates[1] * radians);
-				return coordinates[0] *= degrees$1, coordinates[1] *= degrees$1, coordinates;
-			  };
-
-			  return forward;
-			};
-
-			// Generates a circle centered at [0°, 0°], with a given radius and precision.
-			function circleStream(stream, radius, delta, direction, t0, t1) {
-			  if (!delta) return;
-			  var cosRadius = cos$1(radius),
-				  sinRadius = sin$1(radius),
-				  step = direction * delta;
-			  if (t0 == null) {
-				t0 = radius + direction * tau$4;
-				t1 = radius - step / 2;
-			  } else {
-				t0 = circleRadius(cosRadius, t0);
-				t1 = circleRadius(cosRadius, t1);
-				if (direction > 0 ? t0 < t1 : t0 > t1) t0 += direction * tau$4;
-			  }
-			  for (var point, t = t0; direction > 0 ? t > t1 : t < t1; t -= step) {
-				point = spherical([cosRadius, -sinRadius * cos$1(t), -sinRadius * sin$1(t)]);
-				stream.point(point[0], point[1]);
-			  }
-			}
-
-			// Returns the signed angle of a cartesian point relative to [cosRadius, 0, 0].
-			function circleRadius(cosRadius, point) {
-			  point = cartesian(point), point[0] -= cosRadius;
-			  cartesianNormalizeInPlace(point);
-			  var radius = acos(-point[1]);
-			  return ((-point[2] < 0 ? -radius : radius) + tau$4 - epsilon$4) % tau$4;
-			}
-
-			var circle$1 = function() {
-			  var center = constant$13([0, 0]),
-				  radius = constant$13(90),
-				  precision = constant$13(6),
-				  ring,
-				  rotate,
-				  stream = {point: point};
-
-			  function point(x, y) {
-				ring.push(x = rotate(x, y));
-				x[0] *= degrees$1, x[1] *= degrees$1;
-			  }
-
-			  function circle() {
-				var c = center.apply(this, arguments),
-					r = radius.apply(this, arguments) * radians,
-					p = precision.apply(this, arguments) * radians;
-				ring = [];
-				rotate = rotateRadians(-c[0] * radians, -c[1] * radians, 0).invert;
-				circleStream(stream, r, p, 1);
-				c = {type: "Polygon", coordinates: [ring]};
-				ring = rotate = null;
-				return c;
-			  }
-
-			  circle.center = function(_) {
-				return arguments.length ? (center = typeof _ === "function" ? _ : constant$13([+_[0], +_[1]]), circle) : center;
-			  };
-
-			  circle.radius = function(_) {
-				return arguments.length ? (radius = typeof _ === "function" ? _ : constant$13(+_), circle) : radius;
-			  };
-
-			  circle.precision = function(_) {
-				return arguments.length ? (precision = typeof _ === "function" ? _ : constant$13(+_), circle) : precision;
-			  };
-
-			  return circle;
-			};
-
-			var clipBuffer = function() {
-			  var lines = [],
-				  line;
-			  return {
-				point: function(x, y) {
-				  line.push([x, y]);
-				},
-				lineStart: function() {
-				  lines.push(line = []);
-				},
-				lineEnd: noop$2,
-				rejoin: function() {
-				  if (lines.length > 1) lines.push(lines.pop().concat(lines.shift()));
-				},
-				result: function() {
-				  var result = lines;
-				  lines = [];
-				  line = null;
-				  return result;
-				}
-			  };
-			};
-
-			var clipLine = function(a, b, x0, y0, x1, y1) {
-			  var ax = a[0],
-				  ay = a[1],
-				  bx = b[0],
-				  by = b[1],
-				  t0 = 0,
-				  t1 = 1,
-				  dx = bx - ax,
-				  dy = by - ay,
-				  r;
-
-			  r = x0 - ax;
-			  if (!dx && r > 0) return;
-			  r /= dx;
-			  if (dx < 0) {
-				if (r < t0) return;
-				if (r < t1) t1 = r;
-			  } else if (dx > 0) {
-				if (r > t1) return;
-				if (r > t0) t0 = r;
-			  }
-
-			  r = x1 - ax;
-			  if (!dx && r < 0) return;
-			  r /= dx;
-			  if (dx < 0) {
-				if (r > t1) return;
-				if (r > t0) t0 = r;
-			  } else if (dx > 0) {
-				if (r < t0) return;
-				if (r < t1) t1 = r;
-			  }
-
-			  r = y0 - ay;
-			  if (!dy && r > 0) return;
-			  r /= dy;
-			  if (dy < 0) {
-				if (r < t0) return;
-				if (r < t1) t1 = r;
-			  } else if (dy > 0) {
-				if (r > t1) return;
-				if (r > t0) t0 = r;
-			  }
-
-			  r = y1 - ay;
-			  if (!dy && r < 0) return;
-			  r /= dy;
-			  if (dy < 0) {
-				if (r > t1) return;
-				if (r > t0) t0 = r;
-			  } else if (dy > 0) {
-				if (r < t0) return;
-				if (r < t1) t1 = r;
-			  }
-
-			  if (t0 > 0) a[0] = ax + t0 * dx, a[1] = ay + t0 * dy;
-			  if (t1 < 1) b[0] = ax + t1 * dx, b[1] = ay + t1 * dy;
-			  return true;
-			};
-
-			var pointEqual = function(a, b) {
-			  return abs(a[0] - b[0]) < epsilon$4 && abs(a[1] - b[1]) < epsilon$4;
-			};
-
-			function Intersection(point, points, other, entry) {
-			  this.x = point;
-			  this.z = points;
-			  this.o = other; // another intersection
-			  this.e = entry; // is an entry?
-			  this.v = false; // visited
-			  this.n = this.p = null; // next & previous
-			}
-
-			// A generalized polygon clipping algorithm: given a polygon that has been cut
-			// into its visible line segments, and rejoins the segments by interpolating
-			// along the clip edge.
-			var clipPolygon = function(segments, compareIntersection, startInside, interpolate, stream) {
-			  var subject = [],
-				  clip = [],
-				  i,
-				  n;
-
-			  segments.forEach(function(segment) {
-				if ((n = segment.length - 1) <= 0) return;
-				var n, p0 = segment[0], p1 = segment[n], x;
-
-				// If the first and last points of a segment are coincident, then treat as a
-				// closed ring. TODO if all rings are closed, then the winding order of the
-				// exterior ring should be checked.
-				if (pointEqual(p0, p1)) {
-				  stream.lineStart();
-				  for (i = 0; i < n; ++i) stream.point((p0 = segment[i])[0], p0[1]);
-				  stream.lineEnd();
-				  return;
-				}
-
-				subject.push(x = new Intersection(p0, segment, null, true));
-				clip.push(x.o = new Intersection(p0, null, x, false));
-				subject.push(x = new Intersection(p1, segment, null, false));
-				clip.push(x.o = new Intersection(p1, null, x, true));
-			  });
-
-			  if (!subject.length) return;
-
-			  clip.sort(compareIntersection);
-			  link$1(subject);
-			  link$1(clip);
-
-			  for (i = 0, n = clip.length; i < n; ++i) {
-				clip[i].e = startInside = !startInside;
-			  }
-
-			  var start = subject[0],
-				  points,
-				  point;
-
-			  while (1) {
-				// Find first unvisited intersection.
-				var current = start,
-					isSubject = true;
-				while (current.v) if ((current = current.n) === start) return;
-				points = current.z;
-				stream.lineStart();
-				do {
-				  current.v = current.o.v = true;
-				  if (current.e) {
-					if (isSubject) {
-					  for (i = 0, n = points.length; i < n; ++i) stream.point((point = points[i])[0], point[1]);
-					} else {
-					  interpolate(current.x, current.n.x, 1, stream);
-					}
-					current = current.n;
-				  } else {
-					if (isSubject) {
-					  points = current.p.z;
-					  for (i = points.length - 1; i >= 0; --i) stream.point((point = points[i])[0], point[1]);
-					} else {
-					  interpolate(current.x, current.p.x, -1, stream);
-					}
-					current = current.p;
-				  }
-				  current = current.o;
-				  points = current.z;
-				  isSubject = !isSubject;
-				} while (!current.v);
-				stream.lineEnd();
-			  }
-			};
-
-			function link$1(array) {
-			  if (!(n = array.length)) return;
-			  var n,
-				  i = 0,
-				  a = array[0],
-				  b;
-			  while (++i < n) {
-				a.n = b = array[i];
-				b.p = a;
-				a = b;
-			  }
-			  a.n = b = array[0];
-			  b.p = a;
-			}
-
-			var clipMax = 1e9;
-			var clipMin = -clipMax;
-
-			// TODO Use d3-polygon’s polygonContains here for the ring check?
-			// TODO Eliminate duplicate buffering in clipBuffer and polygon.push?
-
-			function clipExtent(x0, y0, x1, y1) {
-
-			  function visible(x, y) {
-				return x0 <= x && x <= x1 && y0 <= y && y <= y1;
-			  }
-
-			  function interpolate(from, to, direction, stream) {
-				var a = 0, a1 = 0;
-				if (from == null
-					|| (a = corner(from, direction)) !== (a1 = corner(to, direction))
-					|| comparePoint(from, to) < 0 ^ direction > 0) {
-				  do stream.point(a === 0 || a === 3 ? x0 : x1, a > 1 ? y1 : y0);
-				  while ((a = (a + direction + 4) % 4) !== a1);
-				} else {
-				  stream.point(to[0], to[1]);
-				}
-			  }
-
-			  function corner(p, direction) {
-				return abs(p[0] - x0) < epsilon$4 ? direction > 0 ? 0 : 3
-					: abs(p[0] - x1) < epsilon$4 ? direction > 0 ? 2 : 1
-					: abs(p[1] - y0) < epsilon$4 ? direction > 0 ? 1 : 0
-					: direction > 0 ? 3 : 2; // abs(p[1] - y1) < epsilon
-			  }
-
-			  function compareIntersection(a, b) {
-				return comparePoint(a.x, b.x);
-			  }
-
-			  function comparePoint(a, b) {
-				var ca = corner(a, 1),
-					cb = corner(b, 1);
-				return ca !== cb ? ca - cb
-					: ca === 0 ? b[1] - a[1]
-					: ca === 1 ? a[0] - b[0]
-					: ca === 2 ? a[1] - b[1]
-					: b[0] - a[0];
-			  }
-
-			  return function(stream) {
-				var activeStream = stream,
-					bufferStream = clipBuffer(),
-					segments,
-					polygon,
-					ring,
-					x__, y__, v__, // first point
-					x_, y_, v_, // previous point
-					first,
-					clean;
-
-				var clipStream = {
-				  point: point,
-				  lineStart: lineStart,
-				  lineEnd: lineEnd,
-				  polygonStart: polygonStart,
-				  polygonEnd: polygonEnd
-				};
-
-				function point(x, y) {
-				  if (visible(x, y)) activeStream.point(x, y);
-				}
-
-				function polygonInside() {
-				  var winding = 0;
-
-				  for (var i = 0, n = polygon.length; i < n; ++i) {
-					for (var ring = polygon[i], j = 1, m = ring.length, point = ring[0], a0, a1, b0 = point[0], b1 = point[1]; j < m; ++j) {
-					  a0 = b0, a1 = b1, point = ring[j], b0 = point[0], b1 = point[1];
-					  if (a1 <= y1) { if (b1 > y1 && (b0 - a0) * (y1 - a1) > (b1 - a1) * (x0 - a0)) ++winding; }
-					  else { if (b1 <= y1 && (b0 - a0) * (y1 - a1) < (b1 - a1) * (x0 - a0)) --winding; }
-					}
-				  }
-
-				  return winding;
-				}
-
-				// Buffer geometry within a polygon and then clip it en masse.
-				function polygonStart() {
-				  activeStream = bufferStream, segments = [], polygon = [], clean = true;
-				}
-
-				function polygonEnd() {
-				  var startInside = polygonInside(),
-					  cleanInside = clean && startInside,
-					  visible = (segments = merge(segments)).length;
-				  if (cleanInside || visible) {
-					stream.polygonStart();
-					if (cleanInside) {
-					  stream.lineStart();
-					  interpolate(null, null, 1, stream);
-					  stream.lineEnd();
-					}
-					if (visible) {
-					  clipPolygon(segments, compareIntersection, startInside, interpolate, stream);
-					}
-					stream.polygonEnd();
-				  }
-				  activeStream = stream, segments = polygon = ring = null;
-				}
-
-				function lineStart() {
-				  clipStream.point = linePoint;
-				  if (polygon) polygon.push(ring = []);
-				  first = true;
-				  v_ = false;
-				  x_ = y_ = NaN;
-				}
-
-				// TODO rather than special-case polygons, simply handle them separately.
-				// Ideally, coincident intersection points should be jittered to avoid
-				// clipping issues.
-				function lineEnd() {
-				  if (segments) {
-					linePoint(x__, y__);
-					if (v__ && v_) bufferStream.rejoin();
-					segments.push(bufferStream.result());
-				  }
-				  clipStream.point = point;
-				  if (v_) activeStream.lineEnd();
-				}
-
-				function linePoint(x, y) {
-				  var v = visible(x, y);
-				  if (polygon) ring.push([x, y]);
-				  if (first) {
-					x__ = x, y__ = y, v__ = v;
-					first = false;
-					if (v) {
-					  activeStream.lineStart();
-					  activeStream.point(x, y);
-					}
-				  } else {
-					if (v && v_) activeStream.point(x, y);
-					else {
-					  var a = [x_ = Math.max(clipMin, Math.min(clipMax, x_)), y_ = Math.max(clipMin, Math.min(clipMax, y_))],
-						  b = [x = Math.max(clipMin, Math.min(clipMax, x)), y = Math.max(clipMin, Math.min(clipMax, y))];
-					  if (clipLine(a, b, x0, y0, x1, y1)) {
-						if (!v_) {
-						  activeStream.lineStart();
-						  activeStream.point(a[0], a[1]);
-						}
-						activeStream.point(b[0], b[1]);
-						if (!v) activeStream.lineEnd();
-						clean = false;
-					  } else if (v) {
-						activeStream.lineStart();
-						activeStream.point(x, y);
-						clean = false;
-					  }
-					}
-				  }
-				  x_ = x, y_ = y, v_ = v;
-				}
-
-				return clipStream;
-			  };
-			}
-
-			var extent$1 = function() {
-			  var x0 = 0,
-				  y0 = 0,
-				  x1 = 960,
-				  y1 = 500,
-				  cache,
-				  cacheStream,
-				  clip;
-
-			  return clip = {
-				stream: function(stream) {
-				  return cache && cacheStream === stream ? cache : cache = clipExtent(x0, y0, x1, y1)(cacheStream = stream);
-				},
-				extent: function(_) {
-				  return arguments.length ? (x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1], cache = cacheStream = null, clip) : [[x0, y0], [x1, y1]];
-				}
-			  };
-			};
-
-			var lengthSum = adder();
-			var lambda0$2;
-			var sinPhi0$1;
-			var cosPhi0$1;
-
-			var lengthStream = {
-			  sphere: noop$2,
-			  point: noop$2,
-			  lineStart: lengthLineStart,
-			  lineEnd: noop$2,
-			  polygonStart: noop$2,
-			  polygonEnd: noop$2
-			};
-
-			function lengthLineStart() {
-			  lengthStream.point = lengthPointFirst;
-			  lengthStream.lineEnd = lengthLineEnd;
-			}
-
-			function lengthLineEnd() {
-			  lengthStream.point = lengthStream.lineEnd = noop$2;
-			}
-
-			function lengthPointFirst(lambda, phi) {
-			  lambda *= radians, phi *= radians;
-			  lambda0$2 = lambda, sinPhi0$1 = sin$1(phi), cosPhi0$1 = cos$1(phi);
-			  lengthStream.point = lengthPoint;
-			}
-
-			function lengthPoint(lambda, phi) {
-			  lambda *= radians, phi *= radians;
-			  var sinPhi = sin$1(phi),
-				  cosPhi = cos$1(phi),
-				  delta = abs(lambda - lambda0$2),
-				  cosDelta = cos$1(delta),
-				  sinDelta = sin$1(delta),
-				  x = cosPhi * sinDelta,
-				  y = cosPhi0$1 * sinPhi - sinPhi0$1 * cosPhi * cosDelta,
-				  z = sinPhi0$1 * sinPhi + cosPhi0$1 * cosPhi * cosDelta;
-			  lengthSum.add(atan2(sqrt$1(x * x + y * y), z));
-			  lambda0$2 = lambda, sinPhi0$1 = sinPhi, cosPhi0$1 = cosPhi;
-			}
-
-			var length$2 = function(object) {
-			  lengthSum.reset();
-			  geoStream(object, lengthStream);
-			  return +lengthSum;
-			};
-
-			var coordinates = [null, null];
-			var object$1 = {type: "LineString", coordinates: coordinates};
-
-			var distance = function(a, b) {
-			  coordinates[0] = a;
-			  coordinates[1] = b;
-			  return length$2(object$1);
-			};
-
-			function graticuleX(y0, y1, dy) {
-			  var y = range(y0, y1 - epsilon$4, dy).concat(y1);
-			  return function(x) { return y.map(function(y) { return [x, y]; }); };
-			}
-
-			function graticuleY(x0, x1, dx) {
-			  var x = range(x0, x1 - epsilon$4, dx).concat(x1);
-			  return function(y) { return x.map(function(x) { return [x, y]; }); };
-			}
-
-			function graticule() {
-			  var x1, x0, X1, X0,
-				  y1, y0, Y1, Y0,
-				  dx = 10, dy = dx, DX = 90, DY = 360,
-				  x, y, X, Y,
-				  precision = 2.5;
-
-			  function graticule() {
-				return {type: "MultiLineString", coordinates: lines()};
-			  }
-
-			  function lines() {
-				return range(ceil(X0 / DX) * DX, X1, DX).map(X)
-					.concat(range(ceil(Y0 / DY) * DY, Y1, DY).map(Y))
-					.concat(range(ceil(x0 / dx) * dx, x1, dx).filter(function(x) { return abs(x % DX) > epsilon$4; }).map(x))
-					.concat(range(ceil(y0 / dy) * dy, y1, dy).filter(function(y) { return abs(y % DY) > epsilon$4; }).map(y));
-			  }
-
-			  graticule.lines = function() {
-				return lines().map(function(coordinates) { return {type: "LineString", coordinates: coordinates}; });
-			  };
-
-			  graticule.outline = function() {
-				return {
-				  type: "Polygon",
-				  coordinates: [
-					X(X0).concat(
-					Y(Y1).slice(1),
-					X(X1).reverse().slice(1),
-					Y(Y0).reverse().slice(1))
-				  ]
-				};
-			  };
-
-			  graticule.extent = function(_) {
-				if (!arguments.length) return graticule.extentMinor();
-				return graticule.extentMajor(_).extentMinor(_);
-			  };
-
-			  graticule.extentMajor = function(_) {
-				if (!arguments.length) return [[X0, Y0], [X1, Y1]];
-				X0 = +_[0][0], X1 = +_[1][0];
-				Y0 = +_[0][1], Y1 = +_[1][1];
-				if (X0 > X1) _ = X0, X0 = X1, X1 = _;
-				if (Y0 > Y1) _ = Y0, Y0 = Y1, Y1 = _;
-				return graticule.precision(precision);
-			  };
-
-			  graticule.extentMinor = function(_) {
-				if (!arguments.length) return [[x0, y0], [x1, y1]];
-				x0 = +_[0][0], x1 = +_[1][0];
-				y0 = +_[0][1], y1 = +_[1][1];
-				if (x0 > x1) _ = x0, x0 = x1, x1 = _;
-				if (y0 > y1) _ = y0, y0 = y1, y1 = _;
-				return graticule.precision(precision);
-			  };
-
-			  graticule.step = function(_) {
-				if (!arguments.length) return graticule.stepMinor();
-				return graticule.stepMajor(_).stepMinor(_);
-			  };
-
-			  graticule.stepMajor = function(_) {
-				if (!arguments.length) return [DX, DY];
-				DX = +_[0], DY = +_[1];
-				return graticule;
-			  };
-
-			  graticule.stepMinor = function(_) {
-				if (!arguments.length) return [dx, dy];
-				dx = +_[0], dy = +_[1];
-				return graticule;
-			  };
-
-			  graticule.precision = function(_) {
-				if (!arguments.length) return precision;
-				precision = +_;
-				x = graticuleX(y0, y1, 90);
-				y = graticuleY(x0, x1, precision);
-				X = graticuleX(Y0, Y1, 90);
-				Y = graticuleY(X0, X1, precision);
-				return graticule;
-			  };
-
-			  return graticule
-				  .extentMajor([[-180, -90 + epsilon$4], [180, 90 - epsilon$4]])
-				  .extentMinor([[-180, -80 - epsilon$4], [180, 80 + epsilon$4]]);
-			}
-
-			function graticule10() {
-			  return graticule()();
-			}
-
-			var interpolate$2 = function(a, b) {
-			  var x0 = a[0] * radians,
-				  y0 = a[1] * radians,
-				  x1 = b[0] * radians,
-				  y1 = b[1] * radians,
-				  cy0 = cos$1(y0),
-				  sy0 = sin$1(y0),
-				  cy1 = cos$1(y1),
-				  sy1 = sin$1(y1),
-				  kx0 = cy0 * cos$1(x0),
-				  ky0 = cy0 * sin$1(x0),
-				  kx1 = cy1 * cos$1(x1),
-				  ky1 = cy1 * sin$1(x1),
-				  d = 2 * asin$1(sqrt$1(haversin(y1 - y0) + cy0 * cy1 * haversin(x1 - x0))),
-				  k = sin$1(d);
-
-			  var interpolate = d ? function(t) {
-				var B = sin$1(t *= d) / k,
-					A = sin$1(d - t) / k,
-					x = A * kx0 + B * kx1,
-					y = A * ky0 + B * ky1,
-					z = A * sy0 + B * sy1;
-				return [
-				  atan2(y, x) * degrees$1,
-				  atan2(z, sqrt$1(x * x + y * y)) * degrees$1
-				];
-			  } : function() {
-				return [x0 * degrees$1, y0 * degrees$1];
-			  };
-
-			  interpolate.distance = d;
-
-			  return interpolate;
-			};
-
-			var identity$7 = function(x) {
-			  return x;
-			};
-
-			var areaSum$1 = adder();
-			var areaRingSum$1 = adder();
-			var x00;
-			var y00;
-			var x0$1;
-			var y0$1;
-
-			var areaStream$1 = {
-			  point: noop$2,
-			  lineStart: noop$2,
-			  lineEnd: noop$2,
-			  polygonStart: function() {
-				areaStream$1.lineStart = areaRingStart$1;
-				areaStream$1.lineEnd = areaRingEnd$1;
-			  },
-			  polygonEnd: function() {
-				areaStream$1.lineStart = areaStream$1.lineEnd = areaStream$1.point = noop$2;
-				areaSum$1.add(abs(areaRingSum$1));
-				areaRingSum$1.reset();
-			  },
-			  result: function() {
-				var area = areaSum$1 / 2;
-				areaSum$1.reset();
-				return area;
-			  }
-			};
-
-			function areaRingStart$1() {
-			  areaStream$1.point = areaPointFirst$1;
-			}
-
-			function areaPointFirst$1(x, y) {
-			  areaStream$1.point = areaPoint$1;
-			  x00 = x0$1 = x, y00 = y0$1 = y;
-			}
-
-			function areaPoint$1(x, y) {
-			  areaRingSum$1.add(y0$1 * x - x0$1 * y);
-			  x0$1 = x, y0$1 = y;
-			}
-
-			function areaRingEnd$1() {
-			  areaPoint$1(x00, y00);
-			}
-
-			var x0$2 = Infinity;
-			var y0$2 = x0$2;
-			var x1 = -x0$2;
-			var y1 = x1;
-
-			var boundsStream$1 = {
-			  point: boundsPoint$1,
-			  lineStart: noop$2,
-			  lineEnd: noop$2,
-			  polygonStart: noop$2,
-			  polygonEnd: noop$2,
-			  result: function() {
-				var bounds = [[x0$2, y0$2], [x1, y1]];
-				x1 = y1 = -(y0$2 = x0$2 = Infinity);
-				return bounds;
-			  }
-			};
-
-			function boundsPoint$1(x, y) {
-			  if (x < x0$2) x0$2 = x;
-			  if (x > x1) x1 = x;
-			  if (y < y0$2) y0$2 = y;
-			  if (y > y1) y1 = y;
-			}
-
-			// TODO Enforce positive area for exterior, negative area for interior?
-
-			var X0$1 = 0;
-			var Y0$1 = 0;
-			var Z0$1 = 0;
-			var X1$1 = 0;
-			var Y1$1 = 0;
-			var Z1$1 = 0;
-			var X2$1 = 0;
-			var Y2$1 = 0;
-			var Z2$1 = 0;
-			var x00$1;
-			var y00$1;
-			var x0$3;
-			var y0$3;
-
-			var centroidStream$1 = {
-			  point: centroidPoint$1,
-			  lineStart: centroidLineStart$1,
-			  lineEnd: centroidLineEnd$1,
-			  polygonStart: function() {
-				centroidStream$1.lineStart = centroidRingStart$1;
-				centroidStream$1.lineEnd = centroidRingEnd$1;
-			  },
-			  polygonEnd: function() {
-				centroidStream$1.point = centroidPoint$1;
-				centroidStream$1.lineStart = centroidLineStart$1;
-				centroidStream$1.lineEnd = centroidLineEnd$1;
-			  },
-			  result: function() {
-				var centroid = Z2$1 ? [X2$1 / Z2$1, Y2$1 / Z2$1]
-					: Z1$1 ? [X1$1 / Z1$1, Y1$1 / Z1$1]
-					: Z0$1 ? [X0$1 / Z0$1, Y0$1 / Z0$1]
-					: [NaN, NaN];
-				X0$1 = Y0$1 = Z0$1 =
-				X1$1 = Y1$1 = Z1$1 =
-				X2$1 = Y2$1 = Z2$1 = 0;
-				return centroid;
-			  }
-			};
-
-			function centroidPoint$1(x, y) {
-			  X0$1 += x;
-			  Y0$1 += y;
-			  ++Z0$1;
-			}
-
-			function centroidLineStart$1() {
-			  centroidStream$1.point = centroidPointFirstLine;
-			}
-
-			function centroidPointFirstLine(x, y) {
-			  centroidStream$1.point = centroidPointLine;
-			  centroidPoint$1(x0$3 = x, y0$3 = y);
-			}
-
-			function centroidPointLine(x, y) {
-			  var dx = x - x0$3, dy = y - y0$3, z = sqrt$1(dx * dx + dy * dy);
-			  X1$1 += z * (x0$3 + x) / 2;
-			  Y1$1 += z * (y0$3 + y) / 2;
-			  Z1$1 += z;
-			  centroidPoint$1(x0$3 = x, y0$3 = y);
-			}
-
-			function centroidLineEnd$1() {
-			  centroidStream$1.point = centroidPoint$1;
-			}
-
-			function centroidRingStart$1() {
-			  centroidStream$1.point = centroidPointFirstRing;
-			}
-
-			function centroidRingEnd$1() {
-			  centroidPointRing(x00$1, y00$1);
-			}
-
-			function centroidPointFirstRing(x, y) {
-			  centroidStream$1.point = centroidPointRing;
-			  centroidPoint$1(x00$1 = x0$3 = x, y00$1 = y0$3 = y);
-			}
-
-			function centroidPointRing(x, y) {
-			  var dx = x - x0$3,
-				  dy = y - y0$3,
-				  z = sqrt$1(dx * dx + dy * dy);
-
-			  X1$1 += z * (x0$3 + x) / 2;
-			  Y1$1 += z * (y0$3 + y) / 2;
-			  Z1$1 += z;
-
-			  z = y0$3 * x - x0$3 * y;
-			  X2$1 += z * (x0$3 + x);
-			  Y2$1 += z * (y0$3 + y);
-			  Z2$1 += z * 3;
-			  centroidPoint$1(x0$3 = x, y0$3 = y);
-			}
-
-			function PathContext(context) {
-			  this._context = context;
-			}
-
-			PathContext.prototype = {
-			  _radius: 4.5,
-			  pointRadius: function(_) {
-				return this._radius = _, this;
-			  },
-			  polygonStart: function() {
-				this._line = 0;
-			  },
-			  polygonEnd: function() {
-				this._line = NaN;
-			  },
-			  lineStart: function() {
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				if (this._line === 0) this._context.closePath();
-				this._point = NaN;
-			  },
-			  point: function(x, y) {
-				switch (this._point) {
-				  case 0: {
-					this._context.moveTo(x, y);
-					this._point = 1;
-					break;
-				  }
-				  case 1: {
-					this._context.lineTo(x, y);
-					break;
-				  }
-				  default: {
-					this._context.moveTo(x + this._radius, y);
-					this._context.arc(x, y, this._radius, 0, tau$4);
-					break;
-				  }
-				}
-			  },
-			  result: noop$2
-			};
-
-			function PathString() {
-			  this._string = [];
-			}
-
-			PathString.prototype = {
-			  _circle: circle$2(4.5),
-			  pointRadius: function(_) {
-				return this._circle = circle$2(_), this;
-			  },
-			  polygonStart: function() {
-				this._line = 0;
-			  },
-			  polygonEnd: function() {
-				this._line = NaN;
-			  },
-			  lineStart: function() {
-				this._point = 0;
-			  },
-			  lineEnd: function() {
-				if (this._line === 0) this._string.push("Z");
-				this._point = NaN;
-			  },
-			  point: function(x, y) {
-				switch (this._point) {
-				  case 0: {
-					this._string.push("M", x, ",", y);
-					this._point = 1;
-					break;
-				  }
-				  case 1: {
-					this._string.push("L", x, ",", y);
-					break;
-				  }
-				  default: {
-					this._string.push("M", x, ",", y, this._circle);
-					break;
-				  }
-				}
-			  },
-			  result: function() {
-				if (this._string.length) {
-				  var result = this._string.join("");
-				  this._string = [];
-				  return result;
-				}
-			  }
-			};
-
-			function circle$2(radius) {
-			  return "m0," + radius
-				  + "a" + radius + "," + radius + " 0 1,1 0," + -2 * radius
-				  + "a" + radius + "," + radius + " 0 1,1 0," + 2 * radius
-				  + "z";
-			}
-
-			var index$3 = function(projection, context) {
-			  var pointRadius = 4.5,
-				  projectionStream,
-				  contextStream;
-
-			  function path(object) {
-				if (object) {
-				  if (typeof pointRadius === "function") contextStream.pointRadius(+pointRadius.apply(this, arguments));
-				  geoStream(object, projectionStream(contextStream));
-				}
-				return contextStream.result();
-			  }
-
-			  path.area = function(object) {
-				geoStream(object, projectionStream(areaStream$1));
-				return areaStream$1.result();
-			  };
-
-			  path.bounds = function(object) {
-				geoStream(object, projectionStream(boundsStream$1));
-				return boundsStream$1.result();
-			  };
-
-			  path.centroid = function(object) {
-				geoStream(object, projectionStream(centroidStream$1));
-				return centroidStream$1.result();
-			  };
-
-			  path.projection = function(_) {
-				return arguments.length ? (projectionStream = (projection = _) == null ? identity$7 : _.stream, path) : projection;
-			  };
-
-			  path.context = function(_) {
-				if (!arguments.length) return context;
-				contextStream = (context = _) == null ? new PathString : new PathContext(_);
-				if (typeof pointRadius !== "function") contextStream.pointRadius(pointRadius);
-				return path;
-			  };
-
-			  path.pointRadius = function(_) {
-				if (!arguments.length) return pointRadius;
-				pointRadius = typeof _ === "function" ? _ : (contextStream.pointRadius(+_), +_);
-				return path;
-			  };
-
-			  return path.projection(projection).context(context);
-			};
-
-			var sum$2 = adder();
-
-			var polygonContains = function(polygon, point) {
-			  var lambda = point[0],
-				  phi = point[1],
-				  normal = [sin$1(lambda), -cos$1(lambda), 0],
-				  angle = 0,
-				  winding = 0;
-
-			  sum$2.reset();
-
-			  for (var i = 0, n = polygon.length; i < n; ++i) {
-				if (!(m = (ring = polygon[i]).length)) continue;
-				var ring,
-					m,
-					point0 = ring[m - 1],
-					lambda0 = point0[0],
-					phi0 = point0[1] / 2 + quarterPi,
-					sinPhi0 = sin$1(phi0),
-					cosPhi0 = cos$1(phi0);
-
-				for (var j = 0; j < m; ++j, lambda0 = lambda1, sinPhi0 = sinPhi1, cosPhi0 = cosPhi1, point0 = point1) {
-				  var point1 = ring[j],
-					  lambda1 = point1[0],
-					  phi1 = point1[1] / 2 + quarterPi,
-					  sinPhi1 = sin$1(phi1),
-					  cosPhi1 = cos$1(phi1),
-					  delta = lambda1 - lambda0,
-					  sign$$1 = delta >= 0 ? 1 : -1,
-					  absDelta = sign$$1 * delta,
-					  antimeridian = absDelta > pi$4,
-					  k = sinPhi0 * sinPhi1;
-
-				  sum$2.add(atan2(k * sign$$1 * sin$1(absDelta), cosPhi0 * cosPhi1 + k * cos$1(absDelta)));
-				  angle += antimeridian ? delta + sign$$1 * tau$4 : delta;
-
-				  // Are the longitudes either side of the point’s meridian (lambda),
-				  // and are the latitudes smaller than the parallel (phi)?
-				  if (antimeridian ^ lambda0 >= lambda ^ lambda1 >= lambda) {
-					var arc = cartesianCross(cartesian(point0), cartesian(point1));
-					cartesianNormalizeInPlace(arc);
-					var intersection = cartesianCross(normal, arc);
-					cartesianNormalizeInPlace(intersection);
-					var phiArc = (antimeridian ^ delta >= 0 ? -1 : 1) * asin$1(intersection[2]);
-					if (phi > phiArc || phi === phiArc && (arc[0] || arc[1])) {
-					  winding += antimeridian ^ delta >= 0 ? 1 : -1;
-					}
-				  }
-				}
-			  }
-
-			  // First, determine whether the South pole is inside or outside:
-			  //
-			  // It is inside if:
-			  // * the polygon winds around it in a clockwise direction.
-			  // * the polygon does not (cumulatively) wind around it, but has a negative
-			  //   (counter-clockwise) area.
-			  //
-			  // Second, count the (signed) number of times a segment crosses a lambda
-			  // from the point to the South pole.  If it is zero, then the point is the
-			  // same side as the South pole.
-
-			  return (angle < -epsilon$4 || angle < epsilon$4 && sum$2 < -epsilon$4) ^ (winding & 1);
-			};
-
-			var clip = function(pointVisible, clipLine, interpolate, start) {
-			  return function(rotate, sink) {
-				var line = clipLine(sink),
-					rotatedStart = rotate.invert(start[0], start[1]),
-					ringBuffer = clipBuffer(),
-					ringSink = clipLine(ringBuffer),
-					polygonStarted = false,
-					polygon,
-					segments,
-					ring;
-
-				var clip = {
-				  point: point,
-				  lineStart: lineStart,
-				  lineEnd: lineEnd,
-				  polygonStart: function() {
-					clip.point = pointRing;
-					clip.lineStart = ringStart;
-					clip.lineEnd = ringEnd;
-					segments = [];
-					polygon = [];
-				  },
-				  polygonEnd: function() {
-					clip.point = point;
-					clip.lineStart = lineStart;
-					clip.lineEnd = lineEnd;
-					segments = merge(segments);
-					var startInside = polygonContains(polygon, rotatedStart);
-					if (segments.length) {
-					  if (!polygonStarted) sink.polygonStart(), polygonStarted = true;
-					  clipPolygon(segments, compareIntersection, startInside, interpolate, sink);
-					} else if (startInside) {
-					  if (!polygonStarted) sink.polygonStart(), polygonStarted = true;
-					  sink.lineStart();
-					  interpolate(null, null, 1, sink);
-					  sink.lineEnd();
-					}
-					if (polygonStarted) sink.polygonEnd(), polygonStarted = false;
-					segments = polygon = null;
-				  },
-				  sphere: function() {
-					sink.polygonStart();
-					sink.lineStart();
-					interpolate(null, null, 1, sink);
-					sink.lineEnd();
-					sink.polygonEnd();
-				  }
-				};
-
-				function point(lambda, phi) {
-				  var point = rotate(lambda, phi);
-				  if (pointVisible(lambda = point[0], phi = point[1])) sink.point(lambda, phi);
-				}
-
-				function pointLine(lambda, phi) {
-				  var point = rotate(lambda, phi);
-				  line.point(point[0], point[1]);
-				}
-
-				function lineStart() {
-				  clip.point = pointLine;
-				  line.lineStart();
-				}
-
-				function lineEnd() {
-				  clip.point = point;
-				  line.lineEnd();
-				}
-
-				function pointRing(lambda, phi) {
-				  ring.push([lambda, phi]);
-				  var point = rotate(lambda, phi);
-				  ringSink.point(point[0], point[1]);
-				}
-
-				function ringStart() {
-				  ringSink.lineStart();
-				  ring = [];
-				}
-
-				function ringEnd() {
-				  pointRing(ring[0][0], ring[0][1]);
-				  ringSink.lineEnd();
-
-				  var clean = ringSink.clean(),
-					  ringSegments = ringBuffer.result(),
-					  i, n = ringSegments.length, m,
-					  segment,
-					  point;
-
-				  ring.pop();
-				  polygon.push(ring);
-				  ring = null;
-
-				  if (!n) return;
-
-				  // No intersections.
-				  if (clean & 1) {
-					segment = ringSegments[0];
-					if ((m = segment.length - 1) > 0) {
-					  if (!polygonStarted) sink.polygonStart(), polygonStarted = true;
-					  sink.lineStart();
-					  for (i = 0; i < m; ++i) sink.point((point = segment[i])[0], point[1]);
-					  sink.lineEnd();
-					}
-					return;
-				  }
-
-				  // Rejoin connected segments.
-				  // TODO reuse ringBuffer.rejoin()?
-				  if (n > 1 && clean & 2) ringSegments.push(ringSegments.pop().concat(ringSegments.shift()));
-
-				  segments.push(ringSegments.filter(validSegment));
-				}
-
-				return clip;
-			  };
-			};
-
-			function validSegment(segment) {
-			  return segment.length > 1;
-			}
-
-			// Intersections are sorted along the clip edge. For both antimeridian cutting
-			// and circle clipping, the same comparison is used.
-			function compareIntersection(a, b) {
-			  return ((a = a.x)[0] < 0 ? a[1] - halfPi$3 - epsilon$4 : halfPi$3 - a[1])
-				   - ((b = b.x)[0] < 0 ? b[1] - halfPi$3 - epsilon$4 : halfPi$3 - b[1]);
-			}
-
-			var clipAntimeridian = clip(
-			  function() { return true; },
-			  clipAntimeridianLine,
-			  clipAntimeridianInterpolate,
-			  [-pi$4, -halfPi$3]
-			);
-
-			// Takes a line and cuts into visible segments. Return values: 0 - there were
-			// intersections or the line was empty; 1 - no intersections; 2 - there were
-			// intersections, and the first and last segments should be rejoined.
-			function clipAntimeridianLine(stream) {
-			  var lambda0 = NaN,
-				  phi0 = NaN,
-				  sign0 = NaN,
-				  clean; // no intersections
-
-			  return {
-				lineStart: function() {
-				  stream.lineStart();
-				  clean = 1;
-				},
-				point: function(lambda1, phi1) {
-				  var sign1 = lambda1 > 0 ? pi$4 : -pi$4,
-					  delta = abs(lambda1 - lambda0);
-				  if (abs(delta - pi$4) < epsilon$4) { // line crosses a pole
-					stream.point(lambda0, phi0 = (phi0 + phi1) / 2 > 0 ? halfPi$3 : -halfPi$3);
-					stream.point(sign0, phi0);
-					stream.lineEnd();
-					stream.lineStart();
-					stream.point(sign1, phi0);
-					stream.point(lambda1, phi0);
-					clean = 0;
-				  } else if (sign0 !== sign1 && delta >= pi$4) { // line crosses antimeridian
-					if (abs(lambda0 - sign0) < epsilon$4) lambda0 -= sign0 * epsilon$4; // handle degeneracies
-					if (abs(lambda1 - sign1) < epsilon$4) lambda1 -= sign1 * epsilon$4;
-					phi0 = clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1);
-					stream.point(sign0, phi0);
-					stream.lineEnd();
-					stream.lineStart();
-					stream.point(sign1, phi0);
-					clean = 0;
-				  }
-				  stream.point(lambda0 = lambda1, phi0 = phi1);
-				  sign0 = sign1;
-				},
-				lineEnd: function() {
-				  stream.lineEnd();
-				  lambda0 = phi0 = NaN;
-				},
-				clean: function() {
-				  return 2 - clean; // if intersections, rejoin first and last segments
-				}
-			  };
-			}
-
-			function clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1) {
-			  var cosPhi0,
-				  cosPhi1,
-				  sinLambda0Lambda1 = sin$1(lambda0 - lambda1);
-			  return abs(sinLambda0Lambda1) > epsilon$4
-				  ? atan((sin$1(phi0) * (cosPhi1 = cos$1(phi1)) * sin$1(lambda1)
-					  - sin$1(phi1) * (cosPhi0 = cos$1(phi0)) * sin$1(lambda0))
-					  / (cosPhi0 * cosPhi1 * sinLambda0Lambda1))
-				  : (phi0 + phi1) / 2;
-			}
-
-			function clipAntimeridianInterpolate(from, to, direction, stream) {
-			  var phi;
-			  if (from == null) {
-				phi = direction * halfPi$3;
-				stream.point(-pi$4, phi);
-				stream.point(0, phi);
-				stream.point(pi$4, phi);
-				stream.point(pi$4, 0);
-				stream.point(pi$4, -phi);
-				stream.point(0, -phi);
-				stream.point(-pi$4, -phi);
-				stream.point(-pi$4, 0);
-				stream.point(-pi$4, phi);
-			  } else if (abs(from[0] - to[0]) > epsilon$4) {
-				var lambda = from[0] < to[0] ? pi$4 : -pi$4;
-				phi = direction * lambda / 2;
-				stream.point(-lambda, phi);
-				stream.point(0, phi);
-				stream.point(lambda, phi);
-			  } else {
-				stream.point(to[0], to[1]);
-			  }
-			}
-
-			var clipCircle = function(radius, delta) {
-			  var cr = cos$1(radius),
-				  smallRadius = cr > 0,
-				  notHemisphere = abs(cr) > epsilon$4; // TODO optimise for this common case
-
-			  function interpolate(from, to, direction, stream) {
-				circleStream(stream, radius, delta, direction, from, to);
-			  }
-
-			  function visible(lambda, phi) {
-				return cos$1(lambda) * cos$1(phi) > cr;
-			  }
-
-			  // Takes a line and cuts into visible segments. Return values used for polygon
-			  // clipping: 0 - there were intersections or the line was empty; 1 - no
-			  // intersections 2 - there were intersections, and the first and last segments
-			  // should be rejoined.
-			  function clipLine(stream) {
-				var point0, // previous point
-					c0, // code for previous point
-					v0, // visibility of previous point
-					v00, // visibility of first point
-					clean; // no intersections
-				return {
-				  lineStart: function() {
-					v00 = v0 = false;
-					clean = 1;
-				  },
-				  point: function(lambda, phi) {
-					var point1 = [lambda, phi],
-						point2,
-						v = visible(lambda, phi),
-						c = smallRadius
-						  ? v ? 0 : code(lambda, phi)
-						  : v ? code(lambda + (lambda < 0 ? pi$4 : -pi$4), phi) : 0;
-					if (!point0 && (v00 = v0 = v)) stream.lineStart();
-					// Handle degeneracies.
-					// TODO ignore if not clipping polygons.
-					if (v !== v0) {
-					  point2 = intersect(point0, point1);
-					  if (pointEqual(point0, point2) || pointEqual(point1, point2)) {
-						point1[0] += epsilon$4;
-						point1[1] += epsilon$4;
-						v = visible(point1[0], point1[1]);
-					  }
-					}
-					if (v !== v0) {
-					  clean = 0;
-					  if (v) {
-						// outside going in
-						stream.lineStart();
-						point2 = intersect(point1, point0);
-						stream.point(point2[0], point2[1]);
-					  } else {
-						// inside going out
-						point2 = intersect(point0, point1);
-						stream.point(point2[0], point2[1]);
-						stream.lineEnd();
-					  }
-					  point0 = point2;
-					} else if (notHemisphere && point0 && smallRadius ^ v) {
-					  var t;
-					  // If the codes for two points are different, or are both zero,
-					  // and there this segment intersects with the small circle.
-					  if (!(c & c0) && (t = intersect(point1, point0, true))) {
-						clean = 0;
-						if (smallRadius) {
-						  stream.lineStart();
-						  stream.point(t[0][0], t[0][1]);
-						  stream.point(t[1][0], t[1][1]);
-						  stream.lineEnd();
-						} else {
-						  stream.point(t[1][0], t[1][1]);
-						  stream.lineEnd();
-						  stream.lineStart();
-						  stream.point(t[0][0], t[0][1]);
-						}
-					  }
-					}
-					if (v && (!point0 || !pointEqual(point0, point1))) {
-					  stream.point(point1[0], point1[1]);
-					}
-					point0 = point1, v0 = v, c0 = c;
-				  },
-				  lineEnd: function() {
-					if (v0) stream.lineEnd();
-					point0 = null;
-				  },
-				  // Rejoin first and last segments if there were intersections and the first
-				  // and last points were visible.
-				  clean: function() {
-					return clean | ((v00 && v0) << 1);
-				  }
-				};
-			  }
-
-			  // Intersects the great circle between a and b with the clip circle.
-			  function intersect(a, b, two) {
-				var pa = cartesian(a),
-					pb = cartesian(b);
-
-				// We have two planes, n1.p = d1 and n2.p = d2.
-				// Find intersection line p(t) = c1 n1 + c2 n2 + t (n1 ⨯ n2).
-				var n1 = [1, 0, 0], // normal
-					n2 = cartesianCross(pa, pb),
-					n2n2 = cartesianDot(n2, n2),
-					n1n2 = n2[0], // cartesianDot(n1, n2),
-					determinant = n2n2 - n1n2 * n1n2;
-
-				// Two polar points.
-				if (!determinant) return !two && a;
-
-				var c1 =  cr * n2n2 / determinant,
-					c2 = -cr * n1n2 / determinant,
-					n1xn2 = cartesianCross(n1, n2),
-					A = cartesianScale(n1, c1),
-					B = cartesianScale(n2, c2);
-				cartesianAddInPlace(A, B);
-
-				// Solve |p(t)|^2 = 1.
-				var u = n1xn2,
-					w = cartesianDot(A, u),
-					uu = cartesianDot(u, u),
-					t2 = w * w - uu * (cartesianDot(A, A) - 1);
-
-				if (t2 < 0) return;
-
-				var t = sqrt$1(t2),
-					q = cartesianScale(u, (-w - t) / uu);
-				cartesianAddInPlace(q, A);
-				q = spherical(q);
-
-				if (!two) return q;
-
-				// Two intersection points.
-				var lambda0 = a[0],
-					lambda1 = b[0],
-					phi0 = a[1],
-					phi1 = b[1],
-					z;
-
-				if (lambda1 < lambda0) z = lambda0, lambda0 = lambda1, lambda1 = z;
-
-				var delta = lambda1 - lambda0,
-					polar = abs(delta - pi$4) < epsilon$4,
-					meridian = polar || delta < epsilon$4;
-
-				if (!polar && phi1 < phi0) z = phi0, phi0 = phi1, phi1 = z;
-
-				// Check that the first point is between a and b.
-				if (meridian
-					? polar
-					  ? phi0 + phi1 > 0 ^ q[1] < (abs(q[0] - lambda0) < epsilon$4 ? phi0 : phi1)
-					  : phi0 <= q[1] && q[1] <= phi1
-					: delta > pi$4 ^ (lambda0 <= q[0] && q[0] <= lambda1)) {
-				  var q1 = cartesianScale(u, (-w + t) / uu);
-				  cartesianAddInPlace(q1, A);
-				  return [q, spherical(q1)];
-				}
-			  }
-
-			  // Generates a 4-bit vector representing the location of a point relative to
-			  // the small circle's bounding box.
-			  function code(lambda, phi) {
-				var r = smallRadius ? radius : pi$4 - radius,
-					code = 0;
-				if (lambda < -r) code |= 1; // left
-				else if (lambda > r) code |= 2; // right
-				if (phi < -r) code |= 4; // below
-				else if (phi > r) code |= 8; // above
-				return code;
-			  }
-
-			  return clip(visible, clipLine, interpolate, smallRadius ? [0, -radius] : [-pi$4, radius - pi$4]);
-			};
-
-			var transform$1 = function(methods) {
-			  return {
-				stream: transformer(methods)
-			  };
-			};
-
-			function transformer(methods) {
-			  return function(stream) {
-				var s = new TransformStream;
-				for (var key in methods) s[key] = methods[key];
-				s.stream = stream;
-				return s;
-			  };
-			}
-
-			function TransformStream() {}
-
-			TransformStream.prototype = {
-			  constructor: TransformStream,
-			  point: function(x, y) { this.stream.point(x, y); },
-			  sphere: function() { this.stream.sphere(); },
-			  lineStart: function() { this.stream.lineStart(); },
-			  lineEnd: function() { this.stream.lineEnd(); },
-			  polygonStart: function() { this.stream.polygonStart(); },
-			  polygonEnd: function() { this.stream.polygonEnd(); }
-			};
-
-			function fitExtent(projection, extent, object) {
-			  var w = extent[1][0] - extent[0][0],
-				  h = extent[1][1] - extent[0][1],
-				  clip = projection.clipExtent && projection.clipExtent();
-
-			  projection
-				  .scale(150)
-				  .translate([0, 0]);
-
-			  if (clip != null) projection.clipExtent(null);
-
-			  geoStream(object, projection.stream(boundsStream$1));
-
-			  var b = boundsStream$1.result(),
-				  k = Math.min(w / (b[1][0] - b[0][0]), h / (b[1][1] - b[0][1])),
-				  x = +extent[0][0] + (w - k * (b[1][0] + b[0][0])) / 2,
-				  y = +extent[0][1] + (h - k * (b[1][1] + b[0][1])) / 2;
-
-			  if (clip != null) projection.clipExtent(clip);
-
-			  return projection
-				  .scale(k * 150)
-				  .translate([x, y]);
-			}
-
-			function fitSize(projection, size, object) {
-			  return fitExtent(projection, [[0, 0], size], object);
-			}
-
-			var maxDepth = 16;
-			var cosMinDistance = cos$1(30 * radians); // cos(minimum angular distance)
-
-			var resample = function(project, delta2) {
-			  return +delta2 ? resample$1(project, delta2) : resampleNone(project);
-			};
-
-			function resampleNone(project) {
-			  return transformer({
-				point: function(x, y) {
-				  x = project(x, y);
-				  this.stream.point(x[0], x[1]);
-				}
-			  });
-			}
-
-			function resample$1(project, delta2) {
-
-			  function resampleLineTo(x0, y0, lambda0, a0, b0, c0, x1, y1, lambda1, a1, b1, c1, depth, stream) {
-				var dx = x1 - x0,
-					dy = y1 - y0,
-					d2 = dx * dx + dy * dy;
-				if (d2 > 4 * delta2 && depth--) {
-				  var a = a0 + a1,
-					  b = b0 + b1,
-					  c = c0 + c1,
-					  m = sqrt$1(a * a + b * b + c * c),
-					  phi2 = asin$1(c /= m),
-					  lambda2 = abs(abs(c) - 1) < epsilon$4 || abs(lambda0 - lambda1) < epsilon$4 ? (lambda0 + lambda1) / 2 : atan2(b, a),
-					  p = project(lambda2, phi2),
-					  x2 = p[0],
-					  y2 = p[1],
-					  dx2 = x2 - x0,
-					  dy2 = y2 - y0,
-					  dz = dy * dx2 - dx * dy2;
-				  if (dz * dz / d2 > delta2 // perpendicular projected distance
-					  || abs((dx * dx2 + dy * dy2) / d2 - 0.5) > 0.3 // midpoint close to an end
-					  || a0 * a1 + b0 * b1 + c0 * c1 < cosMinDistance) { // angular distance
-					resampleLineTo(x0, y0, lambda0, a0, b0, c0, x2, y2, lambda2, a /= m, b /= m, c, depth, stream);
-					stream.point(x2, y2);
-					resampleLineTo(x2, y2, lambda2, a, b, c, x1, y1, lambda1, a1, b1, c1, depth, stream);
-				  }
-				}
-			  }
-			  return function(stream) {
-				var lambda00, x00, y00, a00, b00, c00, // first point
-					lambda0, x0, y0, a0, b0, c0; // previous point
-
-				var resampleStream = {
-				  point: point,
-				  lineStart: lineStart,
-				  lineEnd: lineEnd,
-				  polygonStart: function() { stream.polygonStart(); resampleStream.lineStart = ringStart; },
-				  polygonEnd: function() { stream.polygonEnd(); resampleStream.lineStart = lineStart; }
-				};
-
-				function point(x, y) {
-				  x = project(x, y);
-				  stream.point(x[0], x[1]);
-				}
-
-				function lineStart() {
-				  x0 = NaN;
-				  resampleStream.point = linePoint;
-				  stream.lineStart();
-				}
-
-				function linePoint(lambda, phi) {
-				  var c = cartesian([lambda, phi]), p = project(lambda, phi);
-				  resampleLineTo(x0, y0, lambda0, a0, b0, c0, x0 = p[0], y0 = p[1], lambda0 = lambda, a0 = c[0], b0 = c[1], c0 = c[2], maxDepth, stream);
-				  stream.point(x0, y0);
-				}
-
-				function lineEnd() {
-				  resampleStream.point = point;
-				  stream.lineEnd();
-				}
-
-				function ringStart() {
-				  lineStart();
-				  resampleStream.point = ringPoint;
-				  resampleStream.lineEnd = ringEnd;
-				}
-
-				function ringPoint(lambda, phi) {
-				  linePoint(lambda00 = lambda, phi), x00 = x0, y00 = y0, a00 = a0, b00 = b0, c00 = c0;
-				  resampleStream.point = linePoint;
-				}
-
-				function ringEnd() {
-				  resampleLineTo(x0, y0, lambda0, a0, b0, c0, x00, y00, lambda00, a00, b00, c00, maxDepth, stream);
-				  resampleStream.lineEnd = lineEnd;
-				  lineEnd();
-				}
-
-				return resampleStream;
-			  };
-			}
-
-			var transformRadians = transformer({
-			  point: function(x, y) {
-				this.stream.point(x * radians, y * radians);
-			  }
-			});
-
-			function projection(project) {
-			  return projectionMutator(function() { return project; })();
-			}
-
-			function projectionMutator(projectAt) {
-			  var project,
-				  k = 150, // scale
-				  x = 480, y = 250, // translate
-				  dx, dy, lambda = 0, phi = 0, // center
-				  deltaLambda = 0, deltaPhi = 0, deltaGamma = 0, rotate, projectRotate, // rotate
-				  theta = null, preclip = clipAntimeridian, // clip angle
-				  x0 = null, y0, x1, y1, postclip = identity$7, // clip extent
-				  delta2 = 0.5, projectResample = resample(projectTransform, delta2), // precision
-				  cache,
-				  cacheStream;
-
-			  function projection(point) {
-				point = projectRotate(point[0] * radians, point[1] * radians);
-				return [point[0] * k + dx, dy - point[1] * k];
-			  }
-
-			  function invert(point) {
-				point = projectRotate.invert((point[0] - dx) / k, (dy - point[1]) / k);
-				return point && [point[0] * degrees$1, point[1] * degrees$1];
-			  }
-
-			  function projectTransform(x, y) {
-				return x = project(x, y), [x[0] * k + dx, dy - x[1] * k];
-			  }
-
-			  projection.stream = function(stream) {
-				return cache && cacheStream === stream ? cache : cache = transformRadians(preclip(rotate, projectResample(postclip(cacheStream = stream))));
-			  };
-
-			  projection.clipAngle = function(_) {
-				return arguments.length ? (preclip = +_ ? clipCircle(theta = _ * radians, 6 * radians) : (theta = null, clipAntimeridian), reset()) : theta * degrees$1;
-			  };
-
-			  projection.clipExtent = function(_) {
-				return arguments.length ? (postclip = _ == null ? (x0 = y0 = x1 = y1 = null, identity$7) : clipExtent(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];
-			  };
-
-			  projection.scale = function(_) {
-				return arguments.length ? (k = +_, recenter()) : k;
-			  };
-
-			  projection.translate = function(_) {
-				return arguments.length ? (x = +_[0], y = +_[1], recenter()) : [x, y];
-			  };
-
-			  projection.center = function(_) {
-				return arguments.length ? (lambda = _[0] % 360 * radians, phi = _[1] % 360 * radians, recenter()) : [lambda * degrees$1, phi * degrees$1];
-			  };
-
-			  projection.rotate = function(_) {
-				return arguments.length ? (deltaLambda = _[0] % 360 * radians, deltaPhi = _[1] % 360 * radians, deltaGamma = _.length > 2 ? _[2] % 360 * radians : 0, recenter()) : [deltaLambda * degrees$1, deltaPhi * degrees$1, deltaGamma * degrees$1];
-			  };
-
-			  projection.precision = function(_) {
-				return arguments.length ? (projectResample = resample(projectTransform, delta2 = _ * _), reset()) : sqrt$1(delta2);
-			  };
-
-			  projection.fitExtent = function(extent, object) {
-				return fitExtent(projection, extent, object);
-			  };
-
-			  projection.fitSize = function(size, object) {
-				return fitSize(projection, size, object);
-			  };
-
-			  function recenter() {
-				projectRotate = compose(rotate = rotateRadians(deltaLambda, deltaPhi, deltaGamma), project);
-				var center = project(lambda, phi);
-				dx = x - center[0] * k;
-				dy = y + center[1] * k;
-				return reset();
-			  }
-
-			  function reset() {
-				cache = cacheStream = null;
-				return projection;
-			  }
-
-			  return function() {
-				project = projectAt.apply(this, arguments);
-				projection.invert = project.invert && invert;
-				return recenter();
-			  };
-			}
-
-			function conicProjection(projectAt) {
-			  var phi0 = 0,
-				  phi1 = pi$4 / 3,
-				  m = projectionMutator(projectAt),
-				  p = m(phi0, phi1);
-
-			  p.parallels = function(_) {
-				return arguments.length ? m(phi0 = _[0] * radians, phi1 = _[1] * radians) : [phi0 * degrees$1, phi1 * degrees$1];
-			  };
-
-			  return p;
-			}
-
-			function cylindricalEqualAreaRaw(phi0) {
-			  var cosPhi0 = cos$1(phi0);
-
-			  function forward(lambda, phi) {
-				return [lambda * cosPhi0, sin$1(phi) / cosPhi0];
-			  }
-
-			  forward.invert = function(x, y) {
-				return [x / cosPhi0, asin$1(y * cosPhi0)];
-			  };
-
-			  return forward;
-			}
-
-			function conicEqualAreaRaw(y0, y1) {
-			  var sy0 = sin$1(y0), n = (sy0 + sin$1(y1)) / 2;
-
-			  // Are the parallels symmetrical around the Equator?
-			  if (abs(n) < epsilon$4) return cylindricalEqualAreaRaw(y0);
-
-			  var c = 1 + sy0 * (2 * n - sy0), r0 = sqrt$1(c) / n;
-
-			  function project(x, y) {
-				var r = sqrt$1(c - 2 * n * sin$1(y)) / n;
-				return [r * sin$1(x *= n), r0 - r * cos$1(x)];
-			  }
-
-			  project.invert = function(x, y) {
-				var r0y = r0 - y;
-				return [atan2(x, abs(r0y)) / n * sign$1(r0y), asin$1((c - (x * x + r0y * r0y) * n * n) / (2 * n))];
-			  };
-
-			  return project;
-			}
-
-			var conicEqualArea = function() {
-			  return conicProjection(conicEqualAreaRaw)
-				  .scale(155.424)
-				  .center([0, 33.6442]);
-			};
-
-			var albers = function() {
-			  return conicEqualArea()
-				  .parallels([29.5, 45.5])
-				  .scale(1070)
-				  .translate([480, 250])
-				  .rotate([96, 0])
-				  .center([-0.6, 38.7]);
-			};
-
-			// The projections must have mutually exclusive clip regions on the sphere,
-			// as this will avoid emitting interleaving lines and polygons.
-			function multiplex(streams) {
-			  var n = streams.length;
-			  return {
-				point: function(x, y) { var i = -1; while (++i < n) streams[i].point(x, y); },
-				sphere: function() { var i = -1; while (++i < n) streams[i].sphere(); },
-				lineStart: function() { var i = -1; while (++i < n) streams[i].lineStart(); },
-				lineEnd: function() { var i = -1; while (++i < n) streams[i].lineEnd(); },
-				polygonStart: function() { var i = -1; while (++i < n) streams[i].polygonStart(); },
-				polygonEnd: function() { var i = -1; while (++i < n) streams[i].polygonEnd(); }
-			  };
-			}
-
-			// A composite projection for the United States, configured by default for
-			// 960×500. The projection also works quite well at 960×600 if you change the
-			// scale to 1285 and adjust the translate accordingly. The set of standard
-			// parallels for each region comes from USGS, which is published here:
-			// http://egsc.usgs.gov/isb/pubs/MapProjections/projections.html#albers
-			var albersUsa = function() {
-			  var cache,
-				  cacheStream,
-				  lower48 = albers(), lower48Point,
-				  alaska = conicEqualArea().rotate([154, 0]).center([-2, 58.5]).parallels([55, 65]), alaskaPoint, // EPSG:3338
-				  hawaii = conicEqualArea().rotate([157, 0]).center([-3, 19.9]).parallels([8, 18]), hawaiiPoint, // ESRI:102007
-				  point, pointStream = {point: function(x, y) { point = [x, y]; }};
-
-			  function albersUsa(coordinates) {
-				var x = coordinates[0], y = coordinates[1];
-				return point = null,
-					(lower48Point.point(x, y), point)
-					|| (alaskaPoint.point(x, y), point)
-					|| (hawaiiPoint.point(x, y), point);
-			  }
-
-			  albersUsa.invert = function(coordinates) {
-				var k = lower48.scale(),
-					t = lower48.translate(),
-					x = (coordinates[0] - t[0]) / k,
-					y = (coordinates[1] - t[1]) / k;
-				return (y >= 0.120 && y < 0.234 && x >= -0.425 && x < -0.214 ? alaska
-					: y >= 0.166 && y < 0.234 && x >= -0.214 && x < -0.115 ? hawaii
-					: lower48).invert(coordinates);
-			  };
-
-			  albersUsa.stream = function(stream) {
-				return cache && cacheStream === stream ? cache : cache = multiplex([lower48.stream(cacheStream = stream), alaska.stream(stream), hawaii.stream(stream)]);
-			  };
-
-			  albersUsa.precision = function(_) {
-				if (!arguments.length) return lower48.precision();
-				lower48.precision(_), alaska.precision(_), hawaii.precision(_);
-				return reset();
-			  };
-
-			  albersUsa.scale = function(_) {
-				if (!arguments.length) return lower48.scale();
-				lower48.scale(_), alaska.scale(_ * 0.35), hawaii.scale(_);
-				return albersUsa.translate(lower48.translate());
-			  };
-
-			  albersUsa.translate = function(_) {
-				if (!arguments.length) return lower48.translate();
-				var k = lower48.scale(), x = +_[0], y = +_[1];
-
-				lower48Point = lower48
-					.translate(_)
-					.clipExtent([[x - 0.455 * k, y - 0.238 * k], [x + 0.455 * k, y + 0.238 * k]])
-					.stream(pointStream);
-
-				alaskaPoint = alaska
-					.translate([x - 0.307 * k, y + 0.201 * k])
-					.clipExtent([[x - 0.425 * k + epsilon$4, y + 0.120 * k + epsilon$4], [x - 0.214 * k - epsilon$4, y + 0.234 * k - epsilon$4]])
-					.stream(pointStream);
-
-				hawaiiPoint = hawaii
-					.translate([x - 0.205 * k, y + 0.212 * k])
-					.clipExtent([[x - 0.214 * k + epsilon$4, y + 0.166 * k + epsilon$4], [x - 0.115 * k - epsilon$4, y + 0.234 * k - epsilon$4]])
-					.stream(pointStream);
-
-				return reset();
-			  };
-
-			  albersUsa.fitExtent = function(extent, object) {
-				return fitExtent(albersUsa, extent, object);
-			  };
-
-			  albersUsa.fitSize = function(size, object) {
-				return fitSize(albersUsa, size, object);
-			  };
-
-			  function reset() {
-				cache = cacheStream = null;
-				return albersUsa;
-			  }
-
-			  return albersUsa.scale(1070);
-			};
-
-			function azimuthalRaw(scale) {
-			  return function(x, y) {
-				var cx = cos$1(x),
-					cy = cos$1(y),
-					k = scale(cx * cy);
-				return [
-				  k * cy * sin$1(x),
-				  k * sin$1(y)
-				];
-			  }
-			}
-
-			function azimuthalInvert(angle) {
-			  return function(x, y) {
-				var z = sqrt$1(x * x + y * y),
-					c = angle(z),
-					sc = sin$1(c),
-					cc = cos$1(c);
-				return [
-				  atan2(x * sc, z * cc),
-				  asin$1(z && y * sc / z)
-				];
-			  }
-			}
-
-			var azimuthalEqualAreaRaw = azimuthalRaw(function(cxcy) {
-			  return sqrt$1(2 / (1 + cxcy));
-			});
-
-			azimuthalEqualAreaRaw.invert = azimuthalInvert(function(z) {
-			  return 2 * asin$1(z / 2);
-			});
-
-			var azimuthalEqualArea = function() {
-			  return projection(azimuthalEqualAreaRaw)
-				  .scale(124.75)
-				  .clipAngle(180 - 1e-3);
-			};
-
-			var azimuthalEquidistantRaw = azimuthalRaw(function(c) {
-			  return (c = acos(c)) && c / sin$1(c);
-			});
-
-			azimuthalEquidistantRaw.invert = azimuthalInvert(function(z) {
-			  return z;
-			});
-
-			var azimuthalEquidistant = function() {
-			  return projection(azimuthalEquidistantRaw)
-				  .scale(79.4188)
-				  .clipAngle(180 - 1e-3);
-			};
-
-			function mercatorRaw(lambda, phi) {
-			  return [lambda, log$1(tan((halfPi$3 + phi) / 2))];
-			}
-
-			mercatorRaw.invert = function(x, y) {
-			  return [x, 2 * atan(exp(y)) - halfPi$3];
-			};
-
-			var mercator = function() {
-			  return mercatorProjection(mercatorRaw)
-				  .scale(961 / tau$4);
-			};
-
-			function mercatorProjection(project) {
-			  var m = projection(project),
-				  scale = m.scale,
-				  translate = m.translate,
-				  clipExtent = m.clipExtent,
-				  clipAuto;
-
-			  m.scale = function(_) {
-				return arguments.length ? (scale(_), clipAuto && m.clipExtent(null), m) : scale();
-			  };
-
-			  m.translate = function(_) {
-				return arguments.length ? (translate(_), clipAuto && m.clipExtent(null), m) : translate();
-			  };
-
-			  m.clipExtent = function(_) {
-				if (!arguments.length) return clipAuto ? null : clipExtent();
-				if (clipAuto = _ == null) {
-				  var k = pi$4 * scale(),
-					  t = translate();
-				  _ = [[t[0] - k, t[1] - k], [t[0] + k, t[1] + k]];
-				}
-				clipExtent(_);
-				return m;
-			  };
-
-			  return m.clipExtent(null);
-			}
-
-			function tany(y) {
-			  return tan((halfPi$3 + y) / 2);
-			}
-
-			function conicConformalRaw(y0, y1) {
-			  var cy0 = cos$1(y0),
-				  n = y0 === y1 ? sin$1(y0) : log$1(cy0 / cos$1(y1)) / log$1(tany(y1) / tany(y0)),
-				  f = cy0 * pow$1(tany(y0), n) / n;
-
-			  if (!n) return mercatorRaw;
-
-			  function project(x, y) {
-				if (f > 0) { if (y < -halfPi$3 + epsilon$4) y = -halfPi$3 + epsilon$4; }
-				else { if (y > halfPi$3 - epsilon$4) y = halfPi$3 - epsilon$4; }
-				var r = f / pow$1(tany(y), n);
-				return [r * sin$1(n * x), f - r * cos$1(n * x)];
-			  }
-
-			  project.invert = function(x, y) {
-				var fy = f - y, r = sign$1(n) * sqrt$1(x * x + fy * fy);
-				return [atan2(x, abs(fy)) / n * sign$1(fy), 2 * atan(pow$1(f / r, 1 / n)) - halfPi$3];
-			  };
-
-			  return project;
-			}
-
-			var conicConformal = function() {
-			  return conicProjection(conicConformalRaw)
-				  .scale(109.5)
-				  .parallels([30, 30]);
-			};
-
-			function equirectangularRaw(lambda, phi) {
-			  return [lambda, phi];
-			}
-
-			equirectangularRaw.invert = equirectangularRaw;
-
-			var equirectangular = function() {
-			  return projection(equirectangularRaw)
-				  .scale(152.63);
-			};
-
-			function conicEquidistantRaw(y0, y1) {
-			  var cy0 = cos$1(y0),
-				  n = y0 === y1 ? sin$1(y0) : (cy0 - cos$1(y1)) / (y1 - y0),
-				  g = cy0 / n + y0;
-
-			  if (abs(n) < epsilon$4) return equirectangularRaw;
-
-			  function project(x, y) {
-				var gy = g - y, nx = n * x;
-				return [gy * sin$1(nx), g - gy * cos$1(nx)];
-			  }
-
-			  project.invert = function(x, y) {
-				var gy = g - y;
-				return [atan2(x, abs(gy)) / n * sign$1(gy), g - sign$1(n) * sqrt$1(x * x + gy * gy)];
-			  };
-
-			  return project;
-			}
-
-			var conicEquidistant = function() {
-			  return conicProjection(conicEquidistantRaw)
-				  .scale(131.154)
-				  .center([0, 13.9389]);
-			};
-
-			function gnomonicRaw(x, y) {
-			  var cy = cos$1(y), k = cos$1(x) * cy;
-			  return [cy * sin$1(x) / k, sin$1(y) / k];
-			}
-
-			gnomonicRaw.invert = azimuthalInvert(atan);
-
-			var gnomonic = function() {
-			  return projection(gnomonicRaw)
-				  .scale(144.049)
-				  .clipAngle(60);
-			};
-
-			function scaleTranslate(k, tx, ty) {
-			  return k === 1 && tx === 0 && ty === 0 ? identity$7 : transformer({
-				point: function(x, y) {
-				  this.stream.point(x * k + tx, y * k + ty);
-				}
-			  });
-			}
-
-			var identity$8 = function() {
-			  var k = 1, tx = 0, ty = 0, transform = identity$7, // scale and translate
-				  x0 = null, y0, x1, y1, clip = identity$7, // clip extent
-				  cache,
-				  cacheStream,
-				  projection;
-
-			  function reset() {
-				cache = cacheStream = null;
-				return projection;
-			  }
-
-			  return projection = {
-				stream: function(stream) {
-				  return cache && cacheStream === stream ? cache : cache = transform(clip(cacheStream = stream));
-				},
-				clipExtent: function(_) {
-				  return arguments.length ? (clip = _ == null ? (x0 = y0 = x1 = y1 = null, identity$7) : clipExtent(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];
-				},
-				scale: function(_) {
-				  return arguments.length ? (transform = scaleTranslate(k = +_, tx, ty), reset()) : k;
-				},
-				translate: function(_) {
-				  return arguments.length ? (transform = scaleTranslate(k, tx = +_[0], ty = +_[1]), reset()) : [tx, ty];
-				},
-				fitExtent: function(extent, object) {
-				  return fitExtent(projection, extent, object);
-				},
-				fitSize: function(size, object) {
-				  return fitSize(projection, size, object);
-				}
-			  };
-			};
-
-			function orthographicRaw(x, y) {
-			  return [cos$1(y) * sin$1(x), sin$1(y)];
-			}
-
-			orthographicRaw.invert = azimuthalInvert(asin$1);
-
-			var orthographic = function() {
-			  return projection(orthographicRaw)
-				  .scale(249.5)
-				  .clipAngle(90 + epsilon$4);
-			};
-
-			function stereographicRaw(x, y) {
-			  var cy = cos$1(y), k = 1 + cos$1(x) * cy;
-			  return [cy * sin$1(x) / k, sin$1(y) / k];
-			}
-
-			stereographicRaw.invert = azimuthalInvert(function(z) {
-			  return 2 * atan(z);
-			});
-
-			var stereographic = function() {
-			  return projection(stereographicRaw)
-				  .scale(250)
-				  .clipAngle(142);
-			};
-
-			function transverseMercatorRaw(lambda, phi) {
-			  return [log$1(tan((halfPi$3 + phi) / 2)), -lambda];
-			}
-
-			transverseMercatorRaw.invert = function(x, y) {
-			  return [-y, 2 * atan(exp(x)) - halfPi$3];
-			};
-
-			var transverseMercator = function() {
-			  var m = mercatorProjection(transverseMercatorRaw),
-				  center = m.center,
-				  rotate = m.rotate;
-
-			  m.center = function(_) {
-				return arguments.length ? center([-_[1], _[0]]) : (_ = center(), [_[1], -_[0]]);
-			  };
-
-			  m.rotate = function(_) {
-				return arguments.length ? rotate([_[0], _[1], _.length > 2 ? _[2] + 90 : 90]) : (_ = rotate(), [_[0], _[1], _[2] - 90]);
-			  };
-
-			  return rotate([0, 0, 90])
-				  .scale(159.155);
-			};
-
-			exports.version = version;
-			exports.bisect = bisectRight;
-			exports.bisectRight = bisectRight;
-			exports.bisectLeft = bisectLeft;
-			exports.ascending = ascending;
-			exports.bisector = bisector;
-			exports.descending = descending;
-			exports.deviation = deviation;
-			exports.extent = extent;
-			exports.histogram = histogram;
-			exports.thresholdFreedmanDiaconis = freedmanDiaconis;
-			exports.thresholdScott = scott;
-			exports.thresholdSturges = sturges;
-			exports.max = max;
-			exports.mean = mean;
-			exports.median = median;
-			exports.merge = merge;
-			exports.min = min;
-			exports.pairs = pairs;
-			exports.permute = permute;
-			exports.quantile = threshold;
-			exports.range = range;
-			exports.scan = scan;
-			exports.shuffle = shuffle;
-			exports.sum = sum;
-			exports.ticks = ticks;
-			exports.tickStep = tickStep;
-			exports.transpose = transpose;
-			exports.variance = variance;
-			exports.zip = zip;
-			exports.entries = entries;
-			exports.keys = keys;
-			exports.values = values;
-			exports.map = map$1;
-			exports.set = set;
-			exports.nest = nest;
-			exports.randomUniform = uniform;
-			exports.randomNormal = normal;
-			exports.randomLogNormal = logNormal;
-			exports.randomBates = bates;
-			exports.randomIrwinHall = irwinHall;
-			exports.randomExponential = exponential;
-			exports.easeLinear = linear;
-			exports.easeQuad = quadInOut;
-			exports.easeQuadIn = quadIn;
-			exports.easeQuadOut = quadOut;
-			exports.easeQuadInOut = quadInOut;
-			exports.easeCubic = cubicInOut;
-			exports.easeCubicIn = cubicIn;
-			exports.easeCubicOut = cubicOut;
-			exports.easeCubicInOut = cubicInOut;
-			exports.easePoly = polyInOut;
-			exports.easePolyIn = polyIn;
-			exports.easePolyOut = polyOut;
-			exports.easePolyInOut = polyInOut;
-			exports.easeSin = sinInOut;
-			exports.easeSinIn = sinIn;
-			exports.easeSinOut = sinOut;
-			exports.easeSinInOut = sinInOut;
-			exports.easeExp = expInOut;
-			exports.easeExpIn = expIn;
-			exports.easeExpOut = expOut;
-			exports.easeExpInOut = expInOut;
-			exports.easeCircle = circleInOut;
-			exports.easeCircleIn = circleIn;
-			exports.easeCircleOut = circleOut;
-			exports.easeCircleInOut = circleInOut;
-			exports.easeBounce = bounceOut;
-			exports.easeBounceIn = bounceIn;
-			exports.easeBounceOut = bounceOut;
-			exports.easeBounceInOut = bounceInOut;
-			exports.easeBack = backInOut;
-			exports.easeBackIn = backIn;
-			exports.easeBackOut = backOut;
-			exports.easeBackInOut = backInOut;
-			exports.easeElastic = elasticOut;
-			exports.easeElasticIn = elasticIn;
-			exports.easeElasticOut = elasticOut;
-			exports.easeElasticInOut = elasticInOut;
-			exports.polygonArea = area;
-			exports.polygonCentroid = centroid;
-			exports.polygonHull = hull;
-			exports.polygonContains = contains;
-			exports.polygonLength = length$1;
-			exports.path = path;
-			exports.quadtree = quadtree;
-			exports.queue = queue;
-			exports.arc = arc;
-			exports.area = area$1;
-			exports.line = line;
-			exports.pie = pie;
-			exports.radialArea = radialArea;
-			exports.radialLine = radialLine$1;
-			exports.symbol = symbol;
-			exports.symbols = symbols;
-			exports.symbolCircle = circle;
-			exports.symbolCross = cross$1;
-			exports.symbolDiamond = diamond;
-			exports.symbolSquare = square;
-			exports.symbolStar = star;
-			exports.symbolTriangle = triangle;
-			exports.symbolWye = wye;
-			exports.curveBasisClosed = basisClosed;
-			exports.curveBasisOpen = basisOpen;
-			exports.curveBasis = basis;
-			exports.curveBundle = bundle;
-			exports.curveCardinalClosed = cardinalClosed;
-			exports.curveCardinalOpen = cardinalOpen;
-			exports.curveCardinal = cardinal;
-			exports.curveCatmullRomClosed = catmullRomClosed;
-			exports.curveCatmullRomOpen = catmullRomOpen;
-			exports.curveCatmullRom = catmullRom;
-			exports.curveLinearClosed = linearClosed;
-			exports.curveLinear = curveLinear;
-			exports.curveMonotoneX = monotoneX;
-			exports.curveMonotoneY = monotoneY;
-			exports.curveNatural = natural;
-			exports.curveStep = step;
-			exports.curveStepAfter = stepAfter;
-			exports.curveStepBefore = stepBefore;
-			exports.stack = stack;
-			exports.stackOffsetExpand = expand;
-			exports.stackOffsetNone = none;
-			exports.stackOffsetSilhouette = silhouette;
-			exports.stackOffsetWiggle = wiggle;
-			exports.stackOrderAscending = ascending$1;
-			exports.stackOrderDescending = descending$2;
-			exports.stackOrderInsideOut = insideOut;
-			exports.stackOrderNone = none$1;
-			exports.stackOrderReverse = reverse;
-			exports.color = color;
-			exports.rgb = rgb;
-			exports.hsl = hsl;
-			exports.lab = lab;
-			exports.hcl = hcl;
-			exports.cubehelix = cubehelix;
-			exports.interpolate = interpolate;
-			exports.interpolateArray = array$1;
-			exports.interpolateDate = date;
-			exports.interpolateNumber = interpolateNumber;
-			exports.interpolateObject = object;
-			exports.interpolateRound = interpolateRound;
-			exports.interpolateString = interpolateString;
-			exports.interpolateTransformCss = interpolateTransformCss;
-			exports.interpolateTransformSvg = interpolateTransformSvg;
-			exports.interpolateZoom = interpolateZoom;
-			exports.interpolateRgb = interpolateRgb;
-			exports.interpolateRgbBasis = rgbBasis;
-			exports.interpolateRgbBasisClosed = rgbBasisClosed;
-			exports.interpolateHsl = hsl$2;
-			exports.interpolateHslLong = hslLong;
-			exports.interpolateLab = lab$1;
-			exports.interpolateHcl = hcl$2;
-			exports.interpolateHclLong = hclLong;
-			exports.interpolateCubehelix = cubehelix$2;
-			exports.interpolateCubehelixLong = cubehelixLong;
-			exports.interpolateBasis = basis$2;
-			exports.interpolateBasisClosed = basisClosed$1;
-			exports.quantize = quantize;
-			exports.dispatch = dispatch;
-			exports.dsvFormat = dsv;
-			exports.csvParse = csvParse;
-			exports.csvParseRows = csvParseRows;
-			exports.csvFormat = csvFormat;
-			exports.csvFormatRows = csvFormatRows;
-			exports.tsvParse = tsvParse;
-			exports.tsvParseRows = tsvParseRows;
-			exports.tsvFormat = tsvFormat;
-			exports.tsvFormatRows = tsvFormatRows;
-			exports.request = request;
-			exports.html = html;
-			exports.json = json;
-			exports.text = text;
-			exports.xml = xml;
-			exports.csv = csv$1;
-			exports.tsv = tsv$1;
-			exports.now = now;
-			exports.timer = timer;
-			exports.timerFlush = timerFlush;
-			exports.timeout = timeout$1;
-			exports.interval = interval$1;
-			exports.timeInterval = newInterval;
-			exports.timeMillisecond = millisecond;
-			exports.timeMilliseconds = milliseconds;
-			exports.timeSecond = second;
-			exports.timeSeconds = seconds;
-			exports.timeMinute = minute;
-			exports.timeMinutes = minutes;
-			exports.timeHour = hour;
-			exports.timeHours = hours;
-			exports.timeDay = day;
-			exports.timeDays = days;
-			exports.timeWeek = sunday;
-			exports.timeWeeks = sundays;
-			exports.timeSunday = sunday;
-			exports.timeSundays = sundays;
-			exports.timeMonday = monday;
-			exports.timeMondays = mondays;
-			exports.timeTuesday = tuesday;
-			exports.timeTuesdays = tuesdays;
-			exports.timeWednesday = wednesday;
-			exports.timeWednesdays = wednesdays;
-			exports.timeThursday = thursday;
-			exports.timeThursdays = thursdays;
-			exports.timeFriday = friday;
-			exports.timeFridays = fridays;
-			exports.timeSaturday = saturday;
-			exports.timeSaturdays = saturdays;
-			exports.timeMonth = month;
-			exports.timeMonths = months;
-			exports.timeYear = year;
-			exports.timeYears = years;
-			exports.utcMillisecond = millisecond;
-			exports.utcMilliseconds = milliseconds;
-			exports.utcSecond = second;
-			exports.utcSeconds = seconds;
-			exports.utcMinute = utcMinute;
-			exports.utcMinutes = utcMinutes;
-			exports.utcHour = utcHour;
-			exports.utcHours = utcHours;
-			exports.utcDay = utcDay;
-			exports.utcDays = utcDays;
-			exports.utcWeek = utcSunday;
-			exports.utcWeeks = utcSundays;
-			exports.utcSunday = utcSunday;
-			exports.utcSundays = utcSundays;
-			exports.utcMonday = utcMonday;
-			exports.utcMondays = utcMondays;
-			exports.utcTuesday = utcTuesday;
-			exports.utcTuesdays = utcTuesdays;
-			exports.utcWednesday = utcWednesday;
-			exports.utcWednesdays = utcWednesdays;
-			exports.utcThursday = utcThursday;
-			exports.utcThursdays = utcThursdays;
-			exports.utcFriday = utcFriday;
-			exports.utcFridays = utcFridays;
-			exports.utcSaturday = utcSaturday;
-			exports.utcSaturdays = utcSaturdays;
-			exports.utcMonth = utcMonth;
-			exports.utcMonths = utcMonths;
-			exports.utcYear = utcYear;
-			exports.utcYears = utcYears;
-			exports.formatLocale = formatLocale;
-			exports.formatDefaultLocale = defaultLocale;
-			exports.formatSpecifier = formatSpecifier;
-			exports.precisionFixed = precisionFixed;
-			exports.precisionPrefix = precisionPrefix;
-			exports.precisionRound = precisionRound;
-			exports.isoFormat = formatIso;
-			exports.isoParse = parseIso;
-			exports.timeFormatLocale = formatLocale$1;
-			exports.timeFormatDefaultLocale = defaultLocale$1;
-			exports.scaleBand = band;
-			exports.scalePoint = point$4;
-			exports.scaleIdentity = identity$4;
-			exports.scaleLinear = linear$2;
-			exports.scaleLog = log;
-			exports.scaleOrdinal = ordinal;
-			exports.scaleImplicit = implicit;
-			exports.scalePow = pow;
-			exports.scaleSqrt = sqrt;
-			exports.scaleQuantile = quantile$$1;
-			exports.scaleQuantize = quantize$1;
-			exports.scaleThreshold = threshold$1;
-			exports.scaleTime = time;
-			exports.scaleUtc = utcTime;
-			exports.schemeCategory10 = category10;
-			exports.schemeCategory20b = category20b;
-			exports.schemeCategory20c = category20c;
-			exports.schemeCategory20 = category20;
-			exports.scaleSequential = sequential;
-			exports.interpolateCubehelixDefault = cubehelix$3;
-			exports.interpolateRainbow = rainbow$1;
-			exports.interpolateWarm = warm;
-			exports.interpolateCool = cool;
-			exports.interpolateViridis = viridis;
-			exports.interpolateMagma = magma;
-			exports.interpolateInferno = inferno;
-			exports.interpolatePlasma = plasma;
-			exports.creator = creator;
-			exports.customEvent = customEvent;
-			exports.local = local;
-			exports.matcher = matcher$1;
-			exports.mouse = mouse;
-			exports.namespace = namespace;
-			exports.namespaces = namespaces;
-			exports.select = select;
-			exports.selectAll = selectAll;
-			exports.selection = selection;
-			exports.selector = selector;
-			exports.selectorAll = selectorAll;
-			exports.touch = touch;
-			exports.touches = touches;
-			exports.window = window;
-			exports.active = active;
-			exports.interrupt = interrupt;
-			exports.transition = transition;
-			exports.axisTop = axisTop;
-			exports.axisRight = axisRight;
-			exports.axisBottom = axisBottom;
-			exports.axisLeft = axisLeft;
-			exports.cluster = cluster;
-			exports.hierarchy = hierarchy;
-			exports.pack = index;
-			exports.packSiblings = siblings;
-			exports.packEnclose = enclose;
-			exports.partition = partition;
-			exports.stratify = stratify;
-			exports.tree = tree;
-			exports.treemap = index$1;
-			exports.treemapBinary = binary;
-			exports.treemapDice = treemapDice;
-			exports.treemapSlice = treemapSlice;
-			exports.treemapSliceDice = sliceDice;
-			exports.treemapSquarify = squarify;
-			exports.treemapResquarify = resquarify;
-			exports.forceCenter = center$1;
-			exports.forceCollide = collide;
-			exports.forceLink = link;
-			exports.forceManyBody = manyBody;
-			exports.forceSimulation = simulation;
-			exports.forceX = x$3;
-			exports.forceY = y$3;
-			exports.drag = drag;
-			exports.dragDisable = dragDisable;
-			exports.dragEnable = yesdrag;
-			exports.voronoi = voronoi;
-			exports.zoom = zoom;
-			exports.zoomIdentity = identity$6;
-			exports.zoomTransform = transform;
-			exports.brush = brush;
-			exports.brushX = brushX;
-			exports.brushY = brushY;
-			exports.brushSelection = brushSelection;
-			exports.chord = chord;
-			exports.ribbon = ribbon;
-			exports.geoAlbers = albers;
-			exports.geoAlbersUsa = albersUsa;
-			exports.geoArea = area$2;
-			exports.geoAzimuthalEqualArea = azimuthalEqualArea;
-			exports.geoAzimuthalEqualAreaRaw = azimuthalEqualAreaRaw;
-			exports.geoAzimuthalEquidistant = azimuthalEquidistant;
-			exports.geoAzimuthalEquidistantRaw = azimuthalEquidistantRaw;
-			exports.geoBounds = bounds;
-			exports.geoCentroid = centroid$1;
-			exports.geoCircle = circle$1;
-			exports.geoClipExtent = extent$1;
-			exports.geoConicConformal = conicConformal;
-			exports.geoConicConformalRaw = conicConformalRaw;
-			exports.geoConicEqualArea = conicEqualArea;
-			exports.geoConicEqualAreaRaw = conicEqualAreaRaw;
-			exports.geoConicEquidistant = conicEquidistant;
-			exports.geoConicEquidistantRaw = conicEquidistantRaw;
-			exports.geoDistance = distance;
-			exports.geoEquirectangular = equirectangular;
-			exports.geoEquirectangularRaw = equirectangularRaw;
-			exports.geoGnomonic = gnomonic;
-			exports.geoGnomonicRaw = gnomonicRaw;
-			exports.geoGraticule = graticule;
-			exports.geoGraticule10 = graticule10;
-			exports.geoIdentity = identity$8;
-			exports.geoInterpolate = interpolate$2;
-			exports.geoLength = length$2;
-			exports.geoMercator = mercator;
-			exports.geoMercatorRaw = mercatorRaw;
-			exports.geoOrthographic = orthographic;
-			exports.geoOrthographicRaw = orthographicRaw;
-			exports.geoPath = index$3;
-			exports.geoProjection = projection;
-			exports.geoProjectionMutator = projectionMutator;
-			exports.geoRotation = rotation;
-			exports.geoStereographic = stereographic;
-			exports.geoStereographicRaw = stereographicRaw;
-			exports.geoStream = geoStream;
-			exports.geoTransform = transform$1;
-			exports.geoTransverseMercator = transverseMercator;
-			exports.geoTransverseMercatorRaw = transverseMercatorRaw;
-
-			Object.defineProperty(exports, '__esModule', { value: true });
-
-			})));
-
-
-			//aigner: HERE IS WHERE IT ALL STARTS!!!
-			},{}],2:[function(require,module,exports){
-				
-
-
-				
-			var d3 = require('d3');
-
-			var PULSE_DURATION = 700;
-			var SUB_ANIM_DELAY = 200;
-			var ACTIVE_COLOR = d3.rgb("seagreen");
-
-			function Animation(xdsms, rootId, delay) {
-			  this.rootId = rootId;
-			  if (typeof (rootId) === 'undefined') {
-				this.rootId = 'root';
-			  }
-			  this.root = xdsms[this.rootId];
-			  this.xdsms = xdsms;
-			  this.duration = PULSE_DURATION;
-			  this.initialDelay = delay || 0;
-			}
-
-			Animation.prototype._pulse = function(delay, toBeSelected, option) {
-			  var sel = d3.select("svg." + this.rootId)
-						  .selectAll(toBeSelected)
-						  .transition().delay(delay);
-			  if (option !== "out") {
-				sel = sel.transition().duration(200)
-						.style('stroke-width', '8px')
-						.style('stroke', ACTIVE_COLOR)
-						.style('fill', function(d) {
-						  if (d.id) {
-							return ACTIVE_COLOR.brighter();
-						  }});
-			  }
-			  if (option !== "in") {
-				sel.transition().duration(3 * PULSE_DURATION)
-						.style('stroke-width', null)
-						.style('stroke', null)
-						.style('fill', null);
-			  }
-			};
-
-			Animation.prototype._animate = function() {
-			  var self = this;
-			  var delay = this.initialDelay;
-			  var animDelay = SUB_ANIM_DELAY;
-			  var graph = self.xdsms[self.rootId].graph;
-			  
-			  var title = d3.select("svg." + self.rootId).select("g.title");
-			  title.select("text").transition().delay(delay).style("fill", ACTIVE_COLOR);
-			  d3.select("svg." + self.rootId).select("rect.border")
-				.transition().delay(delay)
-				  .style("stroke-width", '5px').duration(200)
-				.transition().duration(1000)
-				  .style("stroke", 'black').style("stroke-width", '0px');
-
-			  graph.nodesByStep.forEach(function(nodesAtStep, n, nodesByStep) {
-				var offsets = [];
-				nodesAtStep.forEach(function(nodeId) {
-				  var elapsed = delay + n * PULSE_DURATION;
-				  if (n > 0) {
-					nodesByStep[n-1].forEach(function(prevNodeId) { // eslint-disable-line space-infix-ops
-					  var from = graph.idxOf(prevNodeId);
-					  var to = graph.idxOf(nodeId);
-					  self._pulse(elapsed,"polyline.link_" + from + "_" + to);
-					});
-				  }
-				  //aigner: Look for existing xdsms/Sub-xdsms. Only show those, which are expanded                  
-				  var gnode = "g." + nodeId;
-				  var nodeSel = d3.select("svg." + self.rootId).select(gnode);
-				  var scnId = graph.getNode(nodeId).getScenarioId();
-				  if (nodeSel.classed("mdo") && self.xdsms[scnId]) 
-				  {
-					  self._pulse(elapsed, gnode + " > rect", "in");
-					  var anim = new Animation(self.xdsms, scnId, elapsed + animDelay);
-					  var offset = anim._animate();
-					  offsets.push(offset);
-					  self._pulse(offset + elapsed + animDelay, gnode + " > rect", "out");
-				  } 
-				  else 
-				  {
-					  self._pulse(elapsed, gnode + " > rect");
-				  }
-				}, this);
-
-				if (offsets.length > 0) {
-				  delay += Math.max.apply(null, offsets);
-				}
-				delay += animDelay;
-			  }, this);
-				
-			  title.select("text").transition()
-				.delay(graph.nodesByStep.length * PULSE_DURATION + delay)
-				.style("fill", null);
-
-			  return graph.nodesByStep.length * PULSE_DURATION;
-			};
-
-			Animation.prototype.run = function() {
-			  this._animate();
-			};
-
-			module.exports = Animation;
-
-			},{"d3":1}],3:[function(require,module,exports){
-			var _U_ = "_U_";
-			var MULTI_TYPE = "_multi";
-
-			//aigner: Node() constructor additionally gets the "xdsm"
-			function Node(xdsm, id, uID, name, type, metadata) {                
-			  var splitUndef = name.split("undefined: ")
-			  if (splitUndef.length>1) {name=splitUndef[1]}
-			  else {name=splitUndef[0]}
-			  
-			  if (typeof (name) === 'undefined') {
-				name = id;
-			  }
-			  if (typeof (type) === 'undefined') {
-				type = 'analysis';
-			  }
-			  this.xdsm = xdsm;
-			  this.id = id;
-			  this.uID = uID;
-			  this.name = name;
-			  this.metadata = metadata;
-			  this.isMulti = (type.search(/_multi$/) >= 0);
-			  this.type = this.isMulti ?
-				type.substr(0, type.length - MULTI_TYPE.length) : type;
-			}
-
-			Node.prototype.isMdo = function() {
-			  return this.type === "mdo";
-			};
-
-			Node.prototype.getScenarioId = function() {
-			  if (this.isMdo()) {
-				var idxscn = this.name.indexOf("_scn-");
-				if (idxscn === -1) {
-				  console.log("Warning: MDO Scenario not found. " +
-							  "Bad type or name for node: " + JSON.stringify(this));
-				  return null;
-				}
-				return this.name.substr(idxscn + 1);
-			  }
-			  return null;
-			};
-
-			function Edge(from, to, from_uID, to_uID, name, row, col, isMulti) {
-			  this.id = "link_" + from + "_" + to;
-			  this.name = name;
-			  this.row = row;
-			  this.col = col;
-			  this.iotype = row < col ? "in" : "out";
-			  this.io = {
-				fromU: (from === _U_),
-				toU: (to === _U_)
-			  };
-			  this.from = from;
-			  this.from_uID = from_uID;
-			  this.to = to;
-			  this.to_uID = to_uID;
-			  this.isMulti = isMulti;
-			}
-
-			Edge.prototype.isIO = function() {
-			  return this.io.fromU || this.io.toU;
-			};
-
-			//aigner: Function creates the xdsm graph
-			function Graph(mdo, refname) {
-			  this.nodes = [new Node(_U_, _U_, _U_, _U_, "user",[])];
-			  this.edges = [];
-			  this.chains = [];
-			  this.refname = refname || "";
-			  
-			  //aigner: New numbering due to new workflow definition in KADMOS (Old stuff commented out)
-			  var numbering = Graph.new_number(mdo.workflow);
-			  //var numbering = Graph.number(mdo.workflow);
-			  var numPrefixes = numbering.toNum;
-			  this.nodesByStep = numbering.toNode;
-
-			  mdo.nodes.forEach(function(item) {
-				name = document.createElement("TEXTAREA");
-				name = numPrefixes[item.id] + ": " + item.name;
-				this.nodes.push(new Node(item.xdsm, item.id, item.uID, name, item.type, item.metadata));    
-			  }, this);
-
-			  this.ids = this.nodes.map(function(elt) {
-				return elt.id;
-			  });
-			  
-			  mdo.edges.forEach(function(item) {
-				var idA = this.idxOf(item.from);
-				var idB = this.idxOf(item.to);
-				
-				var isMulti = this.nodes[idA].isMulti || this.nodes[idB].isMulti;
-				this.edges.push(new Edge(item.from, item.to, item.from_uID, item.to_uID, item.name, idA, idB, isMulti));
-			  }, this);
-
-			  
-			  //aigner: new chains with new workflow definition for KADMOS (Old stuff commented out)
-			  this.chains = Graph.new_expand(mdo.workflow,mdo.nodes);
-			  // var echain = Graph.expand(mdo.workflow); 
-			  // echain.forEach(function(leafChain) {
-				// if (leafChain.length < 2) {
-				  // throw new Error("Bad process chain (" + leafChain.length + "elt)");
-				// } else {
-				  // this.chains.push([]);
-				  // var ids = this.nodes.map(function(elt) {
-					// return elt.id;
-				  // });
-				  // leafChain.forEach(function(item, j) {
-					// if (j !== 0) {
-					  // var idA = ids.indexOf(leafChain[j - 1]);
-					  // if (idA < 0) {
-						// throw new Error("Process chain element (" +
-										// leafChain[j - 1] + ") not found");
-					  // }
-					  // var idB = ids.indexOf(leafChain[j]);
-					  // if (idB < 0) {
-						// throw new Error("Process chain element (" +
-										// leafChain[j] + ") not found");
-					  // }
-					  // if (idA !== idB) {
-						// this.chains[this.chains.length - 1].push([idA, idB]);
-					  // }
-					// }
-				  // }, this);
-				// }
-			  // }, this);
-			  
-			  
-			}
-
-			Graph.prototype.idxOf = function(nodeId) {
-			  return this.ids.indexOf(nodeId);
-			};
-			Graph.prototype.getNode = function(nodeId) {
-			  return this.nodes[this.ids.indexOf(nodeId)];
-			};
-
-			function _expand(workflow) {
-			  var ret = [];
-			  var prev;
-			  workflow.forEach(function(item) {
-				if (item instanceof Array) {
-				  if (item[0].hasOwnProperty('parallel')) {
-					if (prev) {
-					  ret = ret.slice(0, ret.length - 1).concat(item[0].parallel.map(
-						  function(elt) {
-							return [prev].concat(_expand([elt]), prev);
-						  }));
-					} else {
-					  throw new Error("Bad workflow structure : " +
-						  "cannot parallel loop without previous starting point.");
-					}
-				  } else if (prev) {
-					ret = ret.concat(_expand(item), prev);
-				  } else {
-					ret = ret.concat(_expand(item));
-				  }
-				  prev = ret[ret.length - 1];
-				} else if (item.hasOwnProperty('parallel')) {
-				  if (prev) {
-					ret = ret.slice(0, ret.length - 1).concat(
-						item.parallel.map(function(elt) {
-						  return [prev].concat(_expand([elt]));
-						}));
-				  } else {
-					ret = ret.concat(item.parallel.map(
-						function(elt) {
-						  return _expand([elt]);
-						}));
-				  }
-				  prev = undefined;
-				} else {
-				  var i = ret.length - 1;
-				  var flagParallel = false;
-				  while (i >= 0 && (ret[i] instanceof Array)) {
-					ret[i] = ret[i].concat(item);
-					i -= 1;
-					flagParallel = true;
-				  }
-				  if (!flagParallel) {
-					ret.push(item);
-				  }
-				  prev = item;
-				}
-			  }, this);
-			  return ret;
-			}
-
-			Graph.expand = function(item) {
-			  var expanded = _expand(item);
-			  var result = [];
-			  var current = [];
-			  expanded.forEach(function(elt) {
-				if (elt instanceof Array) {
-				  if (current.length > 0) {
-					current.push(elt[0]);
-					result.push(current);
-					current = [];
-				  }
-				  result.push(elt);
-				} else {
-				  if (result.length > 0 && current.length === 0) {
-					var lastChain = result[result.length - 1];
-					var lastElt = lastChain[lastChain.length - 1];
-					current.push(lastElt);
-				  }
-				  current.push(elt);
-				}
-			  }, this);
-			  if (current.length > 0) {
-				result.push(current);
-			  }
-			  return result;
-			};
-
-			Graph.new_expand = function(workflow,nodes) {
-				var ids = nodes.map(function(elt) {
-					return elt.id;
-				});
-				var result_tmp = [];
-				for (var i=0; i < workflow.length; i++)
-				{
-					var stepNumber = workflow[i].step_number
-					var edges = workflow[i].edges;
-					for (var j=0; j < edges.length; j++)
-					{
-						var fromNode = edges[j][0];
-						var toNode = edges[j][1];			
-						var fromId = ids.indexOf(fromNode)+1;
-						var toId = ids.indexOf(toNode)+1;
-						result_tmp.push([fromId,toId]);
-					}
-				}
-				var result = [];
-				result.push(result_tmp)
-				return result;
-			};
-
-			Graph.number = function(workflow, num) {
-			  num = (typeof num === 'undefined') ? 0 : num;
-			  var toNum = {};
-			  var toNode = [];
-
-			  function setStep(step, nodeId) {
-				if (step in toNode) {
-				  toNode[step].push(nodeId);
-				} else {
-				  toNode[step] = [nodeId];
-				}
-			  }
-
-			  function setNum(nodeId, beg, end) {
-				if (end === undefined) {
-				  num = String(beg);
-				  setStep(beg, nodeId);
-				} else {
-				  num = end + "-" + beg;
-				  setStep(end, nodeId);
-				}
-				if (nodeId in toNum) {
-				  toNum[nodeId] += "," + num;
-				} else {
-				  toNum[nodeId] = num;
-				}
-			  }
-
-			  function _number(wks, num) {
-				var ret = 0;
-				if (wks instanceof Array) {
-				  if (wks.length === 0) {
-					ret = num;
-				  } else if (wks.length === 1) {
-					ret = _number(wks[0], num);
-				  } else {
-					var head = wks[0];
-					var tail = wks.slice(1);
-					var beg = _number(head, num);
-					if (tail[0] instanceof Array) {
-					  var end = _number(tail[0], beg);
-					  setNum(head, beg, end);
-					  beg = end + 1;
-					  tail.shift();
-					}
-					ret = _number(tail, beg);
-				  }
-				} else if ((wks instanceof Object) && 'parallel' in wks) {
-				  var nums = wks.parallel.map(function(branch) {
-					return _number(branch, num);
-				  });
-				  ret = Math.max.apply(null, nums);
-				} else {
-				  setNum(wks, num);
-				  ret = num + 1;
-				}
-				return ret;
-			  }
-
-			  _number(workflow, num);
-			  // console.log('toNodes=', JSON.stringify(toNode));
-			  // console.log('toNum=',JSON.stringify(toNum));
-			  return {toNum: toNum, toNode: toNode};
-			};
-
-			//aigner: New numbering for the workflow nodes
-			Graph.new_number = function(workflow, num) {
-				num = (typeof num === 'undefined') ? 0 : num;
-				var toNum = {};
-				var toNode = [];
-				
-				for (var i=0; i < workflow.length; i++)
-				{
-					//aigner: Number the nodes with respect to the defined process steps
-					//--> toNum
-					//##########################################
-					for (var j=0; j < workflow[i].process_step_blocks.length; j++)
-					{
-						var proc_id_to = workflow[i].process_step_blocks[j];
-						if (proc_id_to)
-						{
-
-							if (!toNum[proc_id_to])
-							{
-								toNum[proc_id_to] = workflow[i].step_number;
-							}
-							else
-							{
-								toNum[proc_id_to] += "," + workflow[i].step_number;
-							}
-						}
-					}
-					for (var j=0; j < workflow[i].converger_step_blocks.length; j++)
-					{
-						var conv_id_to = workflow[i].converger_step_blocks[j];
-						if (conv_id_to)
-						{
-							toNum[conv_id_to] += "," + workflow[i].step_number;
-							var stepID = parseInt(toNum[conv_id_to].split(',')[0])+1;
-							//aigner: CAUTION hard coded exception for coordinator
-							if (conv_id_to!="Coordinator"){toNum[conv_id_to] += "-" + stepID;}
-						}
-					}
-					//##########################################		
-					//--> toNode
-					//##########################################
-					var stepNumber = workflow[i].step_number
-					var nodeId;
-					if (stepNumber==0){nodeId = [workflow[i].process_step_blocks[0]];}
-					else
-					{
-						var nodeIds = [];
-						for (var j=0; j<workflow[i].edges.length ;j++)
-						{
-							nodeIds.push(workflow[i].edges[j][1]);
-						}
-						nodeId = nodeIds;
-					}
-					toNode[stepNumber] = nodeId;
-					//##########################################
-				}	
-				return {toNum: toNum, toNode: toNode};
-			};
-
-			module.exports = Graph;
-
-			},{}],4:[function(require,module,exports){
-			function Labelizer() {}
-
-			Labelizer.strParse = function(str) {
-			  if (str === "") {
-				return [{base: '', sub: undefined, sup: undefined}];
-			  }
-
-			  //console.log("STR")
-			  //console.log(str);
-			  //aigner: Space sign added
-			  var lstr = str.split(',');
-			  var underscores = /_/g;
-			  var rg = /([0-9\-]+: )?([A-Za-z0-9\{\}\(\)\[\]\-\.]+)(_[A-Za-z0-9\-\._]+)?(\^.+)?/;
-
-			  var res = lstr.map(function(s) {
-				var base;
-				var sub;
-				var sup;
-				
-				//aigner: Modification. xpath is split after each "/"
-				var s_split = s.split("/");
-				s = s_split[s_split.length-1];
-
-				if ((s.match(underscores) || []).length > 1) {
-				  var mu = s.match(/(.+)^(.+)/);
-				  if (mu) {
-					return {base: mu[1], sub: undefined, sup: mu[2]};
-				  }
-				  return {base: s, sub: undefined, sup: undefined};
-				}
-				var m = s.match(rg);
-				if (m) {
-				  base = (m[1] ? m[1] : "") + m[2];
-				  if (m[3]) {
-					sub = m[3].substring(1);
-				  }
-				  if (m[4]) {
-					sup = m[4].substring(1);
-				  }
-				} else {
-				  throw new Error("Labelizer.strParse: Can not parse '" + s + "'");
-				}
-				return {base: base, sub: sub, sup: sup};
-			  }, this);
-			 
-			  return res;
-			};
-
-			Labelizer.labelize = function() {
-			  var ellipsis = 0;
-
-			  //aigner: createLabel modified. Hide variable names if too long.
-			  function createLabel(selection) 
-			  {
-				selection.each(function(d) {
-					//console.log("Labelize-->");
-					//console.log(d);
-				  var tokens = Labelizer.strParse(d.name);
-				  var text = selection.append("text");
-
-				  var className = selection._groups[0][0].getAttribute("class");
-
-				  if (className.includes("node"))
-				  {
-					tokens.every(function(token, i, ary)
-					{
-						var offsetSub = 0;
-						var offsetSup = 0;
-						//aigner: If the node is too big, it will not be shown at first, only when hovering
-						if (ellipsis < 1 || i < 15) 
-						{
-							text.append("tspan").text(token.base);
-							if (token.sub) 
-							{
-							offsetSub = 10;
-							text.append("tspan")
-							  .attr("class", "sub")
-							  .attr("dy", offsetSub)
-							  .text(token.sub);
-							}
-							if (token.sup) {
-								offsetSup = -10;
-								text.append("tspan")
-								  .attr("class", "sup")
-								  .attr("dx", -5)
-								  .attr("dy", -offsetSub + offsetSup)
-								  .text(token.sup);
-								offsetSub = 0;
-							}
-						} else 
-						{
-							text.append("tspan")
-								.attr("dy", -offsetSub - offsetSup)
-								.text("...");
-							selection.classed("ellipsized", true);
-							return false;
-						}
-						if (i < ary.length - 1) 
-						{
-							  text.append("tspan")
-								.attr("dy", -offsetSub - offsetSup)
-								.text(", ");
-						}
-						return true;
-					}, this);
-				  }
-				  else if(className.includes("edge"))
-				  {	  
-						var offsetSub = 0;
-						var offsetSup = 0;
-						//aigner: If there are more than 5 variables in an edge, they are not shown!
-						tokens.every(function(token, i, ary)
-						{           			
-							if(d.io.fromU || d.from =="Coordinator"){text_tmp = "inp."}
-							else if(d.io.toU || d.to=="Coordinator"){text_tmp = "outp."}
-							else{text_tmp = "conn."}
-							//if (ary.length>1){text_tmp = text_tmp+"s"};
-							text.append("tspan")
-							.attr("dy", -offsetSub - offsetSup)
-							.text(ary.length + " " + text_tmp);                    
-							
-							selection.classed("ellipsized", true);
-							return false;
-						}, this);
-				  }
-				});
-			  }
-
-			  createLabel.ellipsis = function(value) {  
-				if (!arguments.length) {
-				  return ellipsis;
-				}
-				ellipsis = value;
-				return createLabel;
-			  };
-
-			  return createLabel;
-			};
-
-			Labelizer.tooltipize = function() {
-			  var text = "";
-
-			  function createTooltip(selection) {
-				var tokens = Labelizer.strParse(text);
-				var html = [];
-				tokens.forEach(function(token) {
-				  var item = token.base;
-				  if (token.sub) {
-					item += "<sub>" + token.sub + "</sub>";
-				  }
-				  if (token.sup) {
-					item += "<sup>" + token.sup + "</sup>";
-				  }
-				  html.push(item);
-				}, this);
-				selection.html(html.join(", "));
-			  }
-
-			  createTooltip.text = function(value) {
-				if (!arguments.length) {
-				  return text;
-				}
-				text = value;
-				return createTooltip;
-			  };
-
-			  return createTooltip;
-			};
-
-			module.exports = Labelizer;
-
-			},{}],5:[function(require,module,exports){
-			var d3 = require('d3');
-			var Labelizer = require('./labelizer.js');
-
-			var WIDTH = 1000;
-			var HEIGHT = 500;
-			var X_ORIG = 70;
-			var Y_ORIG = 20;
-			var PADDING = 20;
-			var CELL_W = 250;
-			var CELL_H = 75;
-			var MULTI_OFFSET = 3;
-
-			function Cell(x, y, width, height) {
-			  this.x = x;
-			  this.y = y;
-			  this.width = width;
-			  this.height = height;
-			}
-
-			function Xdsm(graph, svgid, tooltip) {
-			  this.graph = graph;
-			  this.tooltip = tooltip;
-			  this.svg = d3.select(".xdsm")
-						   .append("svg")
-						 .attr("width", WIDTH)
-						 .attr("height", HEIGHT)
-						 .attr("class", svgid);
-
-			  this.grid = [];
-			  this.nodes = [];
-			  this.edges = [];
-			}
-
-			Xdsm.prototype.draw = function(graphName) {
-			  var self = this;
-
-			  if (self.graph.refname) {
-				var ref = self.svg.append('g').classed('title', true);
-
-				var text_tmp = self.graph.refname.replace(/\w/g, function(l){ return l.toUpperCase() })
-					
-				//ref.append("text").text(graphName);
-				var bbox = ref.nodes()[0].getBBox();
-				ref.insert("rect", "text")
-					.attr('x', bbox.x)
-					.attr('y', bbox.y)
-					.attr('width', bbox.width)
-					.attr('height', bbox.height);
-
-				ref.attr('transform',
-						 'translate(' + X_ORIG + ',' + (Y_ORIG + bbox.height-10) + ')');
-			  }
-
-			  self.nodes = self._createTextGroup("node");
-			  self.edges = self._createTextGroup("edge");
-
-			  // Workflow
-			  self._createWorkflow();
-
-			  // Layout texts
-			  self._layoutText(self.nodes);
-			  self._layoutText(self.edges);
-
-			  // Rectangles for nodes
-			  self.nodes.each(function(d, i) {
-				var that = d3.select(this);
-				that.call(self._customRect.bind(self), d, i, 0);
-				if (d.isMulti) {
-				  that.call(self._customRect.bind(self), d, i, 1 * Number(MULTI_OFFSET));
-				  that.call(self._customRect.bind(self), d, i, 2 * Number(MULTI_OFFSET));
-				}
-			  });
-
-			  // Trapezium for edges
-			  self.edges.each(function(d, i) {
-				var that = d3.select(this);
-				that.call(self._customTrapz.bind(self), d, i, 0);
-				if (d.isMulti) {
-				  that.call(self._customTrapz.bind(self), d, i, 1 * Number(MULTI_OFFSET));
-				  that.call(self._customTrapz.bind(self), d, i, 2 * Number(MULTI_OFFSET));
-				}
-			  });
-
-			  // Dataflow
-			  self._createDataflow(self.edges);
-				
-			  //aigner: set svg size
-			  var w = CELL_W * (self.graph.nodes.length + 1);
-			  var h = CELL_H * (self.graph.nodes.length + 1);
-			  self.svg.attr("width", w).attr("height", h);
-
-			  var bordercolor = 'black';
-			  self.svg.append("rect")
-						.classed("border", true)
-						.attr("x", 4)
-						.attr("y", 4)
-						.attr("height", h - 4)
-						.attr("width", w - 4)
-						.style("stroke", bordercolor)
-						.style("fill", "none")
-						.style("stroke-width", 0);
-						
-			  //aigner: PlayButton for animation
-			  var playButton = self.svg.append("g").attr("class", "playButton")
-				  .attr("transform", "translate("+ 10 +","+ 10 +")")
-				  
-			  playButton
-				.append("rect")
-				  .attr("class", "playButton_rect")
-				  .attr("width", 50)
-				  .attr("height", 50)
-				  .attr("rx", 4)
-				  .style("fill", "#555555");
-				  
-			  playButton
-				.append("path")
-				  .attr("class", "playButton_triangle")
-				  .attr("d", "M15 10 L15 40 L35 25 Z")
-				  .style("fill", "white");
-				  
-			  playButton.append("text")
-				  .attr("y",20)
-				  .attr("x",60)
-				  .text("Play Workflow")
-
-			  //aigner: Hide playbutton if there is no workflow process
-			  if(self.graph.nodesByStep.length<1)
-			  {
-				  playButton.attr("visibility","hidden")
-			  }
-			  playButton.append("svg:title").text("Click to play workflow");
-			};
-
-			Xdsm.prototype._createTextGroup = function(kind) {
-			  var self = this;
-
-			  var group = self.svg.append('g').attr("class", kind + "s");
-
-			  var textGroups =
-				group.selectAll("." + kind)
-				  .data(this.graph[kind + "s"])
-				.enter()
-				  .append("g").attr("class", function(d) {
-					var klass = kind === "node" ? d.type : "dataInter";
-					if (klass === "dataInter" && (d.isIO()||d.from=="Coordinator"||d.to=="Coordinator")) {
-					  klass = "dataIO";
-					}
-					return d.id + " " + kind + " " + klass;
-				  }).each(function() {
-					var labelize = Labelizer.labelize().ellipsis(5);
-					d3.select(this).call(labelize);
-				  });
-
-			  d3.selectAll(".ellipsized")
-				.on("mouseover", function(d) {
-					d3.select(this).style("cursor", "pointer")
-					self.tooltip.transition().duration(200).style("opacity", 0.9);
-					var pipeData = d.name.split(",");
-					var pipeVariables=[];
-					for (var i=0; i<pipeData.length; i++)
-					{
-						if (pipeData[i].includes("/"))
-						{
-							var splitPipeData = pipeData[i].split("/");
-							pipeVariables.push(splitPipeData[splitPipeData.length-1]);
-						}
-					}
-					
-
-					var pruned_pipeVars = {};
-					var tooltipText="";
-					pipeVariables.forEach(function(x) { pruned_pipeVars[x] = (pruned_pipeVars[x] || 0)+1; });
-					for(var keyName in pruned_pipeVars) {
-						var textTmp;
-						var value = pruned_pipeVars[keyName]
-						if (value>1){textTmp = String(keyName+"("+value+")")}
-						else{textTmp=String(keyName)}
-						if (tooltipText==""){tooltipText+=textTmp}
-						else{tooltipText+=","+textTmp}
-					}
-					
-					var tooltipize = Labelizer.tooltipize().text(tooltipText);
-					self.tooltip.call(tooltipize)
-					  .style("width", "200px")
-					  .style("left", (d3.event.pageX) + "px")
-					  .style("top", (d3.event.pageY - 28) + "px");
-				})
-				.on("mouseout", function() {
-					self.tooltip.transition().duration(500).style("opacity", 0);
-				});
-
-			  return textGroups;
-			};
-
-			Xdsm.prototype._createWorkflow = function() {
-			  //  console.log(JSON.stringify(this.graph.chains));
-			  var workflow = this.svg.insert("g", ":first-child")
-								.attr("class", "workflow");
-			  workflow.selectAll("g")
-				.data(this.graph.chains)
-			  .enter()
-				.insert('g').attr("class", "workflow-chain")
-				.selectAll('polyline')
-				  .data(function(d) { return d; })  // eslint-disable-line brace-style
-				.enter()
-				  .append("polyline")
-					.attr("class", function(d) {
-					  return "link_" + d[0] + "_" + d[1];
-					})
-					.attr("points", function(d) {
-					  var w = CELL_W * Math.abs(d[0] - d[1]);
-					  var h = CELL_H * Math.abs(d[0] - d[1]);
-					  var points = [];
-					  if (d[0] < d[1]) {
-						if (d[0] !== 0) {
-						  points.push((-w) + ",0");
-						}
-						points.push("0,0");
-						if (d[1] !== 0) {
-						  points.push("0," + h);
-						}
-					  } else {
-						if (d[0] !== 0) {
-						  points.push(w + ",0");
-						}
-						points.push("0,0");
-						if (d[1] !== 0) {
-						  points.push("0," + (-h));
-						}
-					  }
-					  return points.join(" ");
-					})
-				  .attr("transform", function(d) {
-					var max = Math.max(d[0], d[1]);
-					var min = Math.min(d[0], d[1]);
-					var w;
-					var h;
-					if (d[0] < d[1]) {
-					  w = CELL_W * max + X_ORIG;
-					  h = CELL_H * min + Y_ORIG;
-					} else {
-					  w = CELL_W * min + X_ORIG;
-					  h = CELL_H * max + Y_ORIG;
-					}
-					return "translate(" + (X_ORIG + w) + "," + (Y_ORIG + h) + ")";
-				  });
-			};
-
-			Xdsm.prototype._createDataflow = function(edges) {
-			  var dataflow = this.svg.insert("g", ":first-child")
-							   .attr("class", "dataflow");
-
-			  edges.each(function(d, i) {
-				dataflow.insert("polyline", ":first-child")
-				  .attr("points", function() {
-					var w = CELL_W * Math.abs(d.col - d.row);
-					var h = CELL_H * Math.abs(d.col - d.row);
-					var points = [];
-					if (d.iotype === "in") {
-					  if (!d.io.fromU) {
-						points.push((-w) + ",0");
-					  }
-					  points.push("0,0");
-					  if (!d.io.toU) {
-						points.push("0," + h);
-					  }
-					} else {
-					  if (!d.io.fromU) {
-						points.push(w + ",0");
-					  }
-					  points.push("0,0");
-					  if (!d.io.toU) {
-						points.push("0," + (-h));
-					  }
-					}
-					return points.join(" ");
-				  }).attr("transform", function() {
-					var m = (d.col === undefined) ? i : d.col;
-					var n = (d.row === undefined) ? i : d.row;
-					var w = CELL_W * m + X_ORIG;
-					var h = CELL_H * n + Y_ORIG;
-					return "translate(" + (X_ORIG + w) + "," + (Y_ORIG + h) + ")";
-				  });
-			  });
-			};
-
-			Xdsm.prototype._layoutText = function(items) {
-			  var grid = this.grid;
-			  items.each(function(d, i) {
-				var item = d3.select(this);
-				if (grid[i] === undefined) {
-				  grid[i] = new Array(items.length);
-				}
-				item.select("text").each(function(d, j) {
-				  var that = d3.select(this);
-				  var data = item.data()[0];
-				  var m = (data.row === undefined) ? i : data.row;
-				  var n = (data.col === undefined) ? i : data.col;
-				  var bbox = that.nodes()[j].getBBox();
-				  grid[m][n] = new Cell(-bbox.width / 2, 0, bbox.width, bbox.height);
-				  that.attr("x", function() {
-					return grid[m][n].x;
-				  }).attr("y", function() {
-					return grid[m][n].y;
-				  }).attr("width", function() {
-					return grid[m][n].width;
-				  }).attr("height", function() {
-					return grid[m][n].height;
-				  });
-				});
-			  });
-
-			  items.attr("transform", function(d, i) {
-				var m = (d.col === undefined) ? i : d.col;
-				var n = (d.row === undefined) ? i : d.row;
-				var w = CELL_W * m + X_ORIG;
-				var h = CELL_H * n + Y_ORIG;
-				return "translate(" + (X_ORIG + w) + "," + (Y_ORIG + h) + ")";
-			  });
-			};
-
-			Xdsm.prototype._customRect = function(node, d, i, offset) {
-			  var grid = this.grid;
-			  node.insert("rect", ":first-child").attr("x", function() {
-				return grid[i][i].x + offset - PADDING;
-			  }).attr("y", function() {
-				return -grid[i][i].height * 2 / 3 - PADDING - offset;
-			  }).attr("width", function() {
-				return grid[i][i].width + (PADDING * 2);
-			  }).attr("height", function() {
-				return grid[i][i].height + (PADDING * 2);
-			  }).attr("rx", function() {
-				var rounded = d.type === 'optimization' ||
-							  d.type === 'mda' ||
-							  d.type === 'doe' ||
-							  d.type === 'converger';
-				return rounded ? (grid[i][i].height + (PADDING * 2)) / 2 : 0;
-			  }).attr("ry", function() {
-				var rounded = d.type === 'optimization' ||
-							  d.type === 'mda' ||
-							  d.type === 'doe' ||
-							  d.type === 'converger';
-				return rounded ? (grid[i][i].height + (PADDING * 2)) / 2 : 0;
-			  });
-			};
-
-			Xdsm.prototype._customTrapz = function(edge, d, i, offset) {
-			  var grid = this.grid;
-			  edge.insert("polygon", ":first-child").attr("points", function(d) {
-				var pad = 5;
-				var w = grid[d.row][d.col].width;
-				var h = grid[d.row][d.col].height;
-				var topleft = (-pad - w / 2 + offset) + ", " +
-							  (-pad - h * 2 / 3 - offset);
-				var topright = (w / 2 + pad + offset + 5) + ", " +
-							   (-pad - h * 2 / 3 - offset);
-				var botright = (w / 2 + pad + offset - 5 + 5) + ", " +
-							   (pad + h / 3 - offset);
-				var botleft = (-pad - w / 2 + offset - 5) + ", " +
-							  (pad + h / 3 - offset);
-				var tpz = [topleft, topright, botright, botleft].join(" ");
-				return tpz;
-			  });
-			};
-
-			module.exports = Xdsm;
-
-			},{"./labelizer.js":4,"d3":1}],6:[function(require,module,exports){
-			/*
-			 * XDSMjs
-			 * Copyright 2016 Rémi Lafage
-			 */
-			"use strict";
-
-
-
-
-			var d3 = require('d3');
-			var Graph = require('./src/graph');
-			var Xdsm = require('./src/xdsm');
-			var Animation = require('./src/animation');
-
-
-			//aigner: NEW!
-			//#####################################################################//
-			//aigner: functions for drawing expand- and collapse-symbols
-			function drawExpandSymbol(aCircle, line1, line2)
-			{        
-				 aCircle = aCircle
-					.attr("r", 10)
-					.style("stroke", "black")
-					.style("stroke-width", 2)
-					.style("fill", "#99CC00")
-					.style("fill-opacity", .6)
-				line1 = line1
-					.attr("x1", parseFloat(aCircle.attr("cx"))-5)
-					.attr("y1", parseFloat(aCircle.attr("cy")))
-					.attr("x2", parseFloat(aCircle.attr("cx"))+5)
-					.attr("y2", parseFloat(aCircle.attr("cy")))
-					.style("stroke", "black")
-					.style("stroke-width", 2);
-				line2 = line2
-					.attr("x1", parseFloat(aCircle.attr("cx")))
-					.attr("y1", parseFloat(aCircle.attr("cy"))-5)
-					.attr("x2", parseFloat(aCircle.attr("cx")))
-					.attr("y2", parseFloat(aCircle.attr("cy"))+5)
-					.style("stroke", "black")
-					.style("stroke-width", 2);
-			}
-			function drawRemoveSymbol(anXdsm, aCircle, aMinus)
-			{        
-				 var xOffset=150;
-				 var yOffset=12;
-				 aCircle = aCircle
-					.attr("cx", anXdsm.svg.attr("width")-xOffset)
-					.attr("cy", yOffset)
-					.attr("r", 10)
-					.classed("remCircle",true)
-				aMinus = aMinus
-					.attr("x1", anXdsm.svg.attr("width")-xOffset+5)
-					.attr("y1", yOffset)
-					.attr("x2", anXdsm.svg.attr("width")-xOffset-5)
-					.attr("y2", yOffset)
-					.classed("remMinus",true)
-			}
-			function drawTreeRemoveSymbol(aRemoveSymbol)
-			{
-				aRemoveSymbol = aRemoveSymbol
-					.attr("class", "treeRemoveSymbol")
-					.attr("transform", "translate(38,12)")
-				var circle = aRemoveSymbol.append("circle");
-				var minus = aRemoveSymbol.append("line");
-				var cx = -20;
-				var cy = 12;
-				circle = circle
-					.attr("cx", cx+5)
-					.attr("cy", cy)
-					.attr("r", 10)
-					.classed("remCircle",true)
-				minus = minus
-					.attr("x1", cx)
-					.attr("y1", cy)
-					.attr("x2", cx+10)
-					.attr("y2", cy)
-					.classed("remMinus",true)
-				aRemoveSymbol
-					.on("mouseover", function(){
-						d3.select(this).style("cursor", "pointer")
-						circle.style("fill", "red").style("fill-opacity", .8);
-						})
-					.on("mouseout", function(){circle.style("fill", "red").style("fill-opacity", .6)})
-			}
-
-			//aigner: Update of the sub workflows
-			function update_subXdsm(xdsms, refName)
-			{
-				var playButton = d3.select(".xdsm").select("."+refName).select(".playButton");
-				var rect = playButton.select(".playButton_rect");
-				playButton.on("mouseover",function(){
-						d3.select(this).style("cursor", "pointer")
-						rect.style("fill","#3399FF");
-					})
-					.on("mousedown", function()
-					{
-						rect.style("fill","#3399FF");
-						var anim = new Animation(xdsms, refName);
-						anim.run();
-					})
-					.on("mouseup", function(){rect.style("fill","#4B4B4B");})
-					.on("mouseout", function(){rect.style("fill","#555555");})
-			}
-            
-            //aigner: Move to front function
-			d3.selection.prototype.moveToFront = function() {  
-			  return this.each(function(){
-				this.parentNode.appendChild(this);
-			  });
-			};
-
-			//d3-context-menu for right-click-option
-			d3.contextMenu = function (menu, openCallback) {
-
-				// create the div element that will hold the context menu
-				d3.selectAll('.d3-context-menu').data([1])
-					.enter()
-					.append('div')
-					.attr('class', 'd3-context-menu');
-
-				// close menu
-				d3.select('body').on('click.d3-context-menu', function() {
-					d3.select('.d3-context-menu').style('display', 'none');
-				});
-
-				// this gets executed when a contextmenu event occurs
-				return function(data, index) {	
-					var elm = this;
-
-					d3.selectAll('.d3-context-menu').html('');
-					var list = d3.selectAll('.d3-context-menu').append('ul');
-						list.selectAll('li').data(menu).enter()
-						.append('li')
-						.html(function(d) {
-							return d.title;
-						})
-						.on('mousedown', function(d, i) {
-							d.onMouseDown(elm, data, index);
-						})
-						.on('mouseup', function(d, i) {
-							d.onMouseUp(elm, data, index);
-							d3.select('.d3-context-menu').style('display', 'none');
-						})
-						.on('mouseenter',function(d,i){
-							d.onMouseOver(elm,data,index);
-							if(d.childrenItems.length>0 )
-								 {
-                                  var li = this
-								  d3.select(this).selectAll("ul").remove(); 
-								  d3.select(this)
-									.append("ul")
-                                    .style("top",String(li.offsetTop-5)+"px")
-									.selectAll("li")
-									   .data(d.childrenItems)
-										.enter().append("li")
-										  .text(function(d) { return d.title; })
-									 .on("mouseenter", function(d,i){
-											d.onMouseOver(elm,data,index);
-										})
-									 .on('click',  function(d, i) {
-											d.onMouseClick(elm, d, index);
-										})
-									 .on('mouseleave',function(d,i){
-										
-										});
-								 }
-							 else
-								 return false;
-						})
-						.on('mouseleave',function(d,i){
-							d3.select(this).selectAll("ul").style('display', 'none')                  
-						});
-					
-					  
-
-					// the openCallback allows an action to fire before the menu is displayed
-					// an example usage would be closing a tooltip
-					if (openCallback) openCallback(data, index);
-
-					// display context menu
-					d3.select('.d3-context-menu')
-						.style('left', (d3.event.pageX - 2) + 'px')
-						.style('top', (d3.event.pageY - 2) + 'px')
-						.style('display', 'block');
-                    
-                    //Prevent the default event, which is the left-click. 
-                    //This means, the context-menu will only appear on right mouse clicks
-					d3.event.preventDefault();
-                    
-                    //Place context-menu always on top of everything esle
-                    d3.select(".d3-context-menu").style("z-index",Number.MAX_SAFE_INTEGER);
-				};
-			};
-			
-
-			//aigner: Function creates a table
-			function tabulate(aTable,data,columns) {
-				var thead = aTable.append('thead');
-				var	tbody = aTable.append('tbody');  
-
-				// create a row for each object in the data
-				var rows = tbody.selectAll('tr')
-				  .data(data)
-				  .enter()
-				  .append('tr');
-
-				// create a cell in each row for each column
-				var cells = rows.selectAll('td')
-				  .data(function (row) {
-					return columns.map(function (column) {
-					  return {column: column, value: row[column]};
-					});
-				  })
-				  .enter()
-				  .append('td')
-					.html(function (d) { return d.value; });
-
-				return aTable;
-			}
-
-			function loader(config) {
-			  return function() {
-				var radius = Math.min(config.width, config.height) / 2;
-				var tau = 2 * Math.PI;
-
-				var arc = d3.svg.arc()
-						.innerRadius(radius*0.5)
-						.outerRadius(radius*0.9)
-						.startAngle(0);
-
-				var svg = d3.select(config.container).append("svg")
-					.attr("id", config.id)
-					.attr("width", config.width)
-					.attr("height", config.height)
-				  .append("g")
-					.attr("transform", "translate(" + config.width / 2 + "," + config.height / 2 + ")")
-
-				var background = svg.append("path")
-						.datum({endAngle: 0.33*tau})
-						.style("fill", "#4D4D4D")
-						.attr("d", arc)
-						.call(spin, 1500)
-
-				function spin(selection, duration) {
-					selection.transition()
-						.ease("linear")
-						.duration(duration)
-						.attrTween("transform", function() {
-							return d3.interpolateString("rotate(0)", "rotate(360)");
-						});
-
-					setTimeout(function() { spin(selection, duration); }, duration);
-				}
-
-				function transitionFunction(path) {
-					path.transition()
-						.duration(7500)
-						.attrTween("stroke-dasharray", tweenDash)
-						.each("end", function() { d3.select(this).call(transition); });
-				}
-
-			  };
-			}
-
-
-			var myLoader = loader({width: 960, height: 500, container: "#loader_container", id: "loader"});
-			
-			//aigner: NEW!
-			//aigner: Here, the data is read and the XDSM is created
-			//#####################################################################//
-			function startXDSM(data, graphID) 
-			{	
-				//Highlight function, that shows usage of a node in the XDSM
-				function highlight(data)
-				{
-					var xPath = data.data.xPath;
-					
-                    scenarioKeys.forEach(function(k)
-                    {
-                        var xdsm_tmp;
-                        xdsm_tmp = xdsms[k];
-                        if (xdsm_tmp)
-                        {
-                            xdsm_tmp.svg.selectAll(".edge").each(function(p) 
-                            {
-                                var firstElement_tmp = p.name.split("/")[1]
-                                var xPath_fromFirst = "/"+firstElement_tmp+xPath.split(firstElement_tmp)[1]
-                                var this_edge  = this
-                                var p_name_list = p.name.split(",")
-                                p_name_list.forEach(function(p_name) 
-                                {
-                                    if (include(p_name+"__",xPath_fromFirst+"__") || include(p_name,xPath_fromFirst+"/"))
-                                    {
-                                        var highlightEdge = d3.select(this_edge).select("polygon");
-                                        highlightEdge
-                                            .style("stroke-width",5.)
-                                            .style("stroke","#CC0000")
-                                        d3.selectAll(".treeFrame")
-                                            .attr("fill-opacity", 0.5)
-                                            .attr("stroke-opacity", 0.5);
-                                        d3.selectAll(".nodeText").style("fill-opacity",0.5);
-                                    }
-                                })
-                            })
-                        }
-                    })
-					
-				}
-				
-				//Unhighlight function again
-				function unhighlight(data)
-				{
-					var xPath = data.data.xPath;
-					
-                    scenarioKeys.forEach(function(k)
-                    {
-                        var xdsm_tmp;
-                        xdsm_tmp = xdsms[k];
-                        if (xdsm_tmp)
-                        {
-                            xdsm_tmp.svg.selectAll(".edge").each(function(p) 
-                            {
-                                var firstElement_tmp = p.name.split("/")[1]
-                                var xPath_fromFirst = "/"+firstElement_tmp+xPath.split(firstElement_tmp)[1]
-                                var this_edge  = this
-                                var p_name_list = p.name.split(",")
-                                p_name_list.forEach(function(p_name) 
-                                {
-                                    if (include(p_name+"__",xPath_fromFirst+"__") || include(p_name,xPath_fromFirst+"/"))
-                                    {
-                                        var highlightEdge = d3.select(this_edge).select("polygon");
-                                        highlightEdge
-                                            .style("stroke-width",1.)
-                                            .style("stroke","black");
-                                        d3.selectAll(".treeFrame")
-                                            .attr("fill-opacity", 0.8)
-                                            .attr("stroke-opacity", 0.8);
-                                        d3.selectAll(".nodeText").style("fill-opacity",1);
-                                    }
-                                })
-                            })
-                        }
-                    })
-					
-				}							
-				  
-				
-				function showVariableTable(aVariable)
-				{						
-					var headLine = "Node Information (" + aVariable.data.name + ")";
-					var data = [];
-					// render the table(s)
-					data.push({ "name" : "Name", "value" : "\""+aVariable.data.name+"\"" })
-					data.push({ "name" : "xPath", "value" : aVariable.data.xPath })
-					if (aVariable.data.type){data.push({ "name" : "Type", "value" : aVariable.data.type })}
-					if (aVariable.data.level){data.push({ "name" : "Level", "value" : aVariable.data.level })}
-					if (aVariable.data.children){data.push({ "name" : "Number of children", "value" : aVariable.data.children.length })}
-					if (aVariable.data.dimension){data.push({ "name" : "Dimension", "value" : aVariable.data.dimension })}
-					else if(aVariable.data.dimension===null){data.push({ "name" : "Dimension", "value" : "undefined" })}
-					if (aVariable.data.value){data.push({ "name" : "Value(s)", "value" : aVariable.data.value })}
-					
-					var d3_body = d3.select("body");
-					
-					var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-					panel_div.append("div").attr("class","panel-heading")
-						.append("div").attr("class","panel_title").append("h4").text(headLine)
-					var listGroup = panel_div.append("div").attr("class","panel-body")
-						.append("table").attr("id","myTable")
-						.append("tbody")
-						
-					data.forEach(function(listElement)
-					{
-						var row = listGroup.append("tr")
-						row.append("td").text(listElement.name)
-						row.append("td").text(listElement.value)
-						
-					})
-					$('.myPanel').lobiPanel({
-						reload: false,
-						editTitle: false,
-						expand: false,
-						unpin: false,
-						resize: "none",
-						minWidth: 200,
-						minHeight: 200,
-						maxWidth: 1100,
-						maxHeight: 1200,
-					});
-					$('.myPanel').lobiPanel('unpin');
-				}
-				
-                var markedVariables = [];
-				function preMarkVariable(variableData)
-                {
-                    markedVariables.push(variableData)
-                }
-                
-                function markVariable(variableData_arr)
-				{
-					d3.select('.d3-context-menu').style('display', 'none');    
-                 
-                    //Stringify variable data before sending it to kadmos
-                    var variableData_str = JSON.stringify(variableData_arr)
-                    
-					var bootboxContent = {title: 'Assign parameter roles', message: '<p>Please be patient...</p>'};
-					var xhr = $.ajax({
-						type: 'POST',
-						url: '/kadmos_mark_variable',
-							data: {
-							'graphID':graphID, 
-							'sessionID':sessionID, 
-							'variableData_str':variableData_str,
-							'currentOrder':nodeOrder
-						},
-						success: function(result)
-						{
-							if (result.includes("ERROR:"))
-							{
-								bootboxContent.message = result
-								kadmosErrorMessage(bootboxContent);
-							}
-							else
-							{
-								var updatedData = {};
-								updatedData = data;
-								var graphData = JSON.parse(result);             
-								for (var i = 0; i < updatedData.graphs.length; i++)
-								{
-									if (graphID == updatedData.graphs[i].id)
-									{
-										updatedData.graphs[i] = graphData.graphs[0];   
-									}
-								}
-																			
-								clearView();
-								makeKadmosMenu(updatedData);
-								xdsm_script(updatedData,graphID);
-								
-								bootboxContent.message = "Success!"
-								kadmosSuccessMessage(bootboxContent)
-							}
-						},
-						error: function(result)
-						{
-							bootboxContent.message = result
-							kadmosErrorMessage(bootboxContent);
-						}
-					});
-					kadmosHavePatience(xhr, bootboxContent)
-				}
-				
-				function unmarkVariable(xPath)
-				{
-					d3.select('.d3-context-menu').style('display', 'none');                                
-					
-					var bootboxContent = {title: 'Unmarking variable<p>Please be patient...</p>'};
-					var xhr = $.ajax({
-						type: 'POST',
-						url: '/kadmos_unmark_variable',
-							data: {
-							'graphID':graphID, 
-							'sessionID':sessionID, 
-							'xPath':xPath, 
-							'currentOrder':nodeOrder
-						},
-						success: function(result)
-						{
-							if (result.includes("ERROR:"))
-							{
-								bootboxContent.message = result
-								kadmosErrorMessage(bootboxContent);
-							}
-							else
-							{
-								var updatedData = {};
-								updatedData = data;
-								var graphData = JSON.parse(result);             
-								for (var i = 0; i < updatedData.graphs.length; i++)
-								{
-									if (graphID == updatedData.graphs[i].id)
-									{
-										updatedData.graphs[i] = graphData.graphs[0];   
-									}
-								}
-																			
-								clearView();
-								makeKadmosMenu(updatedData);
-								xdsm_script(updatedData,graphID);
-								
-								bootboxContent.message = "Success!"
-								kadmosSuccessMessage(bootboxContent)
-							}
-						},
-						error: function(result)
-						{
-							bootboxContent.message = result
-							kadmosErrorMessage(bootboxContent);
-						}
-					});
-					kadmosHavePatience(xhr, bootboxContent)
-				}
-				
-				//aigner: Marking variables as ... in KADMOS
-				var markingOptions = [
-					{  
-						title: 'design variable',
-						onMouseClick: function(elm, d, i) {
-							var theVariableData = {};
-							theVariableData.variableType = "designVariable";
-							theVariableData.operator = "";
-							theVariableData.upperBound = 0.;
-							theVariableData.lowerBound = 0.;
-							theVariableData.nominalValue = 0.;
-							
-							bootbox.hideAll();
-							bootbox.confirm({
-							title: 'Marking variable as ' + theVariableData.variableType,
-							message:"<form id='infos' action=''>"
-									+"\Nominal Value: <input type='text' id='nominalValue' name='nominalValue' /><br/>"
-									+"\Upper Bound:   <input type='text' id='upperBound' name='upperBound' /><br/>"
-									+"\Lower Bound:   <input type='text' id='lowerBound' name='lowerBound' />\</form>", 
-							callback: function(result){
-									if(result){
-										theVariableData.nominalValue = $('#nominalValue').submit()[0].value;
-										theVariableData.upperBound = $('#upperBound').submit()[0].value;
-										theVariableData.lowerBound = $('#lowerBound').submit()[0].value;
-                                        
-                                        var firstFromSchema = currentGraph.variableSchemes["schema"][0].xPath.split("/")[1]
-                                        var xPath = "/"+firstFromSchema+elm.__data__.data.xPath.split(firstFromSchema)[1];
-										theVariableData.xPath = xPath;
-										preMarkVariable(theVariableData);
-									}
-								}
-							});
-						},
-						onMouseOver: function(elm,d,i){}
-					},
-					{  
-						title: 'objective',
-						onMouseClick: function(elm, d, i) {
-							var theVariableData = {};
-							theVariableData.variableType = "objective";
-							theVariableData.operator = "";
-							theVariableData.upperBound = 0.;
-							theVariableData.lowerBound = 0.;
-							theVariableData.nominalValue = 0.;
-							var firstFromSchema = currentGraph.variableSchemes["schema"][0].xPath.split("/")[1]
-                            var xPath = "/"+firstFromSchema+elm.__data__.data.xPath.split(firstFromSchema)[1];
-                            theVariableData.xPath = xPath;
-                            preMarkVariable(theVariableData);
-						},
-						onMouseOver: function(elm,d,i){}
-					},
-					{  
-						title: 'constraint',
-						onMouseClick: function(elm, d, i) {
-							var theVariableData = {};
-							theVariableData.variableType = "constraint";
-							theVariableData.operator = "";
-							theVariableData.upperBound = 0.;
-							theVariableData.lowerBound = 0.;
-							theVariableData.nominalValue = 0.;
-							
-							bootbox.hideAll();
-							bootbox.confirm({
-							title: 'Marking variable as ' + theVariableData.variableType,
-							message:"<form id='infos' action=''>"
-									+"\Nominal Value: <input type='text' id='nominalValue' name='nominalValue' /><br/>"
-									+"\Mathematical operator (<, <=, = ,>=, >):   <input type='text' id='operator' name='operator' />\</form>", 
-							callback: function(result){
-									if(result){
-										theVariableData.nominalValue = $('#nominalValue').submit()[0].value;
-										theVariableData.operator = $('#operator').submit()[0].value;
-										var firstFromSchema = currentGraph.variableSchemes["schema"][0].xPath.split("/")[1]
-                                        var xPath = "/"+firstFromSchema+elm.__data__.data.xPath.split(firstFromSchema)[1];
-										theVariableData.xPath = xPath;
-										preMarkVariable(theVariableData);
-									}
-								}
-							});
-						},
-						onMouseOver: function(elm,d,i){}
-					},
-					{  
-						title: 'quantity of interest',
-						onMouseClick: function(elm, d, i) {
-							var theVariableData = {};
-							theVariableData.variableType = "quantityOfInterest";
-							theVariableData.operator = "";
-							theVariableData.upperBound = 0.;
-							theVariableData.lowerBound = 0.;
-							theVariableData.nominalValue = 0.;
-							var firstFromSchema = currentGraph.variableSchemes["schema"][0].xPath.split("/")[1]
-                            var xPath = "/"+firstFromSchema+elm.__data__.data.xPath.split(firstFromSchema)[1];
-                            theVariableData.xPath = xPath;
-                            preMarkVariable(theVariableData);
-						},
-						onMouseOver: function(elm,d,i){}
-					},
-				];
-				
-			   
-				//menu --> functions for right click options
-				var nodeMenu = [
-				{
-					title: 'Show node information',
-					onMouseDown: function(elm, d, i) {
-						showVariableTable(d);
-					},
-					onMouseUp: function(elm, d, i) {},
-					onMouseOver: function(elm, d, i) {},
-					childrenItems: []
-				},
-				{
-					title: 'Show usage of node in XDSM',
-					onMouseDown: function(elm, d, i) {
-						highlight(d);
-					},
-					onMouseUp: function(elm, d, i) {
-						unhighlight(d);
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: []
-				},
-				{
-					title: 'Copy x-path to clipboard',
-					onMouseDown: function(elm, d, i) {
-                        window.prompt("Copy to clipboard: Ctrl+C, Enter", d.data.xPath);
-						d3.select('.d3-context-menu').style('display', 'none');
-					},
-					onMouseUp: function(elm, d, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: []
-				},
-				{ 
-					title: 'Mark variable',
-					onMouseDown: function(elm, d, i) {},
-					onMouseUp: function(elm, d, i) {},
-					onMouseOver: function(elm, d, i) {},
-					childrenItems: markingOptions
-				},
-				{ 
-					title: 'Unmark variable',
-				   onMouseDown: function(elm, d, i) {
-						bootbox.hideAll();
-						bootbox.confirm("Are you sure you want to do this?", function(sure)
-						{
-							if (sure)
-							{
-                                var firstFromSchema = currentGraph.variableSchemes["schema"][0].xPath.split("/")[1]
-                                var xPath = "/"+firstFromSchema+elm.__data__.data.xPath.split(firstFromSchema)[1];
-                                unmarkVariable(xPath)
-                            }
-						})
-					},
-					onMouseUp: function(elm, d, i) {},
-					onMouseOver: function(elm, d, i) {},
-					childrenItems: []
-				}
-				]		
-                
-                
-                
-			   
-				var graphs, currentGraph, varCategories;
-				
-				graphs =  data.graphs;
-				for (var i=0;i<graphs.length;i++)
-				{
-					if (graphs[i].id==graphID)
-					{
-						currentGraph = graphs[i]
-					}
-				}
-				varCategories =  data.categories;
-				
-				//aigner: Get xdsm data
-				var mdo = currentGraph.xdsm;
-				
-				d3.select("body").append("div").attr("class","xdsmDiv")	
-				//################################################################################################//	
-				var headerDiv = d3.select(".xdsmDiv").append("div").attr("class","panel panel-primary")
-				headerDiv.append("div").attr("class","panel-heading text-center")
-					.append("h3")
-					.attr("class","panel-title")
-					.style("font-family","Arial")
-					.style("font-size","20pt")
-					.text("XDSM View")
-				var name_tmp="";
-				if (currentGraph.name){name_tmp=currentGraph.name}
-				else{name_tmp="Graph " + currentGraph.id}
-				headerDiv.append("div").attr("class","panel-body")
-					.style("font-family","Arial")
-					.style("font-size","16pt")
-					.text("Graph name: " + name_tmp)
-				headerDiv.append("div").attr("class","panel-body")
-					.style("font-family","Arial")
-					.style("font-size","16pt")
-					.text("Graph description: " + currentGraph.description)
-				//################################################################################################//	
-				
-                
-                
-                
-                //aigner: Functions for toolMenu
-                //################################################################################################//
-                //aigner: Creation of input/output tree
-                //############################################################
-                function showIOTree(aCategory, categoryDescr, aNode, io)
-                {                        
-                    var edges = d3.selectAll(".edge");
-                    var array="";
-                    var name;
-                    edges.each(function(edge)
-                    {			
-                        if (io=="in")
-                        {
-                            name = "Input tree view: " + aNode.id + "; Categorization: " + categoryDescr;
-                            if (edge.to == aNode.id)
-                            {
-                                array = array + "," + edge.name;
-                            }
-                        }
-                        else if (io=="out")
-                        {
-                            name = "Output tree view:" + aNode.id + "; Categorization: " + categoryDescr;
-                            if (edge.from == aNode.id)
-                            {
-                                array = array + "," + edge.name;
-                            }
-                        }
-                    })
-                    
-                    
-                    var headLine = name;
-                    var d3_body = d3.select("body");
-                    var lobiID = String(getRandomInt(0,1000))
-                    var divClassName = "treeDiv" + lobiID;
-                    var treeLayoutdiv = d3_body.append("div").attr("class",divClassName + " panel-default")
-                                                    .style("left",(d3.event.pageX) + "px")
-                                                    .style("top",(d3.event.pageY - 28) + "px")
-                                                    .style("position", "absolute")
-                    treeLayoutdiv.append("div").attr("class","panel-heading")
-                        .append("div").attr("class","panel_title").append("h4").text(headLine)
-                    $('.'+divClassName).lobiPanel({
-                        reload: false,
-                        editTitle: false,
-                        unpin: false,
-                        minWidth: 1000,
-                        maxWidth: 100000,
-                        minHeight: 500,
-                        maxHeight: 100000,
-                    });
-                    $('.'+divClassName).lobiPanel('unpin');
-                    var treeLayoutSVG = treeLayoutdiv.append("svg").attr("class","treeLayoutSVG")
-                    var treeLayout = treeLayoutSVG.append("g").attr("class","treeLayout");
-                    maketreeLayout(array, treeLayout, treeLayoutSVG, treeLayoutdiv, divClassName, headLine, aCategory);
-                }
-                //############################################################
-                
-                //aigner: Creation of input/output list
-                //############################################################
-                function showIOList(aCategory, categoryDescr, aNode, io)
-                {                        
-                    var edges = d3.selectAll(".edge");
-                    var array="";
-                    var title;
-                    edges.each(function(edge)
-                    {			
-                        if (io=="in")
-                        {
-                            title = "List view of all inputs for " + aNode.id + "; Categorization: " + categoryDescr;
-                            if (edge.to == aNode.id)
-                            {
-                                array = array + "," + edge.name;
-                            }
-                        }
-                        else if (io=="out")
-                        {
-                            title = "List view of all outputs for " + aNode.id + "; Categorization: " + categoryDescr;
-                            if (edge.from == aNode.id)
-                            {
-                                array = array + "," + edge.name;
-                            }
-                        }
-                    })
-                    
-                    var variables = [];
-                    var pipeData = array;
-                    variables = JSON.parse(JSON.stringify(currentGraph.variableSchemes[aCategory]))
-                    prune_tree(pipeData,variables)
-                    variables.forEach(function(variable)
-                    {
-                        variable.name = variable.xPath
-                        //work around because nodeMenu expexts the data, to have a "data" object inside
-                        variable.data = variable
-                        variable.data.name = variable.xPath.split("/")[variable.xPath.split("/").length-1]
-                    })
-
-                    showList(title,variables,nodeMenu);
-                    
-                }
-                //############################################################                
-                
-              
-                function showToolTable(aTool)
-                {
-                    var aToolNameSplit = aTool.name.split(': ')			
-                    var headLine;
-                    if (aToolNameSplit.length>1){headLine = "Competence Information: (" + aToolNameSplit[1] + ")";}
-                    else {headLine = "Competence Information: (" + aToolNameSplit[0] + ")";}
-                    
-                    
-                    var data = [];
-                    // render the table(s)
-                    if (aTool.metadata.length==0)
-                    {
-                        data.push({ "name" : "NO TOOL METADATA AVAILABLE", "value" : "..." })
-                    }
-                    function findSubMetaData(aMetaData)
-                    {
-                        for(var key in aMetaData)
-                        {
-                            if (typeof aMetaData[key] === 'object')
-                            {
-                                data.push({ "name" : key, "value" : ''}) ;
-                                findSubMetaData(aMetaData[key]);
-                            }
-                            else
-                            {
-                                data.push({ "name" : key, "value" : aMetaData[key] })
-                            }
-                        }
-                    }
-                    for (var j=0; j < aTool.metadata.length;j++)
-                    {
-                        var metaData = aTool.metadata[j];
-                        findSubMetaData(metaData);						
-                    }
-                
-                    
-                    var d3_body = d3.select("body");
-                    
-                    var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                    panel_div.append("div").attr("class","panel-heading")
-                        .append("div").attr("class","panel_title").append("h4").text(headLine)
-                    var listGroup = panel_div.append("div").attr("class","panel-body")
-                        .append("table").attr("id","myTable")
-                        .append("tbody")
-                        
-                    data.forEach(function(listElement)
-                    {
-                        var row = listGroup.append("tr")
-                        row.append("td").text(listElement.name)
-                        row.append("td").text(listElement.value)
-                        
-                    })
-                    $('.myPanel').lobiPanel({
-                        reload: false,
-                        editTitle: false,
-                        expand: false,
-                        unpin: false,
-                        resize: "none",
-                        minWidth: 200,
-                        minHeight: 200,
-                        maxWidth: 1100,
-                        maxHeight: 1200,
-                    });
-                    $('.myPanel').lobiPanel('unpin');
-                }
-                
-                
-                function changeNodePosition(aNode)
-                {               
-                    var theOptions = [{text: 'Choose new position...', value: '',}];
-                    for (var j=1; j<currentGraph.xdsm.nodes.length;j++)
-                    {
-                        //aigner: value: j-1 because in KADMOS the coordinator is not in the node list, therefore all other competences' indices are decreased by 1!
-                        theOptions.push({text: String(j) + " ("+currentGraph.xdsm.nodes[j].name+")", value: j-1});
-                    }
-                    bootbox.hideAll();
-                    bootbox.prompt(
-                    {
-                        title: "Please specify a new position for the competence \""+aNode.name+"\"",
-                        inputType: 'select',
-                        inputOptions: theOptions,
-                        callback: function (newPos) {
-                            if (newPos!=null && newPos !='')
-                            {
-                                bootbox.hideAll();
-                                bootbox.confirm("Are you sure you want to do this?", function(sure){
-                                    if (sure)
-                                    {
-                                        var bootboxContent = {title: "Change competence position", message: '<p>Please be patient...</p>'};
-                                        var xhr = $.ajax({
-                                            type: 'POST',
-                                            url: '/kadmos_change_node_pos',
-                                            data: {'graphID':graphID, 'sessionID':sessionID, 'nodeName':aNode.uID, 'newPos':newPos, 'currentOrder':nodeOrder},
-                                            success: function(result)
-                                            {
-                                                if (result.includes("ERROR:"))
-                                                {
-                                                    bootboxContent.message = result
-                                                    kadmosErrorMessage(bootboxContent);
-                                                }
-                                                else
-                                                {
-                                                    var updatedData = {};
-                                                    updatedData = data;
-                                                    var graphData = JSON.parse(result);             
-                                                    for (var i = 0; i < updatedData.graphs.length; i++)
-                                                    {
-                                                        if (graphID == updatedData.graphs[i].id)
-                                                        {
-                                                            updatedData.graphs[i] = graphData.graphs[0];   
-                                                        }
-                                                    }
-                                                    
-                                                    clearView();
-                                                    makeKadmosMenu(updatedData);
-                                                    xdsm_script(updatedData,graphID);
-                                                    
-                                                    bootboxContent.message = "Success!"
-                                                    kadmosSuccessMessage(bootboxContent)
-                                                }
-                                            },
-                                            error: function(result)
-                                            {
-                                                bootboxContent.message = result
-                                                kadmosErrorMessage(bootboxContent);
-                                            }
-                                        });
-                                        kadmosHavePatience(xhr, bootboxContent)
-                                    }
-                                })
-                            }
-                        }
-                    });
-                }
-                
-                function deleteNode(aNode)
-                {               
-                    bootbox.hideAll();
-                    bootbox.confirm("Are you sure you want to do this?", function(sure)
-                    {
-                        if (sure)
-                        {                                
-                            var bootboxContent = {title: "Delete competence", message: '<p>Please be patient...</p>'};
-                            var xhr = $.ajax({
-                                type: 'POST',
-                                url: '/kadmos_delete_node',
-                                data: {'graphID':graphID, 'sessionID':sessionID, 'nodeName':aNode.uID, 'currentOrder':nodeOrder},
-                                success: function(result)
-                                {
-                                    if (result.includes("ERROR:"))
-                                    {
-                                        bootboxContent.message = result
-                                        kadmosErrorMessage(bootboxContent);
-                                    }
-                                    else
-                                    {
-                                        var updatedData = {};
-                                        updatedData = data;
-                                        var graphData = JSON.parse(result);             
-                                        for (var i = 0; i < updatedData.graphs.length; i++)
-                                        {
-                                            if (graphID == updatedData.graphs[i].id)
-                                            {
-                                                updatedData.graphs[i] = graphData.graphs[0];   
-                                            }
-                                        }
-                                        
-                                        clearView();
-                                        makeKadmosMenu(updatedData);
-                                        xdsm_script(updatedData,graphID);
-                                        
-                                        bootboxContent.message = "Success!"
-                                        kadmosSuccessMessage(bootboxContent)
-                                    }
-                                },
-                                error: function(result)
-                                {
-                                    bootboxContent.message = result
-                                    kadmosErrorMessage(bootboxContent);
-                                }
-                            });
-                            kadmosHavePatience(xhr, bootboxContent)
-                        }
-                    })
-                }
-                
-                
-                function addMathematicalFunction()
-                {               
-                    bootbox.hideAll();
-                    
-                    var html = d3.select("html")
-                    var form_content = html.append("div").attr("class","form-content").attr("style","display:none")
-                    var form = form_content.append("form").attr("class","form").attr("role","form")
-                    var form_group, input;
-                        
-                    //Tool information
-                    form_group = form.append("div").attr("class","form-group")
-                    form_group.append("text").text("Name")
-                    input = form_group.append("input")
-                        .attr("id","function_node")
-                        .attr("class","form-control")
-                        .attr("name","function_node")
-                        .attr("placeholder","Add a tool name here...")
-                    //Tool input nodes
-                    form_group = form.append("div").attr("class","form-group")
-                    form_group.append("text").text("Tool input nodes")
-                    input = form_group.append("input")
-                        .attr("id","input_nodes_xPath")
-                        .attr("class","form-control")
-                        .attr("name","input_nodes_xPath")
-                        .attr("placeholder","xPaths of the input nodes (please seperate with comma)")
-                    input = form_group.append("input")
-                        .attr("id","input_nodes_name")
-                        .attr("class","form-control")
-                        .attr("name","input_nodes_name")
-                        .attr("placeholder","Variable names of the input nodes (Please separate with comma)")
-                    //Tool output nodes
-                    form_group = form.append("div").attr("class","form-group")
-                    form_group.append("text").text("Tool output nodes")
-                    input = form_group.append("input")
-                        .attr("id","output_node_xPath")
-                        .attr("class","form-control")
-                        .attr("name","output_node_xPath")
-                        .attr("placeholder","xPath of the output node")
-                    input = form_group.append("input")
-                        .attr("id","equation")
-                        .attr("class","form-control")
-                        .attr("name","equation")
-                        .attr("placeholder","Equation for the output node")
-                    input = form_group.append("input")
-                        .attr("id","language")
-                        .attr("class","form-control")
-                        .attr("name","language")
-                        .attr("placeholder","Programming language (e.g. 'Python')")
-                        
-                    
-                    var modal = bootbox.dialog({
-                        message: $(".form-content").html(),
-                        title: "Add mathematical function",
-                        size: "large",
-                        buttons: [
-                          {
-                            label: "Cancel",
-                            className: "btn btn-default pull-left",
-                            callback: function() {
-                              modal.modal("hide");
-                              d3.selectAll(".form-content").remove();
-                            }
-                          },
-                          {
-                            label: "OK",
-                            className: "btn btn-primary pull-left",
-                            callback: function() {
-                                
-                                //get form data
-                                var form_data = {
-                                    function_node: $('form #function_node').val(),
-                                    input_nodes_xPath: $('form #input_nodes_xPath').val(),
-                                    input_nodes_name: $('form #input_nodes_name').val(),
-                                    output_node_xPath: $('form #output_node_xPath').val(),
-                                    equation: $('form #equation').val(),
-                                    language: $('form #language').val()
-                                }
-                                
-                                
-                                var bootboxContent = {title: "Add mathematical function", message: '<p>Please be patient...</p>'};
-                                var xhr = $.ajax({
-                                    type: 'POST',
-                                    url: '/kadmos_add_mathematical_function',
-                                    data: {'graphID':graphID, 'sessionID':sessionID, 'currentOrder':nodeOrder, 'form_data':JSON.stringify(form_data)},
-                                    success: function(result)
-                                    {
-                                        if (result.includes("ERROR:"))
-                                        {
-                                            bootboxContent.message = result
-                                            kadmosErrorMessage(bootboxContent);
-                                        }
-                                        else
-                                        {
-                                            var updatedData = {};
-                                            updatedData = data;
-                                            var graphData = JSON.parse(result);             
-                                            for (var i = 0; i < updatedData.graphs.length; i++)
-                                            {
-                                                if (graphID == updatedData.graphs[i].id)
-                                                {
-                                                    updatedData.graphs[i] = graphData.graphs[0];   
-                                                }
-                                            }
-                                            
-                                            clearView();
-                                            makeKadmosMenu(updatedData);
-                                            xdsm_script(updatedData,graphID);
-                                            
-                                            bootboxContent.message = "Success!"
-                                            kadmosSuccessMessage(bootboxContent)
-                                        }
-                                    },
-                                    error: function(result)
-                                    {
-                                        bootboxContent.message = result
-                                        kadmosErrorMessage(bootboxContent);
-                                    }
-                                });
-                                kadmosHavePatience(xhr, bootboxContent)
-                                kadmosHavePatience(xhr, bootboxContent)
-                                modal.modal("hide");
-                                d3.selectAll(".form-content").remove();
-                            }
-                          }
-                        ],
-                        onEscape: function() {
-                          modal.modal("hide");
-                          d3.selectAll(".form-content").remove();
-                        }
-                    });
-                    
-                        
-                    
-                }
-                
-                
-                 //aigner: children items for toolMenu
-                //############################################################
-                var inputChildrenitemsTree = [];
-                var outputChildrenitemsTree = [];
-                for (var j=0; j< varCategories.length; j++)
-                {
-                    inputChildrenitemsTree.push({title: 'according to ' + varCategories[j].description,
-                                             varCategory: varCategories[j].name,
-                                             description: varCategories[j].description,
-                                             onMouseClick: function(elm, data, i) {showIOTree(data.varCategory,data.description,elm.__data__,"in")},
-                                             onMouseOver: function(elm,data,i){}});
-                    outputChildrenitemsTree.push({title: 'according to ' + varCategories[j].description,
-                                             varCategory: varCategories[j].name,
-                                             description: varCategories[j].description,
-                                             onMouseClick: function(elm, data, i) {
-                                                showIOTree(data.varCategory,data.description,elm.__data__,"out")},
-                                             onMouseOver: function(elm,data,i){}});
-                }
-                
-                var inputChildrenitemsList = [];
-                var outputChildrenitemsList = [];
-                for (var j=0; j< varCategories.length; j++)
-                {
-                    inputChildrenitemsList.push({title: 'according to ' + varCategories[j].description,
-                                             varCategory: varCategories[j].name,
-                                             description: varCategories[j].description,
-                                             onMouseClick: function(elm, data, i) {showIOList(data.varCategory,data.description,elm.__data__,"out")},
-                                             onMouseOver: function(elm,data,i){}});
-                    outputChildrenitemsList.push({title: 'according to ' + varCategories[j].description,
-                                             varCategory: varCategories[j].name,
-                                             description: varCategories[j].description,
-                                             onMouseClick: function(elm, data, i) {showIOList(data.varCategory,data.description,elm.__data__,"out")},
-                                             onMouseOver: function(elm,data,i){}});
-                }
-                //############################################################
-                
-                
-                //menu --> functions for right click options (coordinator)
-                var toolMenuCoor = [
-                {
-                    title: 'Show competence info',
-                    onMouseDown: function(elm, k, i) {
-                        showToolTable(k);
-                    },
-                    onMouseUp: function(elm, k, i) {
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: []
-                },
-                {
-                    title: 'Show input variable tree...',
-                    onMouseDown: function(elm, k, i) {
-                    },
-                    onMouseUp: function(elm, k, i) {
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: inputChildrenitemsTree
-                },
-                {
-                    title: 'Show output variable tree...',
-                    onMouseDown: function(elm, k, i) {
-                    },
-                    onMouseUp: function(elm, k, i) {
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: outputChildrenitemsTree
-                },
-                {
-                    title: 'Show input variable list...',
-                    onMouseDown: function(elm, k, i) {
-                    },
-                    onMouseUp: function(elm, k, i) {
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: inputChildrenitemsList
-                },
-                {
-                    title: 'Show output variable list...',
-                    onMouseDown: function(elm, k, i) {
-                    },
-                    onMouseUp: function(elm, k, i) {
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: outputChildrenitemsList
-                }
-                ]
-                
-                
-                //menu --> functions for right click options for other tools
-                var toolMenuSpecial = [
-                {
-                    title: 'Add metadata',
-                    onMouseDown: function(elm, k, i) {
-                        addDCMetadata(data,currentGraph,k)
-                        //sendDCMetadata(dc_metadata);
-                    },
-                    onMouseUp: function(elm, k, i) {
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: []
-                },
-                {
-                    title: 'Change competence position in the graph',
-                    onMouseDown: function(elm, k, i) {
-                        changeNodePosition(k);
-                    },
-                    onMouseUp: function(elm, k, i) {
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: []
-                },
-                {
-                    title: 'Delete competence',
-                    onMouseDown: function(elm, k, i) {
-                        deleteNode(k);
-                    },
-                    onMouseUp: function(elm, k, i) {
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: []
-                }]
-                var toolMenu = toolMenuCoor.concat(toolMenuSpecial)
-                //################################################################################################//
-                
-                
-				
-                
-                //################################################################################################//
-                //aigner: Get node order of current graph nodes
-                var nodeOrder="";
-                for (var j=1; j<currentGraph.xdsm.nodes.length;j++)
-                {
-
-                    if (j!=1)
-                        nodeOrder += ",";
-                    nodeOrder += currentGraph.xdsm.nodes[j].uID;
-                }
-                
-                //aigner: theInputOptions -> array of all nodes in the graph, which can then be selected in the fpg manipulations
-                var theInputOptions = [];
-                for (var j=1; j<currentGraph.xdsm.nodes.length;j++)
-                {
-                    //aigner: value: j-1 because in KADMOS the coordinator is not in the node list, therefore all other competences' indices are decreased by 1!
-                    theInputOptions.push({text: currentGraph.xdsm.nodes[j].name, value: currentGraph.xdsm.nodes[j].uID});
-                }
-                
-                //aigner MDAO architecture options
-                var MDAO_architectures = ['-','unconverged-MDA','converged-MDA','MDF','IDF','unconverged-OPT','unconverged-DOE','converged-DOE']
-                var coupling_decompositions = ['-','Gauss-Seidel','Jacobi']
-                var DOE_methods = ['-','Full factorial design','Latin hypercube design','Monte Carlo Design']
-                //################################################################################################//
-                
-                
-                var revertDiv = d3.select(".xdsmDiv").append("div").attr("class","dataModelDiv").style("top","-10px")
-                //aigner: Revert previous step
-                //####################################################################################################################
-                //aigner: KADMOS function Save graph
-                //####################################################################################################################
-                //aigner: Function to download data to a file
-                function download(filename, text) {
-                    var element = document.createElement('a');
-                    element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(text));
-                    element.setAttribute('download', filename);
-
-                    element.style.display = 'none';
-                    document.body.appendChild(element);
-
-                    element.click();
-
-                    document.body.removeChild(element);
-                }
-
-                //aigner: Export changes --> Download as CMDOWS file
-                function exportChangesToFile(fileType)
-                {                
-                    bootbox.hideAll();
-                    var bootboxContent = {title: "Save changes to file", message: '<p>Please be patient...</p>'};
-                    bootbox.prompt(
-                    {
-                        title: "<p>The graph will be downloaded to your computer</p>"
-                              +"<p>Please type in the path of the directory</p>",
-                        value: "",
-                        placeholder: "path...",
-                        callback: function(path)
-                        {
-                            var xhr = $.ajax({
-                                type: 'POST',
-                                data: {'path':path, 'fileName':currentGraph.name, 'fileType': fileType, 'graphID': graphID, 'currentOrder': nodeOrder, 'sessionID': sessionID},
-                                url: '/kadmos_export_graph',
-                                success: function(result)
-                                {                            
-                                    if (result.includes("ERROR:"))
-                                    {
-                                        bootboxContent.message = result
-                                        kadmosErrorMessage(bootboxContent);
-                                    }
-                                    else
-                                    {
-                                        bootboxContent.message = "Successfully downloaded the file(s) to <b>"+result+"</b>"
-                                        kadmosSuccessMessage(bootboxContent);
-                                    }
-                                },
-                                error: function(result)
-                                {
-                                    bootboxContent.message = result
-                                    kadmosErrorMessage(bootboxContent);
-                                }
-                            });
-                            kadmosHavePatience(xhr, bootboxContent)
-                        }
-                    })
-                }
-                    
-              
-                
-				var saveButton = revertDiv.append("button")
-                    .attr("class","btn btn-primary")
-                    .attr("data-toggle","tooltip")
-                    .attr("data-placement","top")
-                    .attr("title","Save graph")
-                    .style("margin-left","10px")
-                    .style("margin-bottom","10px")
-                saveButton.append("span")
-                    .attr("class","glyphicon glyphicon-floppy-disk")
-                    .attr("aria-hidden","true")
-                saveButton.on("mousedown", function()
-                {	
-                    bootbox.hideAll();
-                    
-                    bootbox.prompt(
-                    {
-                        title: "Save graph. What would you like to save the graph as?",
-                        inputType: 'select',
-                        inputOptions: [ {text:" Save as new VISTOMS graph",value:"VISTOMS"},
-                                        {text:"Save as KDMS file (download)",value:"kdms"},
-                                        {text:"Save as CMDOWS file (download)",value:"cmdows"}],
-                        value: "VISTOMS",
-                        callback: function (fileType)
-                        {   
-                            if (fileType)
-                            {
-                               
-                                if (fileType.includes("VISTOMS"))
-                                {
-                                    bootbox.prompt(
-                                    {
-                                        title: "<p>The graph will be saved as new VISTOMS graph</p>"
-                                              +"<p>Please type in the name of the new graph!</p>",
-                                        value: currentGraph.name,
-                                        callback: function(newGraphName)
-                                        {
-                                            if (newGraphName!=null)
-                                            {   
-                                                var bootboxContent = {title: "Save as new VISTOMS graph", message: '<p>Please be patient...</p>'};
-                                                var newGraphID = ""
-                                                if (data.graphs.length<100){newGraphID="0"+String(data.graphs.length+1)}
-                                                else {newGraphID=String(data.graphs.length+1)}
-                                                
-                                                var newGraphID = '01';
-                                                data.graphs.forEach(function(graph) 
-                                                {
-                                                    id_int = parseInt(graph.id)
-                                                    if (data.graphs.length < 100){newGraphID = "0" + String(id_int+1);}
-                                                    else{newGraphID = String(id_int+1);}
-                                                })
-                                                
-                                                var xhr = $.ajax(
-                                                {
-                                                    type: 'POST',
-                                                    data: {'graphID': graphID, 'newGraphID': newGraphID, 'newGraphName': newGraphName, 'currentOrder':nodeOrder, 'sessionID': sessionID},
-                                                    url: '/kadmos_save_vistoms_graph',
-                                                    success: function(result)
-                                                    {
-                                                        if (result.includes("ERROR:"))
-                                                        {
-                                                            bootboxContent.message = result
-                                                            kadmosErrorMessage(bootboxContent);
-                                                        }
-                                                        else
-                                                        {
-                                                            var updatedData = jQuery.extend(true, {}, data);
-                                                            var graphData = JSON.parse(result);
-                                                            
-                                                            for (var i = 0; i < data.graphs.length; i++)
-                                                            {
-                                                                if (graphID == data.graphs[i].id)
-                                                                {
-                                                                    //Insert copied graph behind the original one
-                                                                    updatedData.graphs.splice(i+1, 0, graphData.graphs[0])
-                                                                }
-                                                            }
-                                                            
-                                                            clearView();
-                                                            makeKadmosMenu(updatedData);
-                                                            xdsm_script(updatedData,newGraphID);
-                                                            
-                                                            bootboxContent.message = "Success!"
-                                                            kadmosSuccessMessage(bootboxContent)
-                                                        }
-                                                    },
-                                                    error: function(result)
-                                                    {
-                                                        bootboxContent.message = result
-                                                        kadmosErrorMessage(bootboxContent);
-                                                    }
-                                                });
-                                                kadmosHavePatience(xhr, bootboxContent)
-                                            }
-                                        }
-                                    })
-                                }
-                                else
-                                {
-                                    exportChangesToFile(fileType)
-                                }
-                            }
-                        }
-                    })
-                })
-                //####################################################################################################################
-                
-                
-                
-                
-                var deleteButton = revertDiv.append("button")
-                    .attr("class","btn btn-danger")
-                    .attr("data-toggle","tooltip")
-                    .attr("data-placement","top")
-                    .attr("title","Delete graph")
-                    .style("margin-left","10px")
-                    .style("margin-bottom","10px")
-                deleteButton.append("span")
-                    .attr("class","glyphicon glyphicon-trash")
-                    .attr("aria-hidden","true")
-                deleteButton.on("mousedown", function()
-                {
-                    var bootboxContent = {title: "Deleting graph", message: '<p>Please be patient...</p>'};
-                    bootbox.hideAll();
-                    bootbox.confirm("Are you sure you want to permanently delete the graph? <b>This cannot be reverted!</b>", function(sure)
-                    {
-                        if (sure)
-                        {   
-                            var xhr = $.ajax(
-                            {
-                                type: 'POST',
-                                url: '/kadmos_delete_graph',
-                                data: {'graphID':graphID, 'sessionID': sessionID},
-                                success: function(result)
-                                {
-                                    if (result.includes("ERROR:"))
-                                    {
-                                        bootboxContent.message = result
-                                        kadmosErrorMessage(bootboxContent);
-                                    }
-                                    else
-                                    {                                        
-                                        var dataArray = result;       
-                                        var data = []
-                                        if (dataArray.length == 0){data="REP__GRAPH_DATA__REP"}
-                                        else{data = {"graphs":[], "categories":""};}
-                                        for (var i = 0; i < dataArray.length; i++)
-                                        {
-                                            var data_tmp = JSON.parse(dataArray[i])
-                                            data.graphs.push(data_tmp.graphs[0]);
-                                            if (data.categories == [])
-                                            {
-                                                data.categories = data_tmp.categories;                                        
-                                            }
-                                        }
-                                        
-                                        clearView();
-                                        makeKadmosMenu(data);
-                                        mainPage();
-                                        
-                                        bootboxContent.message = "Graph was sucessfully deleted!"
-                                        kadmosSuccessMessage(bootboxContent)
-                                    }
-                                },
-                                error: function(result)
-                                {
-                                    bootboxContent.message = result
-                                    kadmosErrorMessage(bootboxContent);
-                                }
-                            });
-                            kadmosHavePatience(xhr, bootboxContent)
-                        }
-                    })
-                })
-                
-                
-                var backButton = revertDiv.append("button")
-                    .attr("class","btn btn-warning")
-                    .attr("data-toggle","tooltip")
-                    .attr("data-placement","top")
-                    .attr("title","Revert graph manipulation step")
-                    .style("margin-left","10px")
-                    .style("margin-bottom","10px")
-                backButton.append("span")
-                    .attr("class","glyphicon glyphicon-arrow-left")
-                    .attr("aria-hidden","true")
-                backButton.on("mousedown", function()
-                {
-                    var bootboxContent = {title: "Revert graph manipulation step", message: '<p>Please be patient...</p>'};
-                    
-                    bootbox.hideAll();
-                    bootbox.confirm("Are you sure you want to revert the last step?", function(sure)
-                    {
-                        if (sure)
-                        {   
-                            
-                            var xhr = $.ajax(
-                            {
-                                type: 'POST',
-                                url: '/kadmos_revert_step',
-                                data: {'graphID':graphID, 'sessionID': sessionID},
-                                success: function(result)
-                                {
-                                    if (result.includes("ERROR:"))
-                                    {
-                                        bootboxContent.message = result
-                                        kadmosErrorMessage(bootboxContent);
-                                    }
-                                    else
-                                    {
-                                        var updatedData = {};
-                                        updatedData = data;
-                                        var graphData = JSON.parse(result);             
-                                        for (var i = 0; i < updatedData.graphs.length; i++)
-                                        {
-                                            if (graphID == updatedData.graphs[i].id)
-                                            {
-                                                updatedData.graphs[i] = graphData.graphs[0];   
-                                            }
-                                        }
-                                        
-                                        clearView();
-                                        makeKadmosMenu(updatedData);
-                                        xdsm_script(updatedData,graphID);
-                                        
-                                        bootboxContent.message = "Success!"
-                                        kadmosSuccessMessage(bootboxContent)
-                                    }
-                                },
-                                error: function(result)
-                                {
-                                    bootboxContent.message = result
-                                    kadmosErrorMessage(bootboxContent);
-                                }
-                            });
-                            kadmosHavePatience(xhr, bootboxContent)
-                        }
-                    })
-                })
-                    
-                 var fwdButton = revertDiv.append("button")
-                    .attr("class","btn btn-warning")
-                    .attr("data-toggle","tooltip")
-                    .attr("data-placement","top")
-                    .attr("title","Restore graph manipulation step")
-                    .style("margin-left","10px")
-                    .style("margin-bottom","10px")
-                fwdButton.append("span")
-                    .attr("class","glyphicon glyphicon-arrow-right")
-                    .attr("aria-hidden","true")
-                fwdButton.on("mousedown", function()
-                {
-                    var bootboxContent = {title: "Restore graph manipulation step", message: '<p>Please be patient...</p>'};
-                    
-                    bootbox.hideAll();
-                    bootbox.confirm("Are you sure you want to restore the last step?", function(sure)
-                    {
-                        if (sure)
-                        {   
-                            var xhr = $.ajax(
-                            {
-                                type: 'POST',
-                                url: '/kadmos_revert_step',
-                                data: {'graphID':graphID, 'sessionID':sessionID},
-                                success: function(result)
-                                {
-                                    if (result.includes("ERROR:"))
-                                    {
-                                        bootboxContent.message = result
-                                        kadmosErrorMessage(bootboxContent);
-                                    }
-                                    else
-                                    {
-                                        var updatedData = {};
-                                        updatedData = data;
-                                        var graphData = JSON.parse(result);             
-                                        for (var i = 0; i < updatedData.graphs.length; i++)
-                                        {
-                                            if (graphID == updatedData.graphs[i].id)
-                                            {
-                                                updatedData.graphs[i] = graphData.graphs[0];   
-                                            }
-                                        }
-                                        
-                                        clearView();
-                                        makeKadmosMenu(updatedData);
-                                        xdsm_script(updatedData,graphID);
-                                        
-                                        bootboxContent.message = "Success!"
-                                        kadmosSuccessMessage(bootboxContent)
-                                    }
-                                },
-                                error: function(result)
-                                {
-                                    bootboxContent.message = result
-                                    kadmosErrorMessage(bootboxContent);
-                                }
-                            });
-                            kadmosHavePatience(xhr, bootboxContent)
-                        }
-                    })
-                })
-               
-                
-                var addCBButton = revertDiv.append("button")
-                    .attr("class","btn btn-success")
-                    .attr("data-toggle","tooltip")
-                    .attr("data-placement","top")
-                    .attr("title","Add competence block")
-                    .style("margin-left","10px")
-                    .style("margin-bottom","10px")
-                addCBButton.append("span")
-                    .attr("class","glyphicon glyphicon-plus")
-                    .attr("aria-hidden","true")
-                addCBButton.on("mousedown", function()
-                {
-                    var bootboxContent = {title: "Add competence block", message: '<p>Please be patient...</p>'};
-                    
-                    bootbox.hideAll();
-                    bootbox.prompt({
-                        title: "<b>Add competence block</b>"
-                              +"<p>Which type of competence block do you want to add?</p>",
-                        inputType: 'select',
-                        inputOptions: [
-                            {
-                                text: 'Please choose...',
-                                value: '',
-                            },
-                            {
-                                text: 'Design competence',
-                                value: 'dc',
-                            },
-                            {
-                                text: 'Mathematical function',
-                                value: 'mf',
-                            }
-                        ],
-                        callback: function (result) {
-                            if (result == 'mf')
-                            {
-                                addMathematicalFunction();
-                            }
-                            else if(result == "dc")
-                            {
-                                addDesignCompetence(data, currentGraph);
-                            }
-                            else;
-                        }
-                    });
-                })
-                    
-                
-                //####################################################################################################################               
-                
-                
-
-                var inspectionsDiv = d3.select(".xdsmDiv").append("div").attr("class","dataModelDiv").style("top","-10px")
-                //aigner: Search for graph elements
-                //####################################################################################################################               
-                //CATEGORIES
-                 var categories = [
-                    {text:"all",value:"all"},
-                    {text:"variable",value:"variable"},
-                    {text:"function",value:"function"}]
-                
-                
-                var subCategories = [
-                    {text:"all",value:"all"},
-                    //VARIABLES:
-                    {text:"hole",value:"hole"},
-                    {text:"supplied input ",value:"supplied input "},
-                    {text:"supplied shared input",value:"supplied shared input"},
-                    {text:"output",value:"output"},
-                    {text:"collision",value:"collision"},
-                    {text:"coupling",value:"coupling"},
-                    {text:"pure circular coupling",value:"pure circular coupling"},
-                    {text:"shared coupling",value:"shared coupling"},
-                    {text:"shared circular coupling",value:"shared circular coupling"},
-                    {text:"collided coupling",value:"collided coupling"},
-                    {text:"collided circular coupling",value:"collided circular coupling"},
-                    {text:"collided shared coupling",value:"collided shared coupling"},
-                    {text:"collided shared circular coupling",value:"collided shared circular coupling"},
-                    {text:"all inputs",value:"all inputs"},
-                    {text:"all outputs",value:"all outputs"},
-                    {text:"all couplings",value:"all couplings"},
-                    {text:"all circular variables",value:"all circular variables"},
-                    {text:"all collisions",value:"all collisions"},
-                    {text:"all splittable variables",value:"all splittable variables"},
-                    {text:"all problematic variables",value:"all problematic variables"},
-                    //FUNCTIONS:
-                    {text:"hole",value:"hole"},
-                    {text:"inputless",value:"inputless"},
-                    {text:"outputless",value:"outputless"},
-                    {text:"complete",value:"complete"},
-                    {text:"all problematic functions",value:"all problematic functions"}]
-                    
-                var operators = [
-                    {text:"",value:""},
-                    {text:"<",value:"<"},
-                    {text:"<=",value:"<="},
-                    {text:"==",value:"=="},
-                    {text:">=",value:">="},
-                    {text:">",value:">"}]
-                
-                var inspectGraph_ul = inspectionsDiv.append("ul")
-                var inspectGraph_li = inspectGraph_ul.append("li")
-                    .on("mouseover", function(){
-                        d3.select(this)
-                            .style("cursor", "pointer")
-                    })
-				inspectGraph_li.append("a").text("Search")
-                inspectGraph_li.style("left", "0px")
-                inspectGraph_li.on("mousedown", function()
-                {
-                    bootbox.hideAll();
-                    
-                    var html = d3.select("html")
-                    var form_content = html.append("div").attr("class","form-content").attr("style","display:none")
-                    var form = form_content.append("form").attr("class","form").attr("role","form")
-                    
-                    var form_group1 = form.append("div").attr("class","form-group")
-                    form_group1.append("label").attr("for","category").text("Category")
-                    var input1 = form_group1.append("select").attr("id","category")
-                    categories.forEach(function(category)
-                        {
-                            input1.append("option").attr("type","select").attr("value",category.value).text(category.text)
-                        }
-                    )
-                    
-                    var form_group2 = form.append("div").attr("class","form-group")
-                    form_group2.append("label").attr("for","subcategory").text("Sub-category")
-                    var input2 = form_group2.append("select").attr("id","sub-category")
-                    subCategories.forEach(function(subcategory)
-                        {
-                            input2.append("option").attr("type","select").attr("value",subcategory.value).text(subcategory.text)
-                        }
-                    )
-                    
-                    
-                    var maxNumOfAttributes = 3;
-                    var form_group3 = form.append("div").attr("class","form-group")
-                    for (var i=0; i<maxNumOfAttributes; i++)
-                    {
-                        var input = form_group3.append("div").attr("class","attribute")
-                        if (i==0){input.append("label").attr("for","attribute"+String(i)).text("Attribute conditions (max. "+String(maxNumOfAttributes)+")")}
-                        input.append("input")
-                            .attr("id","attribute"+String(i))
-                            .attr("class","form-control")
-                            .attr("name","attribute")
-                            .attr("placeholder","attribute "+String(i+1))
-                        input.append("input")
-                            .attr("id","operator"+String(i))
-                            .attr("class","form-control")
-                            .attr("name","operator "+String(i+1))
-                            .attr("placeholder","operator "+String(i+1)+" (<,<=,==,>=,>)")
-                        input.append("input")
-                            .attr("id","value"+String(i))
-                            .attr("class","form-control")
-                            .attr("name","value")
-                            .attr("placeholder","value "+String(i+1))
-                    }
-                    
-                    var form_group4 = form.append("div").attr("class","form-group")
-                    for (var i=0; i<maxNumOfAttributes; i++)
-                    {
-                        var input = form_group4.append("div").attr("class","attribute")
-                        if (i==0){input.append("label").attr("for","attribute"+String(i)).text("Included attributes (max. "+String(maxNumOfAttributes)+")")}
-                        input.append("input")
-                            .attr("id","attr_include"+String(i))
-                            .attr("class","form-control")
-                            .attr("name","attr_include")
-                            .attr("placeholder","attribute "+String(i+1))
-                        input.append("input")
-                            .attr("id","attr_include_val"+String(i))
-                            .attr("class","form-control")
-                            .attr("name","attr_include_val "+String(i+1))
-                            .attr("placeholder","value "+String(i+1))
-                    }
-                    
-                    var form_group5 = form.append("div").attr("class","form-group")
-                    for (var i=0; i<maxNumOfAttributes; i++)
-                    {
-                        var input = form_group5.append("div").attr("class","attribute")
-                        if (i==0){input.append("label").attr("for","attribute"+String(i)).text("Excluded attributes (max. "+String(maxNumOfAttributes)+")")}
-                        input.append("input")
-                            .attr("id","attr_exclude"+String(i))
-                            .attr("class","form-control")
-                            .attr("name","attr_exclude")
-                            .attr("placeholder","attribute "+String(i+1))
-                        input.append("input")
-                            .attr("id","attr_exclude_val"+String(i))
-                            .attr("class","form-control")
-                            .attr("name","attr_exclude_val")
-                            .attr("placeholder","value "+String(i+1))
-                    }
-                        
-                    var form_group8 = form.append("div").attr("class","form-group")
-                    form_group8.append("label").attr("for","xPath_include").text("Included xPaths")
-                    var input8 = form_group8.append("input")
-                        .attr("id","xPath_include")
-                        .attr("class","form-control")
-                        .attr("name","xPath_include")
-                        .attr("placeholder","/schema/parent/child1, /schema/parent/child2, ...")
-                        
-                    var form_group9 = form.append("div").attr("class","form-group")
-                    form_group9.append("label").attr("for","xPath_exclude").text("Excluded xPaths")
-                    var input9 = form_group9.append("input")
-                        .attr("id","xPath_exclude")
-                        .attr("class","form-control")
-                        .attr("name","xPath_exclude")
-                        .attr("placeholder","/schema/parent/child1, /schema/parent/child2, ...")
-                        
-                        
-                    
-                    
-                    var modal = bootbox.dialog({
-                        message: $(".form-content").html(),
-                        title: "Search for graph elements.",
-                        size: "large",
-                        buttons: [
-                          {
-                            label: "Cancel",
-                            className: "btn btn-default pull-left",
-                            callback: function() {
-                              modal.modal("hide");
-                              d3.selectAll(".form-content").remove();
-                            }
-                          },
-                          {
-                            label: "OK",
-                            className: "btn btn-primary pull-left",
-                            callback: function() {
-                                
-                                var category = $('form #category').val()
-                                var sub_category = $('form #sub-category').val()
-                                var attr_cond = []
-                                var attr_include = [] 
-                                var attr_exclude = []
-                                for (var i=0; i<maxNumOfAttributes; i++)
-                                {   
-                                    if ($('form #attribute'+String(i)).val()!=""&&$('form #operator'+String(i)).val()!=""&&$('form #value'+String(i)).val()!="")
-                                    {attr_cond.push([$('form #attribute'+String(i)).val(),$('form #operator'+String(i)).val(),$('form #value'+String(i)).val()])}
-                                    if ($('form #attr_include'+String(i)).val()!=""&&$('form #attr_include_val'+String(i)).val()!="")
-                                    {attr_include.push([$('form #attr_include'+String(i)).val(),$('form #attr_include_val'+String(i)).val()])}
-                                    if ($('form #attr_exclude'+String(i)).val()!=""&&$('form #attr_exclude_val'+String(i)).val()!="")
-                                    {attr_exclude.push([$('form #attr_exclude'+String(i)).val(),$('form #attr_exclude_val'+String(i)).val()])}
-                                }
-                                var xPath_include = $('form #xPath_include').val()
-                                var xPath_exclude = $('form #xPath_exclude').val()
-                                
-                                var bootboxContent = {title: "Get graph elements", message: '<p>Please be patient...</p>'};
-                                var xhr = $.ajax(
-                                {
-                                    type: 'POST',
-                                    url: '/kadmos_find_all_nodes',
-                                    data: {'graphID':graphID,
-                                           'sessionID': sessionID,
-                                           'category':category,
-                                           'sub_category':sub_category,
-                                           'attr_cond':JSON.stringify(attr_cond),
-                                           'attr_include':JSON.stringify(attr_include),
-                                           'attr_exclude':JSON.stringify(attr_exclude),
-                                           'xPath_include':xPath_include,
-                                           'xPath_exclude':xPath_exclude,},
-                                    success: function(result)
-                                    {
-                                        if (result.includes("ERROR:"))
-                                        {
-                                            bootboxContent.message = result
-                                            kadmosErrorMessage(bootboxContent);
-                                        }
-                                        else if (result == "[]")
-                                        {   
-                                            bootboxContent.title = "<b>Get graph elements</b>"
-                                            bootboxContent.message = "<b>No matching graph elements!</b>"
-                                            kadmosSuccessMessage(bootboxContent);
-                                        }
-                                        else
-                                        {   
-                                            bootbox.hideAll();
-											var treeData = (JSON.parse(JSON.stringify(currentGraph.variableSchemes[varCategories[0].description])));
-											var firstEl = treeData[0].xPath.split("/")[1]		
-
-											var graphElements = JSON.parse(result)
-                                            
-                                            var title = "List view of graph elements."
-                                                    +" category: \"" + category + "\""
-                                                    +", sub-category: \"" + sub_category + "\""
-                                            var message = "";
-											
-											var variables = [];
-											var functions = [];
-											
-                                            //get all potential functions first. these will be 
-                                            var functions_all = [];
-                                            var alld3Nodes = d3.selectAll(".node")
-                                            alld3Nodes.each(
-                                                function(){
-                                                   functions_all.push(this.__data__)
-                                                }
-                                            )
-                                            
-											if (result.includes("/"+firstEl))
-                                            {
-                                                //There are variables in the result
-												
-												
-                                                //push back functions in list
-                                                functions_all.forEach(function(aFunction){
-                                                    if (graphElements.includes(aFunction.uID)){functions.push(aFunction);}
-                                                })
-                                                
-                                                //push back variables in list
-                                                var pipeData = [];
-												graphElements.forEach(function(graphElement)
-												{
-													if (graphElement.includes("/"+firstEl))
-													{ 
-														pipeData += ","+graphElement;
-													}
-												})
-												variables = JSON.parse(JSON.stringify(treeData))
-												prune_tree(pipeData,variables)
-												variables.forEach(function(variable)
-												{
-													variable.name = variable.xPath
-													//work around because nodeMenu expexts the data, to have a "data" object inside
-                                                    variable.data = variable
-                                                    variable.data.name = variable.xPath.split("/")[variable.xPath.split("/").length-1]
-												})
-												
-                                                //message with option: How does the user want to show the variables, as a list or as a tree view?
-												bootbox.prompt(
-                                                {
-                                                    title: "The graph elements you requested contain variables. How do you want them displayed?",
-                                                    inputType: 'checkbox',
-                                                    inputOptions: [{text:" Show variables as tree view",value:"Tree View"},{text:" Show variables as list",value:"List"}],
-                                                    callback: function (result)
-                                                    {
-                                                        if (result)
-                                                        {
-                                                            var message1 = "", message2 = "";
-                                                            var array
-                                                            bootbox.hideAll();
-                                                            if(result.includes("Tree View"))
-                                                            {
-                                                                var headLine = "Tree Layout for category:\" " + category + "\", subcategory:\" " + sub_category + "\"";  
-                                                                var d3_body = d3.select("body");
-                                                                var lobiID = String(getRandomInt(0,1000))
-                                                                var divClassName = "treeDiv" + lobiID;
-                                                                var treeLayoutdiv = d3_body.append("div").attr("class",divClassName+ " panel-default")
-                                                                                                .style("left","200px")
-                                                                                                .style("top","200px")
-                                                                                                .style("position", "absolute")
-                                                                treeLayoutdiv.append("div").attr("class","panel-heading")
-                                                                    .append("div").attr("class","panel_title").append("h4").text(headLine)
-                                                                $('.' + divClassName).lobiPanel({
-                                                                    reload: false,
-                                                                    editTitle: false,
-                                                                    unpin: false,
-                                                                    minWidth: 200,
-                                                                    maxWidth: 100000,
-                                                                    minHeight: 200,
-                                                                    maxHeight: 100000,
-                                                                });
-                                                                $('.'+divClassName).lobiPanel('unpin');
-                                                                var treeLayoutSVG = treeLayoutdiv.append("svg").attr("class","treeLayoutSVG")
-                                                                var treeLayout = treeLayoutSVG.append("g").attr("class","treeLayout");
-                                                                maketreeLayout(array, treeLayout, treeLayoutSVG, treeLayoutdiv, divClassName, headLine, varCategories[0].description);
-                                                            }
-															if (result.includes("List"))
-															{
-																showList(title,variables,nodeMenu);
-															}
-                                                            
-                                                        }
-                                                    }
-                                                })
-											}
-                                            else
-                                            {
-                                                //push back functions in list
-                                                functions_all.forEach(function(aFunction){
-                                                    if (graphElements.includes(aFunction.uID)){functions.push(aFunction);}
-                                                })
-                                            }
-                                            showList(title,functions,toolMenu);
-                                        }
-                                    },
-                                    error: function(result)
-                                    {
-                                        bootboxContent.message = result
-                                        kadmosErrorMessage(bootboxContent);
-                                    }
-                                });
-                                kadmosHavePatience(xhr, bootboxContent)
-                                modal.modal("hide");
-                                d3.selectAll(".form-content").remove();
-                            }
-                          }
-                        ],
-                        onEscape: function() {
-                          modal.modal("hide");
-                          d3.selectAll(".form-content").remove();
-                        }
-                    });
-                    
-                    
-               
-                })
-                //####################################################################################################################
-                
-                
-                
-                //aigner: Kadmos functions --> Check graph
-                //####################################################################################################################				
-                var checkGraph_ul = inspectionsDiv.append("ul")
-				var checkGraph_li = checkGraph_ul.append("li")
-                    .on("mouseover", function(){
-                        d3.select(this)
-                            .style("cursor", "default")
-                    })
-                checkGraph_li.append("a").text("Check")
-                var checkGraph = checkGraph_li.append("ul");
-                var xOffset_ul = checkGraph_li._groups[0][0].offsetLeft+checkGraph_li._groups[0][0].offsetWidth-40;
-                checkGraph.style("left", String(xOffset_ul)+"px")
-                
-                //aigner: Kadmos function --> graph checks
-                checkGraph.append("li").append("a")
-                    .text("L1 check: graph")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        var bootboxContent = {title: "L1 check: graph", message: '<p>Please be patient...</p>'};
-                        var xhr = $.ajax({
-                            type: 'POST',
-                            data: {'graphID': graphID, 'sessionID': sessionID},
-                            url: '/kadmos_L1_check',
-                            success: function(result)
-                            {
-                                if (result.includes("ERROR:"))
-                                {
-                                    bootboxContent.message = result
-                                    kadmosErrorMessage(bootboxContent);
-                                }
-                                else
-                                {
-                                    bootboxContent.message = result
-                                    kadmosSuccessMessage(bootboxContent);
-                                }
-                            },
-                            error: function(result)
-                            {
-                                bootboxContent.message = result
-                                kadmosErrorMessage(bootboxContent);
-                            }
-                        });
-                        kadmosHavePatience(xhr, bootboxContent)
-                    })
-                    
-                checkGraph.append("li").append("a")
-                    .text("L2 check: problem formulation")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        var bootboxContent = {title: "L2 check: problem formulation", message: '<p>Please be patient...</p>'};
-                        var xhr = $.ajax({
-                            type: 'POST',
-                            data: {'graphID': graphID, 'sessionID': sessionID},
-                            url: '/kadmos_L2_check',
-                            success: function(result)
-                            {
-                                if (result.includes("ERROR:"))
-                                {
-                                    bootboxContent.message = result
-                                    kadmosErrorMessage(bootboxContent);
-                                }
-                                else
-                                {
-                                    bootboxContent.message = result
-                                    kadmosSuccessMessage(bootboxContent);
-                                }
-                            },
-                            error: function(result)
-                            {
-                                bootboxContent.message = result
-                                kadmosErrorMessage(bootboxContent);
-                            }
-                        });
-                        kadmosHavePatience(xhr, bootboxContent)
-                    })
-                    
-                checkGraph.append("li").append("a")
-                    .text("L3 check: graph & problem formulation")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        var bootboxContent = {title: "L3 check: graph & problem formulation", message: '<p>Please be patient...</p>'};
-                        var xhr = $.ajax({
-                            type: 'POST',
-                            data: {'graphID': graphID, 'sessionID': sessionID},
-                            url: '/kadmos_L3_check',
-                            success: function(result)
-                            {
-                                if (result.includes("ERROR:"))
-                                {
-                                    bootboxContent.message = result
-                                    kadmosErrorMessage(bootboxContent);
-                                }
-                                else
-                                {
-                                    bootboxContent.message = result
-                                    kadmosSuccessMessage(bootboxContent);
-                                }
-                            },
-                            error: function(result)
-                            {
-                                bootboxContent.message = result
-                                kadmosErrorMessage(bootboxContent);
-                            }
-                        });
-                        kadmosHavePatience(xhr, bootboxContent)
-                    })
-                
-                //####################################################################################################################
-
-                
-                //aigner: Kadmos functions --> Graph manipulation
-                //####################################################################################################################				
-                var optionsDiv = d3.select(".xdsmDiv").append("div").attr("class","dataModelDiv").style("top","-10px")
-                var fpgManipulations_ul = optionsDiv.append("ul")
-				var fpgManipulations_li = fpgManipulations_ul.append("li")
-                    .on("mouseover", function(){
-                        d3.select(this)
-                            .style("cursor", "default")
-                    })
-                fpgManipulations_li.append("a").text("1. FPG Manipulations")
-                var fpgManipulations = fpgManipulations_li.append("ul");
-                var xOffset_ul = fpgManipulations_li._groups[0][0].offsetLeft+fpgManipulations_li._groups[0][0].offsetWidth-40;
-                fpgManipulations.style("left", String(xOffset_ul)+"px")
-                
-                //aigner: Kadmos function --> Start defining MDO problem
-                fpgManipulations.append("li").append("a")
-                    .text("1.1. Start defining MDO problem")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "<p>This will create an initial FPG for your MDO problem. After clicking this button, you can go through the \"<b>FPG manipulation</b>\" steps."
-                                  +"<p>Please type in a new name for the graph</p>",
-                            value: currentGraph.name,
-                            callback: function(newGraphName)
-                            {
-                                if (newGraphName)
-                                {
-                                    var newGraphID = '01';
-                                    data.graphs.forEach(function(graph) 
-                                    {
-                                        id_int = parseInt(graph.id)
-                                        if (data.graphs.length < 100){newGraphID = "0" + String(id_int+1);}
-                                        else{newGraphID = String(id_int+1);}
-                                    })
-                                    var bootboxContent = {title: "Start defining MDO problem", message: '<p>Please be patient...</p>'};
-                                    var xhr = $.ajax({
-                                        type: 'POST',
-                                        url: '/kadmos_start_defining_MDO_problem',
-                                        data: {'graphID':graphID, 'currentOrder': nodeOrder, 'newGraphName':newGraphName, 'newGraphID':newGraphID, 'sessionID': sessionID},
-                                        success: function(result)
-                                        {
-                                            if (result.includes("ERROR:"))
-                                            {
-                                                bootboxContent.message = result
-                                                kadmosErrorMessage(bootboxContent);
-                                            }
-                                            else
-                                            {
-                                                var updatedData = jQuery.extend(true, {}, data);
-                                                var graphData = JSON.parse(result);
-                                                
-                                                for (var i = 0; i < data.graphs.length; i++)
-                                                {
-                                                    if (graphID == data.graphs[i].id)
-                                                    {
-                                                        
-                                                        //Insert copied graph behind the original one
-                                                        updatedData.graphs.splice(i+1, 0, graphData.graphs[0])
-                                                    }
-                                                }
-                                                
-                                                clearView();
-                                                makeKadmosMenu(updatedData);
-                                                xdsm_script(updatedData,newGraphID);
-                                                
-                                                bootboxContent.message = "Success!"
-                                                kadmosSuccessMessage(bootboxContent)
-                                            }
-                                        },
-                                        error: function(result)
-                                        {
-                                            bootboxContent.message = result
-                                            kadmosErrorMessage(bootboxContent);
-                                        }
-                                    });
-                                    kadmosHavePatience(xhr, bootboxContent)
-                                }
-                            }
-                        })
-                    })
-                
-                
-                
-                fpgManipulations.append("li").append("a")
-                    .text("1.2. Exclude Design Competences")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {                        
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "Please select the design competences you would like to exclude.",
-                            inputType: 'checkbox',
-                            inputOptions: theInputOptions,
-                            callback: function (nodeList) 
-                            {
-                                if (nodeList)
-                                {
-                                    var nodeStr = '';
-                                    for (var i=0; i< nodeList.length; i++)
-                                    {
-                                        if (i==0){nodeStr += nodeList[i]}
-                                        else{nodeStr += ',' + nodeList[i]}
-                                    }
-                                    
-                                    bootbox.hideAll();
-                                    bootbox.confirm("Are you sure you want to do this?", function(sure)
-                                    {
-                                        if (sure)
-                                        {                                
-                                            var bootboxContent = {title: "Exclude design competences", message: '<p>Please be patient...</p>'};
-                                            var xhr = $.ajax({
-                                                type: 'POST',
-                                                url: '/kadmos_exclude_DCs',
-                                                data: {'graphID':graphID, 'nodeList':nodeStr, 'currentOrder':nodeOrder, 'sessionID': sessionID},
-                                                success: function(result)
-                                                {
-                                                    if (result.includes("ERROR:"))
-                                                    {
-                                                        bootboxContent.message = result
-                                                        kadmosErrorMessage(bootboxContent);
-                                                    }
-                                                    else
-                                                    {
-                                                        var updatedData = {};
-                                                        updatedData = data;
-                                                        var graphData = JSON.parse(result);             
-                                                        for (var i = 0; i < updatedData.graphs.length; i++)
-                                                        {
-                                                            if (graphID == updatedData.graphs[i].id)
-                                                            {
-                                                                updatedData.graphs[i] = graphData.graphs[0];   
-                                                            }
-                                                        }
-                                                        
-                                                        clearView();
-                                                        makeKadmosMenu(updatedData);
-                                                        xdsm_script(updatedData,graphID);
-                                                        
-                                                        bootboxContent.message = "Success!"
-                                                        kadmosSuccessMessage(bootboxContent)
-                                                    }
-                                                },
-                                                error: function(result)
-                                                {
-                                                    bootboxContent.message = result
-                                                    kadmosErrorMessage(bootboxContent);
-                                                }
-                                            });
-                                            kadmosHavePatience(xhr, bootboxContent)
-                                        }
-                                    })
-                                }
-                            }
-                        });
-                    })
-                    
-                fpgManipulations.append("li").append("a")
-                    .text("1.3. Merge sequential competences")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {                        
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "Please select the sequential design competences you would like to merge.",
-                            inputType: 'checkbox',
-                            inputOptions: theInputOptions,
-                            callback: function (nodeList) 
-                            {
-                                if (nodeList)
-                                {
-                                    var nodeStr = '';
-                                    for (var i=0; i< nodeList.length; i++)
-                                    {
-                                        if (i==0){nodeStr += nodeList[i]}
-                                        else{nodeStr += ',' + nodeList[i]}
-                                    }
-                                    
-                                    bootbox.hideAll();
-                                    bootbox.confirm("Are you sure you want to do this", function(sure)
-                                    {
-                                        if (sure)
-                                        {                       
-                                            var bootboxContent = {title: "Merge sequential design competences", message: '<p>Please be patient...</p>'};
-                                            var xhr = $.ajax({
-                                                type: 'POST',
-                                                url: '/kadmos_merge_seq_DCs',
-                                                data: {'graphID':graphID, 'nodeList':nodeStr, 'currentOrder':nodeOrder, 'sessionID': sessionID},
-                                                success: function(result)
-                                                {
-                                                    if (result.includes("ERROR:"))
-                                                    {
-                                                        bootboxContent.message = result
-                                                        kadmosErrorMessage(bootboxContent);
-                                                    }
-                                                    else
-                                                    {
-                                                        var updatedData = {};
-                                                        updatedData = data;
-                                                        var graphData = JSON.parse(result);             
-                                                        for (var i = 0; i < updatedData.graphs.length; i++)
-                                                        {
-                                                            if (graphID == updatedData.graphs[i].id)
-                                                            {
-                                                                updatedData.graphs[i] = graphData.graphs[0];   
-                                                            }
-                                                        }
-                                                        
-                                                        clearView();
-                                                        makeKadmosMenu(updatedData);
-                                                        xdsm_script(updatedData,graphID);
-                                                        
-                                                        bootboxContent.message = "Success!"
-                                                        kadmosSuccessMessage(bootboxContent)
-                                                    }
-                                                },
-                                                error: function(result)
-                                                {
-                                                    bootboxContent.message = result
-                                                    kadmosErrorMessage(bootboxContent);
-                                                }
-                                            });
-                                            kadmosHavePatience(xhr, bootboxContent)
-                                        }
-                                    })
-                                
-                                }
-                            }
-                        });
-                    })
-                
-                fpgManipulations.append("li").append("a")
-                    .text("1.4. Merge parallel competences")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "Please select the parallel design competences you would like to merge.",
-                            inputType: 'checkbox',
-                            inputOptions: theInputOptions,
-                            callback: function (nodeList) 
-                            {
-                                if (nodeList)
-                                {
-                                    var nodeStr = '';
-                                    for (var i=0; i< nodeList.length; i++)
-                                    {
-                                        if (i==0){nodeStr += nodeList[i]}
-                                        else{nodeStr += ',' + nodeList[i]}
-                                    }
-                                    
-                                    bootbox.hideAll();
-                                    bootbox.confirm("Are you sure you want to do this", function(sure)
-                                    {
-                                        if (sure)
-                                        {                       
-                                            var bootboxContent = {title: "Merge parallel design competences", message: '<p>Please be patient...</p>'};
-                                            var xhr = $.ajax({
-                                                type: 'POST',
-                                                url: '/kadmos_merge_parallel_DCs',
-                                                data: {'graphID':graphID, 'nodeList':nodeStr, 'currentOrder':nodeOrder, 'sessionID': sessionID},
-                                                success: function(result)
-                                                {
-                                                    if (result.includes("ERROR:"))
-                                                    {
-                                                        bootboxContent.message = result
-                                                        kadmosErrorMessage(bootboxContent);
-                                                    }
-                                                    else
-                                                    {
-                                                        var updatedData = {};
-                                                        updatedData = data;
-                                                        var graphData = JSON.parse(result);             
-                                                        for (var i = 0; i < updatedData.graphs.length; i++)
-                                                        {
-                                                            if (graphID == updatedData.graphs[i].id)
-                                                            {
-                                                                updatedData.graphs[i] = graphData.graphs[0];   
-                                                            }
-                                                        }
-                                                        
-                                                        clearView();
-                                                        makeKadmosMenu(updatedData);
-                                                        xdsm_script(updatedData,graphID);
-                                                        
-                                                        bootboxContent.message = "Success!"
-                                                        kadmosSuccessMessage(bootboxContent)
-                                                    }
-                                                },
-                                                error: function(result)
-                                                {
-                                                    bootboxContent.message = result
-                                                    kadmosErrorMessage(bootboxContent);
-                                                }
-                                            });
-                                            kadmosHavePatience(xhr, bootboxContent)
-                                        }
-                                    })
-                                
-                                }
-                            }
-                        });
-                    })
-                    
-                fpgManipulations.append("li").append("a")
-                    .text("1.5. Merge function modes competences")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "Please select the design competences you would like to merge.",
-                            inputType: 'checkbox',
-                            inputOptions: theInputOptions,
-                            callback: function (nodeList) 
-                            {
-                                if (nodeList)
-                                {
-                                    var nodeStr = '';
-                                    for (var i=0; i< nodeList.length; i++)
-                                    {
-                                        if (i==0){nodeStr += nodeList[i]}
-                                        else{nodeStr += ',' + nodeList[i]}
-                                    }
-                                    
-                                    bootbox.hideAll();
-                                    bootbox.confirm("Are you sure you want to do this", function(sure)
-                                    {
-                                        if (sure)
-                                        {                       
-                                            var bootboxContent = {title: "Merge function mode design competences", message: '<p>Please be patient...</p>'};
-                                            var xhr = $.ajax({
-                                                type: 'POST',
-                                                url: '/kadmos_merge_func_mod_DCs',
-                                                data: {'graphID':graphID, 'nodeList':nodeStr, 'currentOrder':nodeOrder, 'sessionID': sessionID},
-                                                success: function(result)
-                                                {
-                                                    if (result.includes("ERROR:"))
-                                                    {
-                                                        bootboxContent.message = result
-                                                        kadmosErrorMessage(bootboxContent);
-                                                    }
-                                                    else
-                                                    {
-                                                        var updatedData = {};
-                                                        updatedData = data;
-                                                        var graphData = JSON.parse(result);             
-                                                        for (var i = 0; i < updatedData.graphs.length; i++)
-                                                        {
-                                                            if (graphID == updatedData.graphs[i].id)
-                                                            {
-                                                                updatedData.graphs[i] = graphData.graphs[0];   
-                                                            }
-                                                        }
-                                                        
-                                                        clearView();
-                                                        makeKadmosMenu(updatedData);
-                                                        xdsm_script(updatedData,graphID);
-                                                        
-                                                        bootboxContent.message = "Success!"
-                                                        kadmosSuccessMessage(bootboxContent)
-                                                    }
-                                                },
-                                                error: function(result)
-                                                {
-                                                    bootboxContent.message = result
-                                                    kadmosErrorMessage(bootboxContent);
-                                                }
-                                            });
-                                            kadmosHavePatience(xhr, bootboxContent)
-                                        }
-                                    })
-                                
-                                }
-                            }
-                        });
-                    })
-                    
-                fpgManipulations.append("li").append("a")
-                    .text("1.6. Remove collision parameters")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "Please select the design competences for which you would like to remove collisions.",
-                            inputType: 'checkbox',
-                            inputOptions: theInputOptions,
-                            callback: function (nodeList) 
-                            {
-                                if (nodeList)
-                                {
-                                    var nodeStr = '';
-                                    for (var i=0; i< nodeList.length; i++)
-                                    {
-                                        if (i==0){nodeStr += nodeList[i]}
-                                        else{nodeStr += ',' + nodeList[i]}
-                                    }
-                                    
-                                    bootbox.hideAll();
-                                    bootbox.confirm("Are you sure you want to do this", function(sure)
-                                    {
-                                        if (sure)
-                                        {                       
-                                            var bootboxContent = {title: "Remove collisions", message: '<p>Please be patient...</p>'};
-                                            var xhr = $.ajax({
-                                                type: 'POST',
-                                                url: '/kadmos_remove_collision',
-                                                data: {'graphID':graphID, 'nodeList':nodeStr, 'currentOrder':nodeOrder, 'sessionID': sessionID},
-                                                success: function(result)
-                                                {
-                                                    if (result.includes("ERROR:"))
-                                                    {
-                                                        bootboxContent.message = result
-                                                        kadmosErrorMessage(bootboxContent);
-                                                    }
-                                                    else
-                                                    {
-                                                        var updatedData = {};
-                                                        updatedData = data;
-                                                        var graphData = JSON.parse(result);             
-                                                        for (var i = 0; i < updatedData.graphs.length; i++)
-                                                        {
-                                                            if (graphID == updatedData.graphs[i].id)
-                                                            {
-                                                                updatedData.graphs[i] = graphData.graphs[0];   
-                                                            }
-                                                        }
-                                                        
-                                                        clearView();
-                                                        makeKadmosMenu(updatedData);
-                                                        xdsm_script(updatedData,graphID);
-                                                        
-                                                        bootboxContent.message = "Success!"
-                                                        kadmosSuccessMessage(bootboxContent)
-                                                    }
-                                                },
-                                                error: function(result)
-                                                {
-                                                    bootboxContent.message = result
-                                                    kadmosErrorMessage(bootboxContent);
-                                                }
-                                            });
-                                            kadmosHavePatience(xhr, bootboxContent)
-                                        }
-                                    })
-                                
-                                }
-                            }
-                        });
-                    })
-                    
-                fpgManipulations.append("li").append("a")
-                    .text("1.7. Make all variables valid")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        bootbox.hideAll();
-                        bootbox.confirm("<p>This will automatically remove all collisions from the graph by creating multiple variable instances.</p>" 
-										+"<p>Are you sure you want to do this?</p>", function(sure)
-                        {
-                            if (sure)
-                            {
-                                var bootboxContent = {title: "Create FPG", message: '<p>Please be patient...</p>'};
-                                var xhr = $.ajax({
-                                    type: 'POST',
-                                    url: '/kadmos_make_all_variables_valid',
-                                    data: {'graphID':graphID, 'currentOrder':nodeOrder, 'sessionID': sessionID},
-                                    success: function(result)
-                                    {
-                                        if (result.includes("ERROR:"))
-                                        {
-                                            bootboxContent.message = result
-                                            kadmosErrorMessage(bootboxContent);
-                                        }
-                                        else
-                                        {
-                                            var updatedData = {};
-                                            updatedData = data;
-                                            var graphData = JSON.parse(result);             
-                                            for (var i = 0; i < updatedData.graphs.length; i++)
-                                            {
-                                                if (graphID == updatedData.graphs[i].id)
-                                                {
-                                                    updatedData.graphs[i] = graphData.graphs[0];   
-                                                }
-                                            }
-                                            
-                                            clearView();
-                                            makeKadmosMenu(updatedData);
-                                            xdsm_script(updatedData,graphID);
-                                            
-                                            bootboxContent.message = "Success!"
-                                            kadmosSuccessMessage(bootboxContent)
-                                        }
-                                    },
-                                    error: function(result)
-                                    {
-                                        bootboxContent.message = result
-                                        kadmosErrorMessage(bootboxContent);
-                                    }
-                                });
-                                kadmosHavePatience(xhr, bootboxContent)
-                            }
-                        });
-                    })
-                    
-                fpgManipulations.append("li").append("a")
-                    .text("1.8. Add problem function roles")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        bootbox.hideAll();
-                        bootbox.confirm("Are you sure you want to do this?", function(sure)
-                        {
-                            if (sure)
-                            {
-                                var bootboxContent = {title: "Create FPG", message: '<p>Please be patient...</p>'};
-                                var xhr = $.ajax({
-                                    type: 'POST',
-                                    url: '/kadmos_add_function_problem_roles',
-                                    data: {'graphID':graphID, 'sessionID':sessionID, 'currentOrder':nodeOrder},
-                                    success: function(result)
-                                    {
-                                        if (result.includes("ERROR:"))
-                                        {
-                                            bootboxContent.message = result
-                                            kadmosErrorMessage(bootboxContent);
-                                        }
-                                        else
-                                        {
-                                            var updatedData = {};
-                                            updatedData = data;
-                                            var graphData = JSON.parse(result);             
-                                            for (var i = 0; i < updatedData.graphs.length; i++)
-                                            {
-                                                if (graphID == updatedData.graphs[i].id)
-                                                {
-                                                    updatedData.graphs[i] = graphData.graphs[0];   
-                                                }
-                                            }
-                                            
-                                            clearView();
-                                            makeKadmosMenu(updatedData);
-                                            xdsm_script(updatedData,graphID);
-                                            
-                                            bootboxContent.message = "Success!"
-                                            kadmosSuccessMessage(bootboxContent)
-                                        }
-                                    },
-                                    error: function(result)
-                                    {
-                                        bootboxContent.message = result
-                                        kadmosErrorMessage(bootboxContent);
-                                    }
-                                });
-                                kadmosHavePatience(xhr, bootboxContent)
-                            }
-                        });
-                    })
-                    
-                    
-                fpgManipulations.append("li").append("a")
-                    .text("1.9. Assign parameter roles")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        if (markedVariables.length<1)
-                        {
-                            bootbox.hideAll();
-                            bootbox.alert({
-                                title: "Assign parameter roles",
-                                message: "<p>Please mark all parameters, which are of special interest. The options are:</p>"
-                                         +"<ul><li><b>Design Variable</b></li>"
-                                         +"<li><b>Objective</b></li>"
-                                         +"<li><b>Constraint</b></li>"
-                                         +"<li><b>State Variable</b> (also \"quantity of interest\")</li></ul><br/>"
-                                         +"<p>To \"pre-mark\" special parameters open the <b>Data Model Tree</b> or <b>Data Model List</b>, select the parameters via right-mouse click and use one  if the \"Mark Variable\" options.</p>"
-                                         +"<p><b>IMPORTANT: After all parameters are \"pre-marked\", klick this button again to assign the parameter roles!</b></p>"
-                            })
-                        }
-                        else
-                        {
-                            markVariable(markedVariables)
-                        }
-                        
-                    })
-                
-                fpgManipulations.append("li").append("a")
-                    .text("1.10. Get Possible Function Order")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "Select a sorting method",
-                            inputType: 'select',
-                            value: 'single-swap',
-                            inputOptions: [
-                                        {
-                                    text: 'single-swap',
-                                    value: 'single-swap',
-                                },
-                                {
-                                    text: 'two-swap',
-                                    value: 'two-swap',
-                                },
-                                {
-                                    text: 'hybrid-swap',
-                                    value: 'hybrid-swap',
-                                },
-                                {
-                                    text: 'brute-force',
-                                    value: 'brute-force',
-                                },
-                                {
-                                    text: 'branch-and-bound',
-                                    value: 'branch-and-bound',
-                                }
-                            ],
-                            callback: function (result) {
-                                if (result)
-                                {            
-                                    var method = result;
-                                    var bootboxContent = {title: "Get Possible Function Order", message: '<p>Please be patient...</p>'};
-                                    var xhr = $.ajax({
-                                        type: 'POST',
-                                        url: '/kadmos_get_possible_function_order',
-                                        data: {'graphID':graphID, 'sortingMethod':method, 'currentOrder':nodeOrder, 'sessionID': sessionID},
-                                        success: function(result)
-                                        {
-                                            if (result.includes("ERROR:"))
-                                            {
-                                                bootboxContent.message = result
-                                                kadmosErrorMessage(bootboxContent);
-                                            }
-                                            else
-                                            {
-                                                var updatedData = {};
-                                                updatedData = data;
-                                                var graphData = JSON.parse(result);             
-                                                for (var i = 0; i < updatedData.graphs.length; i++)
-                                                {
-                                                    if (graphID == updatedData.graphs[i].id)
-                                                    {
-                                                        updatedData.graphs[i] = graphData.graphs[0];   
-                                                    }
-                                                }
-                                                
-                                                clearView();
-                                                makeKadmosMenu(updatedData);
-                                                xdsm_script(updatedData,graphID);
-                                                
-                                                bootboxContent.message = "Success!"
-                                                kadmosSuccessMessage(bootboxContent)
-                                            }
-                                        },
-                                        error: function(result)
-                                        {
-                                            bootboxContent.message = result
-                                            kadmosErrorMessage(bootboxContent);
-                                        }
-                                    });
-                                    kadmosHavePatience(xhr, bootboxContent)
-                                }
-                            }
-                        });
-                    })
-                
-                fpgManipulations.append("li").append("a")
-                    .text("1.11. Remove unused outputs")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "<p><b>Remove unused outputs</b></p>" 
-                                  +"<p>Do you want to clean up the graph afterwards?</p>" 
-                                  +"<b>CAUTION:</b> This will remove all unused competences automatically as well!",
-                            inputType: 'select',
-                            value: "True",
-                            inputOptions: [{text:'yes', value:'True'}, {text:'no', value:'False'}],
-                            callback: function (selection) 
-                            {
-                                if (selection)
-                                {
-                                    var bootboxContent = {title: "Enrich FPG", message: '<p>Please be patient...</p>'};
-                                    var xhr = $.ajax({
-                                        type: 'POST',
-                                        url: '/kadmos_remove_unused_outputs',
-                                        data: {'graphID':graphID, 'currentOrder':nodeOrder, 'cleanUp':selection, 'sessionID': sessionID},
-                                        success: function(result)
-                                        {
-                                            if (result.includes("ERROR:"))
-                                            {
-                                                bootboxContent.message = result
-                                                kadmosErrorMessage(bootboxContent);
-                                            }
-                                            else
-                                            {
-                                                var updatedData = {};
-                                                updatedData = data;
-                                                var graphData = JSON.parse(result);             
-                                                for (var i = 0; i < updatedData.graphs.length; i++)
-                                                {
-                                                    if (graphID == updatedData.graphs[i].id)
-                                                    {
-                                                        updatedData.graphs[i] = graphData.graphs[0];   
-                                                    }
-                                                }
-                                                
-                                                clearView();
-                                                makeKadmosMenu(updatedData);
-                                                xdsm_script(updatedData,graphID);
-                                                
-                                                bootboxContent.message = "Success!"
-                                                kadmosSuccessMessage(bootboxContent)
-                                            }
-                                        },
-                                        error: function(result)
-                                        {
-                                            bootboxContent.message = result
-                                            kadmosErrorMessage(bootboxContent);
-                                        }
-                                    });
-                                    kadmosHavePatience(xhr, bootboxContent)
-                                }
-                            
-                            }
-                        })
-                    })
-                //####################################################################################################################
-                
-                
-                //aigner: MDPG manipulations
-                //####################################################################################################################				
-                var mpgManipulations_ul = optionsDiv.append("ul")
-				var mpgManipulations_li = mpgManipulations_ul.append("li")
-                    .on("mouseover", function(){
-                        d3.select(this)
-                            .style("cursor", "default")
-                    })
-                mpgManipulations_li.append("a").text("2. MDPG Manipulations")
-                var mpgManipulations = mpgManipulations_li.append("ul");
-                var xOffset_ul = mpgManipulations_li._groups[0][0].offsetLeft+mpgManipulations_li._groups[0][0].offsetWidth-40;
-                mpgManipulations.style("left", String(xOffset_ul)+"px")
-                
-                
-                //aigner: Kadmos function --> Start defining MDO problem
-                mpgManipulations.append("li").append("a")
-                    .text("2.1. Start defining MDAO architecture")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "<p>This will create an initial MDPG for your MDO problem. After clicking this button, you can go through the \"<b>MDPG manipulation</b>\" steps."
-                                  +"<p>Please type in a new name for the graph</p>",
-                            value: currentGraph.name,
-                            callback: function(newGraphName)
-                            {
-                                if (newGraphName)
-                                {
-                                    var newGraphID = '01';
-                                    data.graphs.forEach(function(graph) 
-                                    {
-                                        id_int = parseInt(graph.id)
-                                        if (data.graphs.length < 100){newGraphID = "0" + String(id_int+1);}
-                                        else{newGraphID = String(id_int+1);}
-                                    })
-                                    var bootboxContent = {title: "Start defining MDAO architecture", message: '<p>Please be patient...</p>'};
-                                    var xhr = $.ajax({
-                                        type: 'POST',
-                                        url: '/kadmos_start_defining_MDAO_architecture',
-                                        data: {'graphID':graphID, 'currentOrder': nodeOrder, 'newGraphName':newGraphName, 'newGraphID':newGraphID, 'sessionID': sessionID},
-                                        success: function(result)
-                                        {
-                                            if (result.includes("ERROR:"))
-                                            {
-                                                bootboxContent.message = result
-                                                kadmosErrorMessage(bootboxContent);
-                                            }
-                                            else
-                                            {
-                                                var updatedData = jQuery.extend(true, {}, data);
-                                                var graphData = JSON.parse(result);
-                                                
-                                                for (var i = 0; i < data.graphs.length; i++)
-                                                {
-                                                    if (graphID == data.graphs[i].id)
-                                                    {
-                                                        
-                                                        //Insert copied graph behind the original one
-                                                        updatedData.graphs.splice(i+1, 0, graphData.graphs[0])
-                                                    }
-                                                }
-                                                
-                                                clearView();
-                                                makeKadmosMenu(updatedData);
-                                                xdsm_script(updatedData,newGraphID);
-                                                
-                                                bootboxContent.message = "Success!"
-                                                kadmosSuccessMessage(bootboxContent)
-                                            }
-                                        },
-                                        error: function(result)
-                                        {
-                                            bootboxContent.message = result
-                                            kadmosErrorMessage(bootboxContent);
-                                        }
-                                    });
-                                    kadmosHavePatience(xhr, bootboxContent)
-                                }
-                            }
-                        })
-                    })
-                
-                
-                var MDAO_architecture = '-';
-                var coupling_decomposition = '-';
-                var DOE_method = '-';
-                mpgManipulations.append("li").append("a")
-                    .text("2.2. Select MDAO Architecture")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        var theOptions = []
-                        for (var i = 0; i<MDAO_architectures.length; i++){theOptions.push({text:MDAO_architectures[i], value:MDAO_architectures[i]})}
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "Select MDAO Architecture",
-                            inputType: 'select',
-                            value: MDAO_architecture,
-                            inputOptions: theOptions,
-                            callback: function (result) {if (result){MDAO_architecture = result;}}
-                        })
-                    })
-                    
-                mpgManipulations.append("li").append("a")
-                    .text("2.3. Select Coupling Decomposition")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        var theOptions = []
-                        for (var i = 0; i<coupling_decompositions.length; i++){theOptions.push({text:coupling_decompositions[i], value:coupling_decompositions[i]})}
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "Select Coupling Decomposition",
-                            value: coupling_decomposition,
-                            inputType: 'select',
-                            inputOptions: theOptions,
-                            callback: function (result) {if (result){coupling_decomposition = result;}}
-                        })
-                    })
-                    
-                mpgManipulations.append("li").append("a")
-                    .text("2.4. Select DOE Method")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        var theOptions = []
-                        for (var i = 0; i<DOE_methods.length; i++){theOptions.push({text:DOE_methods[i], value:DOE_methods[i]})}
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "Select DOE Method",
-                            value: DOE_method,
-                            inputType: 'select',
-                            inputOptions: theOptions,
-                            callback: function (result) {if (result){DOE_method = result;}}
-                        })
-                    })
-                    
-                mpgManipulations.append("li").append("a")
-                    .text("2.5. Impose MDAO Architecture")
-                    .on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-                    .on("mousedown", function()
-                    {
-                        var theOptions = [{text:"yes",value:"True"},{text:"no",value:"False"}]
-                        bootbox.hideAll();
-                        bootbox.prompt(
-                        {
-                            title: "Allow Unconverged Couplings?",
-                            value: "True",
-                            inputType: 'select',
-                            inputOptions: theOptions,
-                            callback: function (result) 
-                            {
-                                if (result)
-                                {   
-                                    var allow_unconverged_couplings = result;                                    
-                                    var bootboxContent = {title: "Impose MDAO Architecture", message: '<p>Please be patient...</p>'};
-                                    var xhr = $.ajax(
-                                    {
-                                        type: 'POST',
-                                        url: '/kadmos_impose_MDAO_architecture',
-                                        data: {'graphID':graphID,
-                                               'sessionID': sessionID,
-                                               'currentOrder':nodeOrder,
-                                               'mdao_architecture':MDAO_architecture,
-                                               'doe_method':DOE_method,
-                                               'coupling_decomposition':coupling_decomposition,
-                                               'allow_unconverged_couplings':allow_unconverged_couplings},
-                                        success: function(result)
-                                        {
-                                            if (result.includes("ERROR:"))
-                                            {
-                                                bootboxContent.message = result
-                                                kadmosErrorMessage(bootboxContent);
-                                            }
-                                            else
-                                            {
-                                                var updatedData = {};
-                                                updatedData = data;
-                                                var graphData = JSON.parse(result);             
-                                                for (var i = 0; i < updatedData.graphs.length; i++)
-                                                {
-                                                    if (graphID == updatedData.graphs[i].id)
-                                                    {
-                                                        updatedData.graphs[i] = graphData.graphs[0];   
-                                                    }
-                                                }
-                                                
-                                                clearView();
-                                                makeKadmosMenu(updatedData);
-                                                xdsm_script(updatedData,graphID);
-                                                
-                                                bootboxContent.message = "Success!"
-                                                kadmosSuccessMessage(bootboxContent)
-                                            }
-                                        },
-                                        error: function(result)
-                                        {
-                                            bootboxContent.message = result
-                                            kadmosErrorMessage(bootboxContent);
-                                        }
-                                    });
-                                    kadmosHavePatience(xhr, bootboxContent)
-                                
-                                }
-                            
-                            }
-                        })
-                    })
-                //####################################################################################################################
-                
-                
-                //aigner: Upload custom KADMOS script
-                //####################################################################################################################
-                var uploadCustomScript_ul = optionsDiv.append("ul")
-				var uploadCustomScript_li = uploadCustomScript_ul.append("li")
-                    .on("mouseover", function(){
-                        d3.select(this)
-                            .style("cursor", "pointer")
-                    })
-                    .on("mousedown", function(){
-                            bootbox.dialog({
-                                title: "Upload custom script",
-                                message: "<button id='downloadBtn' class='btn btn-primary'><i class='glyphicon glyphicon-download-alt '></i> Download template script</button>"
-                                        +"<form style='margin-top:20px;' id='scriptForm' method='post' enctype='multipart/form-data'>" 
-                                        +"<label>"
-                                        +"<text>Upload script file:</text>"
-                                        +"<input type='file' name='file[]' />"
-                                        +"<input type='submit' value='Submit'/>"
-                                        +"</label></form>",
-                                buttons : 
-                                { 
-                                    cancel: {
-                                        label: "Cancel",
-                                        className: 'btn-danger'
-                                    }
-                                }                                
-                            });
-                            
-                            //aigner: template for custom script that user can download
-                            $('#downloadBtn').on("mousedown", function(){
-                                    var script_template = "import sys\n\n"
-                                    +"from kadmos.graph import *\n\n\n"
-                                    +"def script(graph, mpg):\n"
-                                    +"    \"\"\"\n"
-                                    +"    Script to include manual operations in the KADMOS integration in VISTOMS\n\n"
-                                    +"    :param graph: Any kadmos graph\n"
-                                    +"    :param mpg: A corresponding MDO process graph\n"
-                                    +"    :return: graph, mpg\n"
-                                    +"    \"\"\"\n"
-                                    +"    # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #\n"
-                                    +"    #                                       ADD YOUR SCRIPT BELOW THIS LINE                                           #\n"
-                                    +"    # Example script:\n"
-                                    +"    # graph.remove_node('node_ID')\n"
-                                    +"    # graph.remove_edge('node_ID1', 'node_ID2')\n"
-                                    +"    #                                          END SCRIPT ABOVE THIS LINE                                             #\n"
-                                    +"    # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #\n"
-                                    +"    return graph, mpg\n"
-
-                                    download('script_template.py',script_template);
-                            })
-                            //upload of custom script
-                            $('#scriptForm').on('submit',function(event){
-                                event.preventDefault();
-                                var formData = new FormData($('#scriptForm')[0]);
-                                formData.append('graphID', graphID);
-                                formData.append('sessionID', sessionID);
-                               
-                                if (typeof currentGraph.xdsm.workflow !== 'undefined' && currentGraph.xdsm.workflow.length > 0) 
-                                {
-                                    // the array is defined and has at least one element
-                                    upload_custom_script()
-                                }
-                                else
-                                {
-                                    upload_custom_script()
-                                }
-                                
-                                function upload_custom_script()
-                                {
-                                    var bootboxContent = {title: "Upload custom KADMOS script", message: '<p>Please be patient...</p>'};
-                                    var xhr = $.ajax({
-                                        type: 'POST',
-                                        url: '/kadmos_run_custom_script',
-                                        data: formData,
-                                        processData: false,
-                                        contentType: false,
-                                        success: function(result)
-                                        {
-                                            if (result.includes("ERROR:"))
-                                            {
-                                                bootboxContent.message = result
-                                                kadmosErrorMessage(bootboxContent);
-                                            }
-                                            else
-                                            {
-                                                var updatedData = {};
-                                                updatedData = data;
-                                                var graphData = JSON.parse(result);             
-                                                for (var i = 0; i < updatedData.graphs.length; i++)
-                                                {
-                                                    if (graphID == updatedData.graphs[i].id)
-                                                    {
-                                                        updatedData.graphs[i] = graphData.graphs[0];   
-                                                    }
-                                                }
-                                                                                                                
-                                                clearView();
-                                                makeKadmosMenu(updatedData);
-                                                xdsm_script(updatedData,graphID);
-                                                
-                                                bootboxContent.message = "Success!"
-                                                kadmosSuccessMessage(bootboxContent)
-                                            }
-                                        },
-                                        error: function(result)
-                                        {
-                                            bootboxContent.message = result
-                                            kadmosErrorMessage(bootboxContent);
-                                        }
-                                    });
-                                    kadmosHavePatience(xhr, bootboxContent)
-                                }
-                            });
-                    })
-                    
-                uploadCustomScript_li.append("a").text("Upload Custom Script")
-                //####################################################################################################################
-                
-				
-				//aigner: Data Model Tree View Button
-				//####################################################################################################################
-				var dataModelDiv = d3.select(".xdsmDiv").append("div").attr("class","dataModelDiv").attr("transform","translate(10,0)")
-				var ul = dataModelDiv.append("ul")
-				var dropdown1 = ul.append("li").on("mouseover", function(){d3.select(this).style("cursor", "default")})
-				dropdown1.append("img").attr("src",fileReference.AGILE_Icon)
-					.attr("align","left")
-					.style("margin-left","6px")
-					.style("margin-right","-10px")
-					.style("margin-top","10px")
-					.style("margin-bottom","0px")
-					.attr("height","20")
-					.attr("width","20")
-				dropdown1.append("a").text("Data Model Tree")
-				var links = dropdown1.append("ul");
-                var xOffset_ul = dropdown1._groups[0][0].offsetLeft+dropdown1._groups[0][0].offsetWidth-40;
-                links.style("left", String(xOffset_ul)+"px")
-				for (var j=0; j< varCategories.length; j++)
-				{
-					//console.log(varCategories[j])
-					var linkLi = links.append("li");
-					var linkA = linkLi.append("a")
-						.attr("id",j)
-						.text(varCategories[j].description)
-						.on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-						.on("click", function()
-						{		
-							showFullTree(varCategories[this.id].name,varCategories[this.id].description)
-						})
-				}
-				//aigner: Set width of the div, so the VISTOMS dropdown (in the top of the page) still works
-				//dataModelDiv.style("width", String(dropdown1.node().getBoundingClientRect().width+20)+"px")
-				//####################################################################################################################
-                
-                //aigner: Data Model List View Button
-				//####################################################################################################################
-				//aigner: Function, that shows a list of elements
-                function showList(aTitle,aList,aMenu)
-                {
-                    if (aList.length != 0)
-                    {
-                        var d3_body = d3.select("body");
-                        
-                        var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                        panel_div.append("div").attr("class","panel-heading")
-                            .append("div").attr("class","panel_title").append("h4").text(aTitle)
-                        panel_div.append("input")
-                            .attr("id","myInput")
-                            .attr("placeholder","Filter search...")
-                            .attr("title","Type in a name")
-                            .attr("onkeyup","filterSearch()")
-                        var listGroup = panel_div.append("div").attr("class","panel-body")
-                            .append("table").attr("id","myTable")
-                            .append("tbody")
-                            
-                        var tr = listGroup
-                            .selectAll('tr')
-                            .data(aList).enter()
-                                .append('tr')
-                        var td = tr.append("td").html(function(d) { 
-                            if (d.xPath){return d.xPath;} 
-                            else {return d.name;} 
-                        })
-                        tr.on('contextmenu', d3.contextMenu(aMenu));
-                        $('.myPanel').lobiPanel({
-                            reload: false,
-                            editTitle: false,
-                            expand: false,
-                            unpin: false,
-                            resize: "none",
-                            minWidth: 200,
-                            minHeight: 200,
-                            maxWidth: 1100,
-                            maxHeight: 1200,
-                        });
-                        $('.myPanel').lobiPanel('unpin');
-                    }
-                }
-                
-                var ul_list = dataModelDiv.append("ul")
-				var dropdownList = ul_list.append("li").on("mouseover", function(){d3.select(this).style("cursor", "default")})
-				dropdownList.append("img").attr("src",fileReference.AGILE_Icon)
-					.attr("align","left")
-					.style("margin-left","6px")
-					.style("margin-right","-10px")
-					.style("margin-top","10px")
-					.style("margin-bottom","0px")
-					.attr("height","20")
-					.attr("width","20")
-				dropdownList.append("a").text("Data Model List")
-				var linksList = dropdownList.append("ul");
-                var xOffset_ul = dropdownList._groups[0][0].offsetLeft+dropdownList._groups[0][0].offsetWidth-40;
-                linksList.style("left", String(xOffset_ul)+"px")
-				for (var j=0; j< varCategories.length; j++)
-				{
-					//console.log(varCategories[j])
-					var linkLi = linksList.append("li");
-					var linkA = linkLi.append("a")
-						.attr("id",j)
-						.text(varCategories[j].description)
-						.on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-						.on("click", function()
-						{	
-                            var variables = JSON.parse(JSON.stringify(currentGraph.variableSchemes[varCategories[this.id].name]));
-                            variables.forEach(function(variable)
-                            {
-                                variable.name = variable.xPath
-                                //work around because nodeMenu expexts the data, to have a "data" object inside
-                                variable.data = variable
-                                variable.data.name = variable.xPath.split("/")[variable.xPath.split("/").length-1]
-                            })
-                            var title = "List view: full variable set categorized according to " + varCategories[this.id].description
-                            showList(title,variables,nodeMenu)
-						})
-				}
-				//aigner: Set width of the div, so the VISTOMS dropdown (in the top of the page) still works
-				//####################################################################################################################
-				
-                
-				//aigner: Tree option menu to select which kind of tree view the user wants to see
-				//#####################################################################//
-				var emptyArray;
-				function showFullTree(aCategory,categoryDescr)
-				{
-                    var headLine = "Full data model tree view; Categorization: " + categoryDescr;
-                    var d3_body = d3.select("body");
-                    var lobiID = String(getRandomInt(0,1000))
-                    var divClassName = 'treeDiv' + lobiID;
-                    var treeLayoutdiv = d3_body.append("div").attr("class",divClassName+" panel-default")
-													.style("left",(d3.event.pageX) + "px")
-													.style("top",(d3.event.pageY - 28) + "px")
-													.style("position", "absolute")
-                    treeLayoutdiv.append("div").attr("class","panel-heading")
-                        .append("div").attr("class","panel_title").append("h4").text(headLine)
-                    $('.' + divClassName).lobiPanel({
-                        reload: false,
-                        editTitle: false,
-                        unpin: false,
-                        minWidth: 200,
-                        maxWidth: 100000,
-                        minHeight: 200,
-                        maxHeight: 100000,
-                    });
-                    $('.'+divClassName).lobiPanel('unpin');
-					var treeLayoutSVG = treeLayoutdiv.append("svg").attr("class","treeLayoutSVG")
-					var treeLayout = treeLayoutSVG.append("g").attr("class","treeLayout");
-					maketreeLayout(emptyArray, treeLayout, treeLayoutSVG, treeLayoutdiv, divClassName, headLine, aCategory);
-				}
-				
-				var childrenItems = [];
-				for (var j=0; j< varCategories.length; j++)
-				{
-					childrenItems.push({title: 'according to ' + varCategories[j].description,
-								   varCategory: varCategories[j].name,
-								   description: varCategories[j].description,
-								   onMouseClick: function(elm, d, i) {showFullTree(d.varCategory,d.description)},
-								   onMouseOver: function(elm,d,i){}})
-				}
-				var treeOptionMenu = [
-				{
-					title: 'Show variable tree...',
-					onMouseDown: function(elm, d, i) {
-					},
-					onMouseUp: function(elm, d, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: childrenItems
-				}
-				]
-				//#####################################################################//
-				
-
-				//create the xdsm div
-				d3.select(".xdsmDiv").append("div").attr("class","xdsm");
-				//create tooltip
-				var tooltip = d3.select(".xdsmDiv").selectAll(".tooltip").data(['tooltip'])
-							  .enter().append("div")
-							.attr("class", "tooltip")
-							.style("opacity", 0);
-
-				var scenarioKeys = Object.keys(mdo).sort();
-				var xdsms = {};
-				
-				//If there is only one MDO and it is not named root, then it is created
-				if (scenarioKeys.indexOf('root') === -1) 
-				{
-					var scenarioKeys_tmp = [];
-					scenarioKeys_tmp.push('root');
-					scenarioKeys = scenarioKeys_tmp;
-					var mdo_tmp={};
-					mdo_tmp['root']=mdo;
-					mdo = mdo_tmp;
-				} 		
-				// new format managing several XDSM
-				var index = scenarioKeys.indexOf('root');
-				if (index > -1) 
-				{
-					scenarioKeys.splice(index, 1);
-				}
-				scenarioKeys.unshift('root');
-
-				var xdsm;
-				scenarioKeys.forEach(function(k) 
-				{
-					if (mdo.hasOwnProperty(k) && k =="root") 
-					{
-						//aigner: Here the graphs are created
-						var graph = new Graph(mdo[k], k);
-						//aigner: Here the xdsms are drawn
-						xdsms[k] = new Xdsm(graph, k, tooltip);
-						xdsms[k].draw(currentGraph.name);
-						xdsm = xdsms[k];
-						update_subXdsm(xdsms, k);
-						prepareTreeLayout(xdsms, k);
-					}
-				}, this)
-				
-					
-				xdsm.svg.selectAll(".node")
-				.each(function(node) 
-				{		
-					var gNode = this;
-					var d3gNode = d3.select(gNode);
-                    
-					scenarioKeys.forEach(function(k)
-					{
-						if (k == node.xdsm)
-						{
-							var cx, cy;
-							for (var j=0; j < gNode.childNodes.length; j++)
-							{
-								if(gNode.childNodes[j].nodeName != "text")
-								{
-									cx = gNode.childNodes[j].getAttribute("width")/2-13;
-									cy = -gNode.childNodes[j].getAttribute("height")/2+8;
-								}
-							}
-							//Expand Symbol is created
-							var expandSymbol = d3.select(gNode).append("g").attr("class", "expandSymbol");
-							var circle = expandSymbol.append("circle")
-								.attr("cx", cx)
-								.attr("cy", cy);
-							var line1 = expandSymbol.append("line");
-							var line2 = expandSymbol.append("line");
-							drawExpandSymbol( circle, line1,line2);
-							expandSymbol = expandSymbol
-							.on("mouseover", function(){circle.style("fill-opacity", .8);})
-							.on("mouseout", function(){circle.style("fill-opacity", .6)})
-							
-							.on("click", function()
-							{
-								//On mousedown, additional sub-workflows will be visualized
-								var createNew = true;
-								if(xdsms[k]){createNew=false;}                    
-								if (createNew == true)
-								{
-									var graph = new Graph(mdo[k], k);
-									xdsms[k] = new Xdsm(graph, k, tooltip);
-									xdsms[k].draw(currentGraph.name);
-									update_subXdsm(xdsms, k);
-									prepareTreeLayout(xdsms, k);
-									//Remove Symbol is created
-									var removeSymbol = xdsms[k].svg.append("g")
-										.attr("class", "removeSymbol");
-									var circle = removeSymbol.append("circle");
-									var minus = removeSymbol.append("line");
-									drawRemoveSymbol(xdsms[k], circle, minus);
-									//Clicking on remove symbol will remove sub-workflow
-									removeSymbol.append("svg:title").text("Click right to inspect");
-									removeSymbol = removeSymbol
-									.on("mouseover", function(){
-										circle.style("fill", "red").style("fill-opacity", .8);})
-									.on("mouseout", function(){
-										circle.style("fill", "red").style("fill-opacity", .6)})
-									.on("mousedown", function(){circle.style("fill", "darkred").style("fill-opacity",1);})
-									.on("mouseup", function(d)
-									{
-										xdsms[k].svg.remove();
-										d3.select(".treeDiv"+k).remove();
-										delete xdsms[k];
-									})
-									
-									xdsms[k].svg.selectAll(".node")
-										.each(function(d) 
-										{		
-											var gNode = this;
-											d3.select(gNode).on('contextmenu', d3.contextMenu(toolMenu));
-										})
-								}
-							})
-						}
-					})
-					d3gNode.append("svg:title").text("Click right to inspect");
-                    d3gNode = d3gNode.on('mouseover', function(){d3.select(this).style("cursor", "pointer")});
-                    if (this.__data__.name == "Coordinator")
-                    {
-                        d3gNode = d3gNode.on('contextmenu', d3.contextMenu(toolMenuCoor))
-                    }
-                    else
-                    {
-                        d3gNode = d3gNode.on('contextmenu', d3.contextMenu(toolMenu))
-                    }
-				})	
-				
-				function prepareTreeLayout(xdsms, refName)
-				{			
-					function showEdgeTree(data,aVarCategory,categoryDescr)
-					{
-                        var headLine = "Tree view: " + data.from + "  →  " + data.to + "; Categorization: " + categoryDescr;
-                        var d3_body = d3.select("body");
-                        var lobiID = String(getRandomInt(0,1000))
-                        var divClassName = "treeDiv" + lobiID;
-                        var treeLayoutdiv = d3_body.append("div").attr("class",divClassName + " panel-default")
-                                                        .style("left",(d3.event.pageX) + "px")
-                                                        .style("top",(d3.event.pageY - 28) + "px")
-                                                        .style("position", "absolute")
-                        treeLayoutdiv.append("div").attr("class","panel-heading")
-                            .append("div").attr("class","panel_title").append("h4").text(headLine)
-                        $('.'+divClassName).lobiPanel({
-                            reload: false,
-                            editTitle: false,
-                            unpin: false,
-                            minWidth: 1000,
-                            maxWidth: 100000,
-                            minHeight: 500,
-                            maxHeight: 100000,
-                        });
-                        $('.'+divClassName).lobiPanel('unpin');
-                        var treeLayoutSVG = treeLayoutdiv.append("svg").attr("class","treeLayoutSVG")
-                        var treeLayout = treeLayoutSVG.append("g").attr("class","treeLayout");
-                        maketreeLayout(data.name, treeLayout, treeLayoutSVG, treeLayoutdiv, divClassName, headLine, aVarCategory);
-					}
-					
-					function showEdgeTable(anEdge)
-					{						                        
-                        var headLine = "Edge Information (" + anEdge.from + " - " + anEdge.to + ")";
-						var anEdgeNameSplit = anEdge.name.split(',')
-						var numberOfconnections = anEdgeNameSplit.length;
-						var dimension=0;
-						var nullDim=false;
-						var undefinedLeafs;
-						var theLeafNodes = (JSON.parse(JSON.stringify(currentGraph.variableSchemes[varCategories[0].name])));
-						var pipeData = anEdge.name;
-						prune_tree(pipeData,theLeafNodes)
-						var undefLeafsNumber=0;
-						var defLeafsNumber=0;
-						for (var k=0;k<theLeafNodes.length;k++)
-						{
-							if (theLeafNodes[k].dimension!=null){dimension = dimension+theLeafNodes[k].dimension}
-							else{nullDim=true}
-							if (theLeafNodes[k].value.includes("could not be found")||theLeafNodes[k].value.includes("unknown"))
-							{
-								if (undefLeafsNumber==0){undefinedLeafs += theLeafNodes[k].xPath;}
-								else {undefinedLeafs += "," + theLeafNodes[k].xPath;}
-								undefLeafsNumber ++;
-							}
-							else
-							{
-								defLeafsNumber++;
-							}
-						}
-						
-						//Render data for table
-						var data = [];
-						data.push({ "name" : "Total number of connections", "value" : numberOfconnections })
-						data.push({ "name" : "Number of referenced connections", "value" : defLeafsNumber })
-						data.push({ "name" : "Dimension of referenced connections", "value" : String(dimension) })
-						if (undefinedLeafs)
-						{
-							data.push({ "name" : "Number of unreferenced connections", "value" :  undefLeafsNumber})					
-						}
-						
-                        var d3_body = d3.select("body");
-                        
-                        var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                        panel_div.append("div").attr("class","panel-heading")
-                            .append("div").attr("class","panel_title").append("h4").text(headLine)
-                        var listGroup = panel_div.append("div").attr("class","panel-body")
-                            .append("table").attr("id","myTable")
-                            .append("tbody")
-                            
-                        data.forEach(function(listElement)
-                        {
-                            var row = listGroup.append("tr")
-                            row.append("td").text(listElement.name)
-                            row.append("td").text(listElement.value)
-                            
-                        })
-                        $('.myPanel').lobiPanel({
-                            reload: false,
-                            editTitle: false,
-                            expand: false,
-                            unpin: false,
-                            resize: "none",
-                            minWidth: 200,
-                            minHeight: 200,
-                            maxWidth: 1100,
-                            maxHeight: 1200,
-                        });
-                        $('.myPanel').lobiPanel('unpin');
-					}
-					
-					xdsms[refName].svg.selectAll(".edge")
-					.each(function(edge) 
-					{
-						//edgeMenu --> functions for right click options
-						var edgeChildrenItemsTree = [];
-						for (var j=0; j< varCategories.length; j++)
-						{
-							edgeChildrenItemsTree.push({title: 'according to ' + varCategories[j].description,
-													varCategory: varCategories[j].name,
-													description: varCategories[j].description,
-													onMouseClick: function(elm, data, i) {showEdgeTree(edge,data.varCategory,data.description)},
-													onMouseOver: function(elm,data,i){}});
-						}
-                        var edgeChildrenItemsList = [];
-						for (var j=0; j< varCategories.length; j++)
-						{
-							edgeChildrenItemsList.push({title: 'according to ' + varCategories[j].description,
-                                varCategory: varCategories[j].name,
-                                description: varCategories[j].description,
-                                onMouseClick: function(elm, data, i) {
-                                    var variables = [];
-                                    var pipeData = edge.name;
-                                    var title = "List view: " + edge.from + "  →  " + edge.to + "; Categorization: " + data.description;
-                                    variables = JSON.parse(JSON.stringify(currentGraph.variableSchemes[data.varCategory]))
-                                    prune_tree(pipeData,variables)
-                                    variables.forEach(function(variable)
-                                    {
-                                        variable.name = variable.xPath
-                                        //work around because nodeMenu expexts the data, to have a "data" object inside
-                                        variable.data = variable
-                                        variable.data.name = variable.xPath.split("/")[variable.xPath.split("/").length-1]
-                                    })
-                                    
-                                    showList(title,variables,nodeMenu);
-                                },
-                                onMouseOver: function(elm,data,i){}});
-						}
-						var theEdge = this;
-						var edgeMenu = [
-						{
-							title: 'Show edge info',
-							onMouseDown: function(elm, k, i) {
-								showEdgeTable(edge)
-							},
-							onMouseUp: function(elm, k, i) {
-							},
-							onMouseOver: function(elm, d, i) {
-							},
-							childrenItems: []
-						},
-						{
-							title: 'Show variable tree...',
-							onMouseDown: function(elm, k, i) {
-							},
-							onMouseUp: function(elm, k, i) {
-							},
-							onMouseOver: function(elm, d, i) {
-							},
-							childrenItems: edgeChildrenItemsTree
-						},
-                        {
-							title: 'Show variable list...',
-							onMouseDown: function(elm, k, i) {
-							},
-							onMouseUp: function(elm, k, i) {
-							},
-							onMouseOver: function(elm, d, i) {
-							},
-							childrenItems: edgeChildrenItemsList
-						},
-						{
-							title: 'Delete a variable connection here...',
-							onMouseDown: function(elm, k, i) {
-                                deleteEdge(k)
-							},
-							onMouseUp: function(elm, k, i) {
-							},
-							onMouseOver: function(elm, d, i) {
-							},
-							childrenItems: {}
-						}
-						]
-                        
-                        function deleteEdge(anEdge)
-                        {         
-                            bootbox.hideAll();
-                            bootbox.confirm({
-								title: "Delete output from competence " + anEdge.from_uID,
-								message: "<form id='infos' action=''>\Full xPath of the variable: <input type='text' name='edgeName' />\</form>",
-								callback: function(result) {
-                                        if(result)
-                                        {
-                                            var formData = $('#infos').submit()[0];
-                                            bootbox.confirm("Are you sure you want to do this?", function(sure)
-                                            {
-                                                if (sure)
-                                                {
-                                                    var bootboxContent = {title: "Delete variable connection", message: '<p>Please be patient...</p>'};
-                                                    var xhr = $.ajax({
-                                                        type: 'POST',
-                                                        url: '/kadmos_delete_edge',
-                                                        data: {graphID: graphID, nodeName: anEdge.from_uID, edgeName: formData[0].value, 'currentOrder':nodeOrder, 'sessionID': sessionID},
-                                                        success: function(result)
-                                                        {
-                                                            if (result.includes("ERROR:"))
-                                                            {
-                                                                bootboxContent.message = result
-                                                                kadmosErrorMessage(bootboxContent);
-                                                            }
-                                                            else
-                                                            {
-                                                                var updatedData = {};
-                                                                updatedData = data;
-                                                                var graphData = JSON.parse(result);             
-                                                                for (var i = 0; i < updatedData.graphs.length; i++)
-                                                                {
-                                                                    if (graphID == updatedData.graphs[i].id)
-                                                                    {
-                                                                        updatedData.graphs[i] = graphData.graphs[0];   
-                                                                    }
-                                                                }
-                                                                                                                                
-                                                                clearView();
-                                                                makeKadmosMenu(updatedData);
-                                                                xdsm_script(updatedData,graphID);
-                                                                
-                                                                bootboxContent.message = "Success!"
-                                                                kadmosSuccessMessage(bootboxContent)
-                                                            }
-                                                        },
-                                                        error: function(result)
-                                                        {
-                                                            bootboxContent.message = result
-                                                            kadmosErrorMessage(bootboxContent);
-                                                        }
-                                                    });
-                                                    kadmosHavePatience(xhr, bootboxContent)
-                                                }
-                                            })
-                                        }
-									}     
-                            });
-                            
-                            $('form').on('submit',function(event){
-                                event.preventDefault();
-                            });
-                        
-                        
-                        }
-						
-						var thisEdge = d3.select(this);
-						//thisEdge.append("svg:title").text("Click right to inspect");
-						thisEdge.on('contextmenu', d3.contextMenu(edgeMenu))
-					})
-				}
-				
-               
-				function maketreeLayout(pipeData, layout, svg, div, aLobiID, aName, aVarCategory)
-				{			
-                    var treeData = (JSON.parse(JSON.stringify(currentGraph.variableSchemes[aVarCategory])));				
-                    //aigner: Build the tree layout                    
-                    //######################################################################
-                    //Function to prune the tree according to list of xPaths that are actually there
-                    //The tree will only be pruned if there is pipeData, such as in an edge or for the input of a tool
-                    if (pipeData)
-                    {
-                        prune_tree(pipeData, treeData);
-                    }                    
-                    //build tree layout for vistoms
-                    var newTree = {};
-                    buildTree(newTree, treeData)                    
-                    treeData = newTree
-                    //######################################################################
-                    
-                    // Set the dimensions and margins of the diagram
-                    var margin = {top: 20, right: 90, bottom: 20, left: 90},
-                        width = 960 - margin.left - margin.right,
-                        height = 500 - margin.top - margin.bottom;
-
-                    // append the svg object to the body of the page
-                    // appends a 'group' element to 'svg'
-                    // moves the 'group' element to the top left margin
-                    var offset_tmp = 60;
-                    svg = svg.attr("width", width + margin.right + margin.left+offset_tmp)
-                             .attr("height", height + margin.top + margin.bottom+offset_tmp);
-                    div = div.attr("width", width + margin.right + margin.left+offset_tmp)
-                             .attr("height", height + margin.top + margin.bottom+offset_tmp);
-                    layout = layout
-                        .attr("width", width + margin.right + margin.left)
-                        .attr("height", height + margin.top + margin.bottom);
-                    var name;
-                    var rect = layout.append("rect")
-                            .attr("class","treeFrame")
-                            .attr("width", 0)
-                            .attr("height", 70)
-                            .attr("transform", "translate("
-                              + String(10) + "," + String(10) + ")")
-                            .attr("fill", "white")
-                            .attr("stroke", "darkgrey")
-                            .attr("stroke-width", 0)
-                            .attr("fill-opacity", 0.8)
-                    //aigner: Put remove button on top of the rect
-                    d3.selectAll(".treeRemoveSymbol").moveToFront();
-                    
-                    //aigner: Exit, if no tree data is available!
-                    if (!treeData.children || treeData.children.length==0)
-                    {
-                        var newText = layout.append('text')
-                        .attr("dx", 40)
-                        .attr("dy", 55)
-                        .style("font-family", "Arial")
-                        .style("font-size", "32pt")
-                        .style("font-weight", "bold")
-                        .html(function (d) {
-                            return 'No tree view available! &#8594; Please check data for consistency!';
-                        });
-                        
-                        var newWidth;
-                        rect.attr("width",  function(d) {
-                            newWidth = this.parentNode.getBBox().width+20;
-                            return newWidth;}) 
-                        div = div.attr("width", newWidth+30)
-                        svg = svg.attr("width", newWidth+30)
-                        return;
-                    }
-                    
-                    // Calculate total nodes, max label length
-                    var totalNodes = 0;
-                    var maxLabelLength = 0;
-                    
-                    var i = 0,
-                        duration = 500,
-                        root;
-
-                    // declares a tree layout and assigns the size
-                    var treemap = d3.tree().size([height, width]);
-
-                    // Assigns parent, children, height, depth
-                    root = d3.hierarchy(treeData, function(d) { return d.children; });
-                    root.x0 = height / 2;
-                    root.y0 = 0;
-                    
-                    // Append a group which holds all nodes and which the zoom Listener can act upon.
-                    var svgGroup_xOff = root.data.name.length*10
-                    var svgGroup = layout.append("g")
-                        .attr("transform", "translate("+ svgGroup_xOff + "," + String(margin.top+10) + ")");
-                    
-                        
-                    // Collapse root initially
-                    collapse(root);
-                    update(root);
-
-                    // Collapse the node and all it's children
-                    function collapse(d) {
-                      if(d.children) {
-                        d._children = d.children
-                        d._children.forEach(collapse)
-                        d.children = null
-                      }
-                    }
-                    // Collapse the node and all it's children
-                    function expand(d) {
-                      if(d._children) {
-                        d.children = d._children
-                        d.children.forEach(expand)
-                        d._children = null
-                      }
-                    }
-                    // Toggle children on click.
-                    function click(d) 
-                    {
-                        if (d.children) {
-                            d._children = d.children;
-                            d.children = null;
-                        } else 
-                        {
-                            d.children = d._children;
-                            d._children = null;
-                        }
-                        update(d);
-                    }
-                    // Collapse/expand entire tree on double-click
-                    function dblclick(d) 
-                    {
-                        if(d.children) 
-                        {
-                            collapse(d);
-                        }
-                        else if(d._children)
-                        {
-                            expand(d);
-                        }
-                        update(d);
-                    }	
-                    
-                    function update(source) 
-                    {
-                        var levelWidth = [1];
-                        var getLevelWidth = function(level, n) 
-                        {
-                            if (n.children && n.children.length > 0) {
-                                if (levelWidth.length <= level + 1) levelWidth.push(0);
-                                
-                                //establish maxLabelLength
-                                maxLabelLength = Math.max(n.data.name.length, maxLabelLength);
-                                
-                                levelWidth[level + 1] += n.children.length;
-                                n.children.forEach(function(d) {
-                                    getLevelWidth(level + 1, d);
-                                });
-                            }
-                        };
-                        getLevelWidth(0, root);
-                        var newHeight = d3.max(levelWidth) * 60; // 20 pixels per line
-                        //BENNI: fill in viewerHeight instead of newHeight for other expanding/collapsing beaviour 
-                        
-                        layout = layout.attr("height", newHeight + margin.top + margin.bottom)
-                        svgGroup = svgGroup.attr("height", newHeight + margin.top + margin.bottom)
-                        treemap = treemap.size([newHeight, width]);
-                        
-                        
-                        // Assigns the x and y position for the nodes
-                        var treeData = treemap(root);
-
-                        // Compute the new tree layout.
-                        var nodes = treeData.descendants(),
-                            links = treeData.descendants().slice(1);
-                        
-                        //aigner: count all descendants of a node
-                        function countDescendants(node, counter) 
-                        {
-                            if (node._children)
-                            {
-                                node._children.forEach(function(n)
-                                {
-                                    counter = countDescendants(n, counter);
-                                });
-                            }
-                            else if (node.children)
-                            {
-                                node.children.forEach(function(n)
-                                {
-                                    counter = countDescendants(n, counter);
-                                });
-                            }
-                            else
-                            {
-                                counter ++;
-                            }
-                            return counter;
-                        }
-                        
-                        
-                        var depth_tmp = 0;
-                        var labelLength = [];
-                        labelLength.push(0);
-                        nodes.forEach(function(d) 
-                        {				
-                            //aigner: If node is collapsed show number of ancestors
-                            if (d._children)
-                            {
-                                d._childrenNum = countDescendants(d, 0);
-                                d.data.text = d.data.name + " (" + d._childrenNum + ")";
-                            }
-                            else 
-                            {
-                                d.data.text = d.data.name
-                            }
-                            
-                            //aigner: Find maximum labelLength for each level
-                            if (d.depth>depth_tmp)
-                            {
-                                depth_tmp = d.depth;
-                                labelLength.push(d.data.text.length);
-                            }
-                            else
-                            {
-                                if (d.depth!=0){labelLength[labelLength.length-1] = Math.max(d.data.text.length, labelLength[labelLength.length-1]);}
-                            }
-                        });
-                        // Set widths between levels based on labelLength of each level.
-                        var y_tmp = 100;		
-                        var depth_tmp = 0;							
-                        nodes.forEach(function(d) 
-                        {
-                            if (d.depth>depth_tmp)
-                            {
-                                depth_tmp = d.depth;
-                                d.y = y_tmp+(labelLength[depth_tmp])*12+50;
-                            }
-                            else
-                            {
-                                d.y = y_tmp;
-                            }
-                            newWidth=d.y;
-                            y_tmp = d.y;
-                        });
-                        
-                        newWidth=Math.max(newWidth,getTextWidth(aName,"Arial 12pt"));
-                        //aigner: Adjust height and width of the frame
-                        $('.' + aLobiID).lobiPanel('setWidth', newWidth + margin.top + margin.bottom +400+maxLabelLength*25+offset_tmp);
-                        $('.' + aLobiID).lobiPanel('setHeight', newHeight + margin.top + 2*margin.bottom+offset_tmp);
-                        div = div.attr("height", newHeight + margin.top + margin.bottom+offset_tmp)
-                        div = div.attr("width", newWidth + margin.top + margin.bottom +400+maxLabelLength*25+offset_tmp)
-                            .on("mousedown", function(d) {
-                                //d3.select(this).moveToFront();
-                            })
-                        svg = svg.attr("height", newHeight + margin.top + margin.bottom+offset_tmp)
-                        svg = svg.attr("width", newWidth + margin.top + margin.bottom +400+maxLabelLength*25+offset_tmp)
-                        rect = rect.attr("height", newHeight + margin.top + margin.bottom)
-                        rect = rect.attr("width", newWidth + margin.top + margin.bottom+400+maxLabelLength*15)
-                        
-                        
-                        
-                        // ****************** Nodes section ***************************
-                        // Update the nodes...
-                        var node = svgGroup.selectAll('g.treeNode')
-                          .data(nodes, function(d) {return d.id || (d.id = ++i); });
-                        
-                        var dblclick_timer = false;
-                        // Enter any new modes at the parent's previous position.
-                        var nodeEnter = node.enter().append('g')
-                          .attr('class', 'treeNode')
-                          .attr("transform", function(d) {
-                            return "translate(" + source.y0 + "," + source.x0 + ")";
-                        })
-                        .on("mousedown", function(d) {
-                            //prevent tree from expanding on right click!
-                            if (d3.event.which != 3)
-                            {
-                                // if double click timer is active, this click is the double click
-                                if ( dblclick_timer )
-                                {
-                                    clearTimeout(dblclick_timer)
-                                    dblclick_timer = false
-                                    // double click code code comes here
-                                    //console.log("DOUBLE CLICK")
-                                    dblclick(d);
-                                }
-                                // otherwise, what to do after single click (double click has timed out)
-                                else dblclick_timer = setTimeout( function(){
-                                    dblclick_timer = false
-                                    // single click code code comes here
-                                    //console.log("SINGLE CLICK")
-                                    click(d);
-                                }, 250)
-                            }
-                            
-                        })
-                        
-                        // Add Circle for the nodes
-                        nodeEnter.append('circle')
-                          .attr('class', 'treeNode')
-                          .attr('r', 4.5)
-                          .style("fill", function(d) {
-                                if (d._children)
-                                {
-                                    if(aName.includes("Input")){return '#ea9999'}
-                                    else if(aName.includes("Output")){return '#d6ea99'}
-                                    else {return "lightsteelblue"}
-                                }
-                                else {return "#fff"}
-                          })
-                          .style("stroke", function(d) {
-                                if(aName.includes("Input")){
-                                    //console.log(d);
-                                    return '#CC0000'}
-                                else if(aName.includes("Output")){
-                                    //console.log(d);
-                                    return '#99CC00'}
-                          });
-
-                        // Add labels for the nodes
-                        nodeEnter.append('text')
-                          .attr('class', 'nodeText')
-                          .attr("dy", ".35em")
-                          .attr("x", function(d) {
-                              return d.children || d._children ? -13 : 13;
-                          })
-                          .attr("text-anchor", function(d) {
-                              return d.children || d._children ? "end" : "start";
-                          })
-                          //.text(function(d) { return d.data.text; });
-                          
-                        
-                        //Function writeTreeToXML goes through tree nodes and puts the into an xml document
-                        function writeTreeToXML(aNode,anXMLDoc,anXPath)
-                        {
-                            //Variable "children" 
-                            //--> One children variable, no matter whether a node has "_children" (collapsed) or "children" (expanded)
-                            var children;
-                            if (aNode._children){children = aNode._children;}
-                            else if (aNode.children){children = aNode.children;}
-                            
-                            //Get current xml element with its xPath
-                            var element = anXMLDoc.evaluate(anXPath,anXMLDoc, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null ).singleNodeValue;
-                            if (element != null) {element.value = '...';}
-                            
-                            //If a node has children (collapsed or expanded), loop through them
-                            if (children)
-                            {
-                                for (var i=0; i < children.length;i++)
-                                {
-                                    //Name of the new XML element --> childName
-                                    var child = children[i];
-                                    var childName = child.data.name.split(/[\[\]]+/);//Split childName at "[]" which is the uID 
-                                    var cleanChildName = childName[0].split(/[\+\*\^\-\ \#]+/);//Split childName all special characters
-                                    var newNode = anXMLDoc.createElement(String(cleanChildName[0]));
-                                    
-                                    //The children are appended to the xPath --> newXPath
-                                    var newXPath = anXPath+"/"+cleanChildName[0];
-                                    
-                                    //If childName contains a uID, make the uID an attribute
-                                    if (childName[1])
-                                    {
-                                        if (parseInt(childName[1]))
-                                        {
-                                            var dummyID = childName[1];
-                                            newNode.setAttribute("dummyID", dummyID)
-                                            newXPath = newXPath+"[@dummyID='"+dummyID+"']";
-                                        }
-                                        else
-                                        {
-                                            var uID = childName[1];
-                                            newNode.setAttribute("uID", uID)
-                                            newXPath = newXPath+"[@uID='"+uID+"']";
-                                        }
-                                    }
-                                    if (cleanChildName.length>1) {newNode.setAttribute("elementName", childName[0])};
-                                    
-                                    //Append the newNode to the xml structure
-                                    element.appendChild(newNode);
-                                    
-                                    
-                                    
-                                    ////aigner: Sorting of XML elements according to "uID"
-                                    // var items = element.children;
-                                    // var itemsArr = [];
-                                    // for (var j in items) {
-                                        // if (items[j].nodeType == 1) { // get rid of the whitespace text nodes
-                                            // itemsArr.push(items[j]);
-                                        // }
-                                    // }
-                                    // itemsArr.sort(function(a,b){
-                                        // if (a.getAttribute("uID") < b.getAttribute("uID"))
-                                            // return -1;
-                                        // if (a.getAttribute("uID") > b.getAttribute("uID"))
-                                            // return 1;
-                                        // return 0;
-                                        // });
-
-                                    // for (j = 0; j < itemsArr.length; ++j) {
-                                      // element.appendChild(itemsArr[j]);
-                                    // }
-                                    
-                                    //call function writeTreeToXML recursively for all children
-                                    writeTreeToXML(child,anXMLDoc,newXPath)
-                                }
-                            }
-                            else
-                            {
-                                if (aNode.data.value){element.innerHTML = String(aNode.data.value);}
-                                else{element.innerHTML = " ";}
-                            }
-                            //return the xml document
-                            return anXMLDoc;
-                        }
-                        
-                        function removeAttributeInAllElements(aDocument,attribute)
-                        {
-                          var matchingElements = [];
-                          var allElements = aDocument.getElementsByTagName('*');
-                          for (var i = 0, n = allElements.length; i < n; i++)
-                          {
-                            if (allElements[i].getAttribute(attribute) !== null)
-                            {
-                                allElements[i].removeAttribute(attribute);
-                            }
-                          }
-                          return matchingElements;
-                        }
-                        
-                        function putAncestorsInXMLString(strWrapper, aNode)
-                        {
-                            //Name of the new XML element
-                            var nodeName = aNode.data.name.split(/[\[\]]+/);//Split name at "[]" which is the uID 
-                            var cleanNodeName = nodeName[0].split(/[\+\*\^\-\ \#]+/);//Split nodeName all special characters
-                            //If nodeName contains a uID, make the uID an attribute
-                            if (nodeName[1])
-                            {
-                                var uID = nodeName[1];
-                                strWrapper.val = "<"+cleanNodeName[0]+" uID='"+ uID +"'>"+strWrapper.val+"</"+cleanNodeName[0]+">";;
-                            }
-                            else
-                            {
-                                strWrapper.val = "<"+cleanNodeName[0]+">"+strWrapper.val+"</"+cleanNodeName[0]+">";;
-                            }
-                            var aParent = aNode.parent;
-                            if (aParent)
-                            {
-                                return putAncestorsInXMLString(strWrapper, aParent);
-                            }
-                            else 
-                            {
-                                return strWrapper;
-                            }
-                        }
-                        
-                        function putAncestorsInXPath(strWrapper, aNode)
-                        {
-                            //Name of the new XML element
-                            var nodeName = aNode.data.name.split(/[\[\]]+/);//Split name at "[]" which is the uID 
-                            var cleanNodeName = nodeName[0].split(/[\+\*\^\-\ \#]+/);//Split nodeName all special characters
-                            //If nodeName contains a uID, make the uID an attribute
-                            if (nodeName[1])
-                            {
-                                var uID = nodeName[1];
-                                strWrapper.val = "/"+cleanNodeName[0]+"[@uID='"+uID+"']"+strWrapper.val;
-                            }
-                            else
-                            {
-                                strWrapper.val = "/"+cleanNodeName[0]+strWrapper.val;
-                            }
-                            var aParent = aNode.parent;
-                            if (aParent)
-                            {
-                                return putAncestorsInXPath(strWrapper, aParent);
-                            }
-                            else 
-                            {
-                                return strWrapper;
-                            }
-                        }
-                        
-                        var nodeTreeMenu = nodeMenu;
-                        var treeMenu = [
-                            {
-                                title: 'Download full tree as XML-file',
-                                onMouseDown: function(elm, d, i) {
-                                    //Begin xml structure with the first element
-                                    var xmlString = "<"+nodes[0].data.name+">"+"</"+nodes[0].data.name+">";
-                                    //Create a new xml document
-                                    var parser = new DOMParser();
-                                    var xmlDocument = parser.parseFromString(xmlString, "text/xml"); //important to use "text/xml"
-                                    //Get initial xPath of the tree and pass it to the function "writeTreeToXML"
-                                    var initialXPath = "/"+nodes[0].data.name;								
-                                    writeTreeToXML(nodes[0],xmlDocument,initialXPath);
-                                    //remove all attributes dummyID
-                                    removeAttributeInAllElements(xmlDocument,'dummyID');
-                                    //Make the xml document a string
-                                    var serializer = new XMLSerializer();
-                                    var xmlString = serializer.serializeToString(xmlDocument);
-                                    xmlString = vkbeautify.xml(xmlString);														
-                                    //Download a document with the xml-schema
-                                    download(aName+'_full.xml',xmlString);						
-                                },
-                                onMouseUp: function(elm, d, i) {
-                                },
-                                onMouseOver: function(elm, d, i) {
-                                },
-                                childrenItems: []
-                            },
-                            {
-                                title: 'Download tree as XML-file from current node',
-                                onMouseDown: function(elm, d, i) {
-                                    var xmlString = putAncestorsInXMLString({ val : '' }, d).val;
-                                    var initialXPath = putAncestorsInXPath({ val : '' }, d).val;												
-                                    //Create a new xml document
-                                    var parser = new DOMParser();
-                                    var xmlDocument = parser.parseFromString(xmlString, "text/xml"); //important to use "text/xml"
-                                    //Get initial xPath of the tree and pass it to the function "writeCurrentTreeToXML"
-                                    writeTreeToXML(d,xmlDocument,initialXPath);
-                                    //remove all attributes dummyID
-                                    removeAttributeInAllElements(xmlDocument,'dummyID');
-                                    //Make the xml document a string
-                                    var serializer = new XMLSerializer();
-                                    xmlString = serializer.serializeToString(xmlDocument);
-                                    xmlString = vkbeautify.xml(xmlString);														
-                                    //Download a document with the xml-schema
-                                    download(aName+"_"+d.data.name+'.xml',xmlString);						
-                                },
-                                onMouseUp: function(elm, d, i) {
-                                },
-                                onMouseOver: function(elm, d, i) {
-                                },
-                                childrenItems: []
-                            }
-                        ]
-                        var nodeTreeMenu = nodeMenu.concat(treeMenu);
-                        
-                        
-                        
-                        nodeEnter = nodeEnter
-                        .on('contextmenu', d3.contextMenu(nodeTreeMenu));                          
-                        
-                        
-                        nodeEnter.append("svg:title").text("Click left to expand, click right to inspect")
-                        
-                        
-
-                        // UPDATE
-                        var nodeUpdate = nodeEnter.merge(node);
-
-                        // Transition to the proper position for the node
-                        nodeUpdate.transition()
-                        .duration(duration)
-                        .attr("transform", function(d) { 
-                            return "translate(" + d.y + "," + d.x + ")";
-                         });
-
-                        // Update the node attributes and style
-                        nodeUpdate.select('circle.treeNode')
-                        .attr('r', 4.5)
-                        .style("fill", function(d) {
-                                if (d._children)
-                                {
-                                    if(aName.includes("Input")){return '#ea9999'}
-                                    else if(aName.includes("Output")){return '#d6ea99'}
-                                    else {return "lightsteelblue"}
-                                }
-                                else {return "#fff"}
-                          })
-                        .attr('cursor', 'pointer');
-                        
-                        nodeUpdate.select('text')
-                        .text(function(d) { return d.data.text; });
-
-
-                        // Remove any exiting nodes
-                        var nodeExit = node.exit().transition()
-                          .duration(duration)
-                          .attr("transform", function(d) {
-                              return "translate(" + source.y + "," + source.x + ")";
-                          })
-                          .remove();
-
-                        // ****************** links section ***************************
-
-                        // Update the links...
-                        var link = svgGroup.selectAll('path.treeLink')
-                          .data(links, function(d) { return d.id; });
-
-                        // Enter any new links at the parent's previous position.
-                        var linkEnter = link.enter().insert('path', "g")
-                          .attr("class", "treeLink")
-                          .attr('d', function(d){
-                            var o = {x: source.x0, y: source.y0}
-                            return diagonal(o, o)
-                          });
-
-                        // UPDATE
-                        var linkUpdate = linkEnter.merge(link);
-
-                        // Transition back to the parent element position
-                        linkUpdate.transition()
-                          .duration(duration)
-                          .attr('d', function(d){ return diagonal(d, d.parent) });
-
-                        // Remove any exiting links
-                        var linkExit = link.exit().transition()
-                          .duration(duration)
-                          .attr('d', function(d) {
-                            var o = {x: source.x, y: source.y}
-                            return diagonal(o, o)
-                          })
-                          .remove();
-
-                        // Store the old positions for transition.
-                        nodes.forEach(function(d){
-                        d.x0 = d.x;
-                        d.y0 = d.y;
-                        });
-
-                        // Creates a curved (diagonal) path from parent to the child nodes
-                        function diagonal(s, d) {
-                        return "M" + s.y + "," + s.x
-                              + "C" + (s.y + d.y) / 2 + "," + s.x
-                              + " " + (s.y + d.y) / 2 + "," + d.x
-                              + " " + d.y + "," + d.x;
-                        }
-                    }
-				}
-			}
-			startXDSM(data,graphID);
-
-			////aigner: Unused functions --> Could be helpful at some point
-			////aigner: clone function, so that original object is not overwritten but deep copied
-			// function clone(obj) {
-				// if (null == obj || "object" != typeof obj) return obj;
-				// var copy = obj.constructor();
-				// for (var attr in obj) {
-					// if (obj.hasOwnProperty(attr)) copy[attr] = obj[attr];
-				// }
-				// return copy;
-			// }
-			////aigner: cleanArray Function
-			// function cleanArray(actual) 
-			// {
-				// var newArray = new Array();
-				// for (var i = 0; i < actual.length; i++) 
-				// {
-					// if (actual[i]) 
-					// {
-						// newArray.push(actual[i]);
-					// }
-				// }
-				// return newArray;
-			// }
-			//#####################################################################//
-
-
-			},{"./src/animation":2,"./src/graph":3,"./src/xdsm":5,"d3":1}]},{},[6]);
-		}
-		
-		function edgeBundles_script(data,graphID)
-		{
-			
-			(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
-			!function(){function n(n){return n&&(n.ownerDocument||n.document||n).documentElement}function t(n){return n&&(n.ownerDocument&&n.ownerDocument.defaultView||n.document&&n||n.defaultView)}function e(n,t){return t>n?-1:n>t?1:n>=t?0:NaN}function r(n){return null===n?NaN:+n}function i(n){return!isNaN(n)}function u(n){return{left:function(t,e,r,i){for(arguments.length<3&&(r=0),arguments.length<4&&(i=t.length);i>r;){var u=r+i>>>1;n(t[u],e)<0?r=u+1:i=u}return r},right:function(t,e,r,i){for(arguments.length<3&&(r=0),arguments.length<4&&(i=t.length);i>r;){var u=r+i>>>1;n(t[u],e)>0?i=u:r=u+1}return r}}}function o(n){return n.length}function a(n){for(var t=1;n*t%1;)t*=10;return t}function l(n,t){for(var e in t)Object.defineProperty(n.prototype,e,{value:t[e],enumerable:!1})}function c(){this._=Object.create(null)}function f(n){return(n+="")===bo||n[0]===_o?_o+n:n}function s(n){return(n+="")[0]===_o?n.slice(1):n}function h(n){return f(n)in this._}function p(n){return(n=f(n))in this._&&delete this._[n]}function g(){var n=[];for(var t in this._)n.push(s(t));return n}function v(){var n=0;for(var t in this._)++n;return n}function d(){for(var n in this._)return!1;return!0}function y(){this._=Object.create(null)}function m(n){return n}function M(n,t,e){return function(){var r=e.apply(t,arguments);return r===t?n:r}}function x(n,t){if(t in n)return t;t=t.charAt(0).toUpperCase()+t.slice(1);for(var e=0,r=wo.length;r>e;++e){var i=wo[e]+t;if(i in n)return i}}function b(){}function _(){}function w(n){function t(){for(var t,r=e,i=-1,u=r.length;++i<u;)(t=r[i].on)&&t.apply(this,arguments);return n}var e=[],r=new c;return t.on=function(t,i){var u,o=r.get(t);return arguments.length<2?o&&o.on:(o&&(o.on=null,e=e.slice(0,u=e.indexOf(o)).concat(e.slice(u+1)),r.remove(t)),i&&e.push(r.set(t,{on:i})),n)},t}function S(){ao.event.preventDefault()}function k(){for(var n,t=ao.event;n=t.sourceEvent;)t=n;return t}function N(n){for(var t=new _,e=0,r=arguments.length;++e<r;)t[arguments[e]]=w(t);return t.of=function(e,r){return function(i){try{var u=i.sourceEvent=ao.event;i.target=n,ao.event=i,t[i.type].apply(e,r)}finally{ao.event=u}}},t}function E(n){return ko(n,Co),n}function A(n){return"function"==typeof n?n:function(){return No(n,this)}}function C(n){return"function"==typeof n?n:function(){return Eo(n,this)}}function z(n,t){function e(){this.removeAttribute(n)}function r(){this.removeAttributeNS(n.space,n.local)}function i(){this.setAttribute(n,t)}function u(){this.setAttributeNS(n.space,n.local,t)}function o(){var e=t.apply(this,arguments);null==e?this.removeAttribute(n):this.setAttribute(n,e)}function a(){var e=t.apply(this,arguments);null==e?this.removeAttributeNS(n.space,n.local):this.setAttributeNS(n.space,n.local,e)}return n=ao.ns.qualify(n),null==t?n.local?r:e:"function"==typeof t?n.local?a:o:n.local?u:i}function L(n){return n.trim().replace(/\s+/g," ")}function q(n){return new RegExp("(?:^|\\s+)"+ao.requote(n)+"(?:\\s+|$)","g")}function T(n){return(n+"").trim().split(/^|\s+/)}function R(n,t){function e(){for(var e=-1;++e<i;)n[e](this,t)}function r(){for(var e=-1,r=t.apply(this,arguments);++e<i;)n[e](this,r)}n=T(n).map(D);var i=n.length;return"function"==typeof t?r:e}function D(n){var t=q(n);return function(e,r){if(i=e.classList)return r?i.add(n):i.remove(n);var i=e.getAttribute("class")||"";r?(t.lastIndex=0,t.test(i)||e.setAttribute("class",L(i+" "+n))):e.setAttribute("class",L(i.replace(t," ")))}}function P(n,t,e){function r(){this.style.removeProperty(n)}function i(){this.style.setProperty(n,t,e)}function u(){var r=t.apply(this,arguments);null==r?this.style.removeProperty(n):this.style.setProperty(n,r,e)}return null==t?r:"function"==typeof t?u:i}function U(n,t){function e(){delete this[n]}function r(){this[n]=t}function i(){var e=t.apply(this,arguments);null==e?delete this[n]:this[n]=e}return null==t?e:"function"==typeof t?i:r}function j(n){function t(){var t=this.ownerDocument,e=this.namespaceURI;return e===zo&&t.documentElement.namespaceURI===zo?t.createElement(n):t.createElementNS(e,n)}function e(){return this.ownerDocument.createElementNS(n.space,n.local)}return"function"==typeof n?n:(n=ao.ns.qualify(n)).local?e:t}function F(){var n=this.parentNode;n&&n.removeChild(this)}function H(n){return{__data__:n}}function O(n){return function(){return Ao(this,n)}}function I(n){return arguments.length||(n=e),function(t,e){return t&&e?n(t.__data__,e.__data__):!t-!e}}function Y(n,t){for(var e=0,r=n.length;r>e;e++)for(var i,u=n[e],o=0,a=u.length;a>o;o++)(i=u[o])&&t(i,o,e);return n}function Z(n){return ko(n,qo),n}function V(n){var t,e;return function(r,i,u){var o,a=n[u].update,l=a.length;for(u!=e&&(e=u,t=0),i>=t&&(t=i+1);!(o=a[t])&&++t<l;);return o}}function X(n,t,e){function r(){var t=this[o];t&&(this.removeEventListener(n,t,t.$),delete this[o])}function i(){var i=l(t,co(arguments));r.call(this),this.addEventListener(n,this[o]=i,i.$=e),i._=t}function u(){var t,e=new RegExp("^__on([^.]+)"+ao.requote(n)+"$");for(var r in this)if(t=r.match(e)){var i=this[r];this.removeEventListener(t[1],i,i.$),delete this[r]}}var o="__on"+n,a=n.indexOf("."),l=$;a>0&&(n=n.slice(0,a));var c=To.get(n);return c&&(n=c,l=B),a?t?i:r:t?b:u}function $(n,t){return function(e){var r=ao.event;ao.event=e,t[0]=this.__data__;try{n.apply(this,t)}finally{ao.event=r}}}function B(n,t){var e=$(n,t);return function(n){var t=this,r=n.relatedTarget;r&&(r===t||8&r.compareDocumentPosition(t))||e.call(t,n)}}function W(e){var r=".dragsuppress-"+ ++Do,i="click"+r,u=ao.select(t(e)).on("touchmove"+r,S).on("dragstart"+r,S).on("selectstart"+r,S);if(null==Ro&&(Ro="onselectstart"in e?!1:x(e.style,"userSelect")),Ro){var o=n(e).style,a=o[Ro];o[Ro]="none"}return function(n){if(u.on(r,null),Ro&&(o[Ro]=a),n){var t=function(){u.on(i,null)};u.on(i,function(){S(),t()},!0),setTimeout(t,0)}}}function J(n,e){e.changedTouches&&(e=e.changedTouches[0]);var r=n.ownerSVGElement||n;if(r.createSVGPoint){var i=r.createSVGPoint();if(0>Po){var u=t(n);if(u.scrollX||u.scrollY){r=ao.select("body").append("svg").style({position:"absolute",top:0,left:0,margin:0,padding:0,border:"none"},"important");var o=r[0][0].getScreenCTM();Po=!(o.f||o.e),r.remove()}}return Po?(i.x=e.pageX,i.y=e.pageY):(i.x=e.clientX,i.y=e.clientY),i=i.matrixTransform(n.getScreenCTM().inverse()),[i.x,i.y]}var a=n.getBoundingClientRect();return[e.clientX-a.left-n.clientLeft,e.clientY-a.top-n.clientTop]}function G(){return ao.event.changedTouches[0].identifier}function K(n){return n>0?1:0>n?-1:0}function Q(n,t,e){return(t[0]-n[0])*(e[1]-n[1])-(t[1]-n[1])*(e[0]-n[0])}function nn(n){return n>1?0:-1>n?Fo:Math.acos(n)}function tn(n){return n>1?Io:-1>n?-Io:Math.asin(n)}function en(n){return((n=Math.exp(n))-1/n)/2}function rn(n){return((n=Math.exp(n))+1/n)/2}function un(n){return((n=Math.exp(2*n))-1)/(n+1)}function on(n){return(n=Math.sin(n/2))*n}function an(){}function ln(n,t,e){return this instanceof ln?(this.h=+n,this.s=+t,void(this.l=+e)):arguments.length<2?n instanceof ln?new ln(n.h,n.s,n.l):_n(""+n,wn,ln):new ln(n,t,e)}function cn(n,t,e){function r(n){return n>360?n-=360:0>n&&(n+=360),60>n?u+(o-u)*n/60:180>n?o:240>n?u+(o-u)*(240-n)/60:u}function i(n){return Math.round(255*r(n))}var u,o;return n=isNaN(n)?0:(n%=360)<0?n+360:n,t=isNaN(t)?0:0>t?0:t>1?1:t,e=0>e?0:e>1?1:e,o=.5>=e?e*(1+t):e+t-e*t,u=2*e-o,new mn(i(n+120),i(n),i(n-120))}function fn(n,t,e){return this instanceof fn?(this.h=+n,this.c=+t,void(this.l=+e)):arguments.length<2?n instanceof fn?new fn(n.h,n.c,n.l):n instanceof hn?gn(n.l,n.a,n.b):gn((n=Sn((n=ao.rgb(n)).r,n.g,n.b)).l,n.a,n.b):new fn(n,t,e)}function sn(n,t,e){return isNaN(n)&&(n=0),isNaN(t)&&(t=0),new hn(e,Math.cos(n*=Yo)*t,Math.sin(n)*t)}function hn(n,t,e){return this instanceof hn?(this.l=+n,this.a=+t,void(this.b=+e)):arguments.length<2?n instanceof hn?new hn(n.l,n.a,n.b):n instanceof fn?sn(n.h,n.c,n.l):Sn((n=mn(n)).r,n.g,n.b):new hn(n,t,e)}function pn(n,t,e){var r=(n+16)/116,i=r+t/500,u=r-e/200;return i=vn(i)*na,r=vn(r)*ta,u=vn(u)*ea,new mn(yn(3.2404542*i-1.5371385*r-.4985314*u),yn(-.969266*i+1.8760108*r+.041556*u),yn(.0556434*i-.2040259*r+1.0572252*u))}function gn(n,t,e){return n>0?new fn(Math.atan2(e,t)*Zo,Math.sqrt(t*t+e*e),n):new fn(NaN,NaN,n)}function vn(n){return n>.206893034?n*n*n:(n-4/29)/7.787037}function dn(n){return n>.008856?Math.pow(n,1/3):7.787037*n+4/29}function yn(n){return Math.round(255*(.00304>=n?12.92*n:1.055*Math.pow(n,1/2.4)-.055))}function mn(n,t,e){return this instanceof mn?(this.r=~~n,this.g=~~t,void(this.b=~~e)):arguments.length<2?n instanceof mn?new mn(n.r,n.g,n.b):_n(""+n,mn,cn):new mn(n,t,e)}function Mn(n){return new mn(n>>16,n>>8&255,255&n)}function xn(n){return Mn(n)+""}function bn(n){return 16>n?"0"+Math.max(0,n).toString(16):Math.min(255,n).toString(16)}function _n(n,t,e){var r,i,u,o=0,a=0,l=0;if(r=/([a-z]+)\((.*)\)/.exec(n=n.toLowerCase()))switch(i=r[2].split(","),r[1]){case"hsl":return e(parseFloat(i[0]),parseFloat(i[1])/100,parseFloat(i[2])/100);case"rgb":return t(Nn(i[0]),Nn(i[1]),Nn(i[2]))}return(u=ua.get(n))?t(u.r,u.g,u.b):(null==n||"#"!==n.charAt(0)||isNaN(u=parseInt(n.slice(1),16))||(4===n.length?(o=(3840&u)>>4,o=o>>4|o,a=240&u,a=a>>4|a,l=15&u,l=l<<4|l):7===n.length&&(o=(16711680&u)>>16,a=(65280&u)>>8,l=255&u)),t(o,a,l))}function wn(n,t,e){var r,i,u=Math.min(n/=255,t/=255,e/=255),o=Math.max(n,t,e),a=o-u,l=(o+u)/2;return a?(i=.5>l?a/(o+u):a/(2-o-u),r=n==o?(t-e)/a+(e>t?6:0):t==o?(e-n)/a+2:(n-t)/a+4,r*=60):(r=NaN,i=l>0&&1>l?0:r),new ln(r,i,l)}function Sn(n,t,e){n=kn(n),t=kn(t),e=kn(e);var r=dn((.4124564*n+.3575761*t+.1804375*e)/na),i=dn((.2126729*n+.7151522*t+.072175*e)/ta),u=dn((.0193339*n+.119192*t+.9503041*e)/ea);return hn(116*i-16,500*(r-i),200*(i-u))}function kn(n){return(n/=255)<=.04045?n/12.92:Math.pow((n+.055)/1.055,2.4)}function Nn(n){var t=parseFloat(n);return"%"===n.charAt(n.length-1)?Math.round(2.55*t):t}function En(n){return"function"==typeof n?n:function(){return n}}function An(n){return function(t,e,r){return 2===arguments.length&&"function"==typeof e&&(r=e,e=null),Cn(t,e,n,r)}}function Cn(n,t,e,r){function i(){var n,t=l.status;if(!t&&Ln(l)||t>=200&&300>t||304===t){try{n=e.call(u,l)}catch(r){return void o.error.call(u,r)}o.load.call(u,n)}else o.error.call(u,l)}var u={},o=ao.dispatch("beforesend","progress","load","error"),a={},l=new XMLHttpRequest,c=null;return!this.XDomainRequest||"withCredentials"in l||!/^(http(s)?:)?\/\//.test(n)||(l=new XDomainRequest),"onload"in l?l.onload=l.onerror=i:l.onreadystatechange=function(){l.readyState>3&&i()},l.onprogress=function(n){var t=ao.event;ao.event=n;try{o.progress.call(u,l)}finally{ao.event=t}},u.header=function(n,t){return n=(n+"").toLowerCase(),arguments.length<2?a[n]:(null==t?delete a[n]:a[n]=t+"",u)},u.mimeType=function(n){return arguments.length?(t=null==n?null:n+"",u):t},u.responseType=function(n){return arguments.length?(c=n,u):c},u.response=function(n){return e=n,u},["get","post"].forEach(function(n){u[n]=function(){return u.send.apply(u,[n].concat(co(arguments)))}}),u.send=function(e,r,i){if(2===arguments.length&&"function"==typeof r&&(i=r,r=null),l.open(e,n,!0),null==t||"accept"in a||(a.accept=t+",*/*"),l.setRequestHeader)for(var f in a)l.setRequestHeader(f,a[f]);return null!=t&&l.overrideMimeType&&l.overrideMimeType(t),null!=c&&(l.responseType=c),null!=i&&u.on("error",i).on("load",function(n){i(null,n)}),o.beforesend.call(u,l),l.send(null==r?null:r),u},u.abort=function(){return l.abort(),u},ao.rebind(u,o,"on"),null==r?u:u.get(zn(r))}function zn(n){return 1===n.length?function(t,e){n(null==t?e:null)}:n}function Ln(n){var t=n.responseType;return t&&"text"!==t?n.response:n.responseText}function qn(n,t,e){var r=arguments.length;2>r&&(t=0),3>r&&(e=Date.now());var i=e+t,u={c:n,t:i,n:null};return aa?aa.n=u:oa=u,aa=u,la||(ca=clearTimeout(ca),la=1,fa(Tn)),u}function Tn(){var n=Rn(),t=Dn()-n;t>24?(isFinite(t)&&(clearTimeout(ca),ca=setTimeout(Tn,t)),la=0):(la=1,fa(Tn))}function Rn(){for(var n=Date.now(),t=oa;t;)n>=t.t&&t.c(n-t.t)&&(t.c=null),t=t.n;return n}function Dn(){for(var n,t=oa,e=1/0;t;)t.c?(t.t<e&&(e=t.t),t=(n=t).n):t=n?n.n=t.n:oa=t.n;return aa=n,e}function Pn(n,t){return t-(n?Math.ceil(Math.log(n)/Math.LN10):1)}function Un(n,t){var e=Math.pow(10,3*xo(8-t));return{scale:t>8?function(n){return n/e}:function(n){return n*e},symbol:n}}function jn(n){var t=n.decimal,e=n.thousands,r=n.grouping,i=n.currency,u=r&&e?function(n,t){for(var i=n.length,u=[],o=0,a=r[0],l=0;i>0&&a>0&&(l+a+1>t&&(a=Math.max(1,t-l)),u.push(n.substring(i-=a,i+a)),!((l+=a+1)>t));)a=r[o=(o+1)%r.length];return u.reverse().join(e)}:m;return function(n){var e=ha.exec(n),r=e[1]||" ",o=e[2]||">",a=e[3]||"-",l=e[4]||"",c=e[5],f=+e[6],s=e[7],h=e[8],p=e[9],g=1,v="",d="",y=!1,m=!0;switch(h&&(h=+h.substring(1)),(c||"0"===r&&"="===o)&&(c=r="0",o="="),p){case"n":s=!0,p="g";break;case"%":g=100,d="%",p="f";break;case"p":g=100,d="%",p="r";break;case"b":case"o":case"x":case"X":"#"===l&&(v="0"+p.toLowerCase());case"c":m=!1;case"d":y=!0,h=0;break;case"s":g=-1,p="r"}"$"===l&&(v=i[0],d=i[1]),"r"!=p||h||(p="g"),null!=h&&("g"==p?h=Math.max(1,Math.min(21,h)):"e"!=p&&"f"!=p||(h=Math.max(0,Math.min(20,h)))),p=pa.get(p)||Fn;var M=c&&s;return function(n){var e=d;if(y&&n%1)return"";var i=0>n||0===n&&0>1/n?(n=-n,"-"):"-"===a?"":a;if(0>g){var l=ao.formatPrefix(n,h);n=l.scale(n),e=l.symbol+d}else n*=g;n=p(n,h);var x,b,_=n.lastIndexOf(".");if(0>_){var w=m?n.lastIndexOf("e"):-1;0>w?(x=n,b=""):(x=n.substring(0,w),b=n.substring(w))}else x=n.substring(0,_),b=t+n.substring(_+1);!c&&s&&(x=u(x,1/0));var S=v.length+x.length+b.length+(M?0:i.length),k=f>S?new Array(S=f-S+1).join(r):"";return M&&(x=u(k+x,k.length?f-b.length:1/0)),i+=v,n=x+b,("<"===o?i+n+k:">"===o?k+i+n:"^"===o?k.substring(0,S>>=1)+i+n+k.substring(S):i+(M?n:k+n))+e}}}function Fn(n){return n+""}function Hn(){this._=new Date(arguments.length>1?Date.UTC.apply(this,arguments):arguments[0])}function On(n,t,e){function r(t){var e=n(t),r=u(e,1);return r-t>t-e?e:r}function i(e){return t(e=n(new va(e-1)),1),e}function u(n,e){return t(n=new va(+n),e),n}function o(n,r,u){var o=i(n),a=[];if(u>1)for(;r>o;)e(o)%u||a.push(new Date(+o)),t(o,1);else for(;r>o;)a.push(new Date(+o)),t(o,1);return a}function a(n,t,e){try{va=Hn;var r=new Hn;return r._=n,o(r,t,e)}finally{va=Date}}n.floor=n,n.round=r,n.ceil=i,n.offset=u,n.range=o;var l=n.utc=In(n);return l.floor=l,l.round=In(r),l.ceil=In(i),l.offset=In(u),l.range=a,n}function In(n){return function(t,e){try{va=Hn;var r=new Hn;return r._=t,n(r,e)._}finally{va=Date}}}function Yn(n){function t(n){function t(t){for(var e,i,u,o=[],a=-1,l=0;++a<r;)37===n.charCodeAt(a)&&(o.push(n.slice(l,a)),null!=(i=ya[e=n.charAt(++a)])&&(e=n.charAt(++a)),(u=A[e])&&(e=u(t,null==i?"e"===e?" ":"0":i)),o.push(e),l=a+1);return o.push(n.slice(l,a)),o.join("")}var r=n.length;return t.parse=function(t){var r={y:1900,m:0,d:1,H:0,M:0,S:0,L:0,Z:null},i=e(r,n,t,0);if(i!=t.length)return null;"p"in r&&(r.H=r.H%12+12*r.p);var u=null!=r.Z&&va!==Hn,o=new(u?Hn:va);return"j"in r?o.setFullYear(r.y,0,r.j):"W"in r||"U"in r?("w"in r||(r.w="W"in r?1:0),o.setFullYear(r.y,0,1),o.setFullYear(r.y,0,"W"in r?(r.w+6)%7+7*r.W-(o.getDay()+5)%7:r.w+7*r.U-(o.getDay()+6)%7)):o.setFullYear(r.y,r.m,r.d),o.setHours(r.H+(r.Z/100|0),r.M+r.Z%100,r.S,r.L),u?o._:o},t.toString=function(){return n},t}function e(n,t,e,r){for(var i,u,o,a=0,l=t.length,c=e.length;l>a;){if(r>=c)return-1;if(i=t.charCodeAt(a++),37===i){if(o=t.charAt(a++),u=C[o in ya?t.charAt(a++):o],!u||(r=u(n,e,r))<0)return-1}else if(i!=e.charCodeAt(r++))return-1}return r}function r(n,t,e){_.lastIndex=0;var r=_.exec(t.slice(e));return r?(n.w=w.get(r[0].toLowerCase()),e+r[0].length):-1}function i(n,t,e){x.lastIndex=0;var r=x.exec(t.slice(e));return r?(n.w=b.get(r[0].toLowerCase()),e+r[0].length):-1}function u(n,t,e){N.lastIndex=0;var r=N.exec(t.slice(e));return r?(n.m=E.get(r[0].toLowerCase()),e+r[0].length):-1}function o(n,t,e){S.lastIndex=0;var r=S.exec(t.slice(e));return r?(n.m=k.get(r[0].toLowerCase()),e+r[0].length):-1}function a(n,t,r){return e(n,A.c.toString(),t,r)}function l(n,t,r){return e(n,A.x.toString(),t,r)}function c(n,t,r){return e(n,A.X.toString(),t,r)}function f(n,t,e){var r=M.get(t.slice(e,e+=2).toLowerCase());return null==r?-1:(n.p=r,e)}var s=n.dateTime,h=n.date,p=n.time,g=n.periods,v=n.days,d=n.shortDays,y=n.months,m=n.shortMonths;t.utc=function(n){function e(n){try{va=Hn;var t=new va;return t._=n,r(t)}finally{va=Date}}var r=t(n);return e.parse=function(n){try{va=Hn;var t=r.parse(n);return t&&t._}finally{va=Date}},e.toString=r.toString,e},t.multi=t.utc.multi=ct;var M=ao.map(),x=Vn(v),b=Xn(v),_=Vn(d),w=Xn(d),S=Vn(y),k=Xn(y),N=Vn(m),E=Xn(m);g.forEach(function(n,t){M.set(n.toLowerCase(),t)});var A={a:function(n){return d[n.getDay()]},A:function(n){return v[n.getDay()]},b:function(n){return m[n.getMonth()]},B:function(n){return y[n.getMonth()]},c:t(s),d:function(n,t){return Zn(n.getDate(),t,2)},e:function(n,t){return Zn(n.getDate(),t,2)},H:function(n,t){return Zn(n.getHours(),t,2)},I:function(n,t){return Zn(n.getHours()%12||12,t,2)},j:function(n,t){return Zn(1+ga.dayOfYear(n),t,3)},L:function(n,t){return Zn(n.getMilliseconds(),t,3)},m:function(n,t){return Zn(n.getMonth()+1,t,2)},M:function(n,t){return Zn(n.getMinutes(),t,2)},p:function(n){return g[+(n.getHours()>=12)]},S:function(n,t){return Zn(n.getSeconds(),t,2)},U:function(n,t){return Zn(ga.sundayOfYear(n),t,2)},w:function(n){return n.getDay()},W:function(n,t){return Zn(ga.mondayOfYear(n),t,2)},x:t(h),X:t(p),y:function(n,t){return Zn(n.getFullYear()%100,t,2)},Y:function(n,t){return Zn(n.getFullYear()%1e4,t,4)},Z:at,"%":function(){return"%"}},C={a:r,A:i,b:u,B:o,c:a,d:tt,e:tt,H:rt,I:rt,j:et,L:ot,m:nt,M:it,p:f,S:ut,U:Bn,w:$n,W:Wn,x:l,X:c,y:Gn,Y:Jn,Z:Kn,"%":lt};return t}function Zn(n,t,e){var r=0>n?"-":"",i=(r?-n:n)+"",u=i.length;return r+(e>u?new Array(e-u+1).join(t)+i:i)}function Vn(n){return new RegExp("^(?:"+n.map(ao.requote).join("|")+")","i")}function Xn(n){for(var t=new c,e=-1,r=n.length;++e<r;)t.set(n[e].toLowerCase(),e);return t}function $n(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+1));return r?(n.w=+r[0],e+r[0].length):-1}function Bn(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e));return r?(n.U=+r[0],e+r[0].length):-1}function Wn(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e));return r?(n.W=+r[0],e+r[0].length):-1}function Jn(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+4));return r?(n.y=+r[0],e+r[0].length):-1}function Gn(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.y=Qn(+r[0]),e+r[0].length):-1}function Kn(n,t,e){return/^[+-]\d{4}$/.test(t=t.slice(e,e+5))?(n.Z=-t,e+5):-1}function Qn(n){return n+(n>68?1900:2e3)}function nt(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.m=r[0]-1,e+r[0].length):-1}function tt(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.d=+r[0],e+r[0].length):-1}function et(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+3));return r?(n.j=+r[0],e+r[0].length):-1}function rt(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.H=+r[0],e+r[0].length):-1}function it(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.M=+r[0],e+r[0].length):-1}function ut(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.S=+r[0],e+r[0].length):-1}function ot(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+3));return r?(n.L=+r[0],e+r[0].length):-1}function at(n){var t=n.getTimezoneOffset(),e=t>0?"-":"+",r=xo(t)/60|0,i=xo(t)%60;return e+Zn(r,"0",2)+Zn(i,"0",2)}function lt(n,t,e){Ma.lastIndex=0;var r=Ma.exec(t.slice(e,e+1));return r?e+r[0].length:-1}function ct(n){for(var t=n.length,e=-1;++e<t;)n[e][0]=this(n[e][0]);return function(t){for(var e=0,r=n[e];!r[1](t);)r=n[++e];return r[0](t)}}function ft(){}function st(n,t,e){var r=e.s=n+t,i=r-n,u=r-i;e.t=n-u+(t-i)}function ht(n,t){n&&wa.hasOwnProperty(n.type)&&wa[n.type](n,t)}function pt(n,t,e){var r,i=-1,u=n.length-e;for(t.lineStart();++i<u;)r=n[i],t.point(r[0],r[1],r[2]);t.lineEnd()}function gt(n,t){var e=-1,r=n.length;for(t.polygonStart();++e<r;)pt(n[e],t,1);t.polygonEnd()}function vt(){function n(n,t){n*=Yo,t=t*Yo/2+Fo/4;var e=n-r,o=e>=0?1:-1,a=o*e,l=Math.cos(t),c=Math.sin(t),f=u*c,s=i*l+f*Math.cos(a),h=f*o*Math.sin(a);ka.add(Math.atan2(h,s)),r=n,i=l,u=c}var t,e,r,i,u;Na.point=function(o,a){Na.point=n,r=(t=o)*Yo,i=Math.cos(a=(e=a)*Yo/2+Fo/4),u=Math.sin(a)},Na.lineEnd=function(){n(t,e)}}function dt(n){var t=n[0],e=n[1],r=Math.cos(e);return[r*Math.cos(t),r*Math.sin(t),Math.sin(e)]}function yt(n,t){return n[0]*t[0]+n[1]*t[1]+n[2]*t[2]}function mt(n,t){return[n[1]*t[2]-n[2]*t[1],n[2]*t[0]-n[0]*t[2],n[0]*t[1]-n[1]*t[0]]}function Mt(n,t){n[0]+=t[0],n[1]+=t[1],n[2]+=t[2]}function xt(n,t){return[n[0]*t,n[1]*t,n[2]*t]}function bt(n){var t=Math.sqrt(n[0]*n[0]+n[1]*n[1]+n[2]*n[2]);n[0]/=t,n[1]/=t,n[2]/=t}function _t(n){return[Math.atan2(n[1],n[0]),tn(n[2])]}function wt(n,t){return xo(n[0]-t[0])<Uo&&xo(n[1]-t[1])<Uo}function St(n,t){n*=Yo;var e=Math.cos(t*=Yo);kt(e*Math.cos(n),e*Math.sin(n),Math.sin(t))}function kt(n,t,e){++Ea,Ca+=(n-Ca)/Ea,za+=(t-za)/Ea,La+=(e-La)/Ea}function Nt(){function n(n,i){n*=Yo;var u=Math.cos(i*=Yo),o=u*Math.cos(n),a=u*Math.sin(n),l=Math.sin(i),c=Math.atan2(Math.sqrt((c=e*l-r*a)*c+(c=r*o-t*l)*c+(c=t*a-e*o)*c),t*o+e*a+r*l);Aa+=c,qa+=c*(t+(t=o)),Ta+=c*(e+(e=a)),Ra+=c*(r+(r=l)),kt(t,e,r)}var t,e,r;ja.point=function(i,u){i*=Yo;var o=Math.cos(u*=Yo);t=o*Math.cos(i),e=o*Math.sin(i),r=Math.sin(u),ja.point=n,kt(t,e,r)}}function Et(){ja.point=St}function At(){function n(n,t){n*=Yo;var e=Math.cos(t*=Yo),o=e*Math.cos(n),a=e*Math.sin(n),l=Math.sin(t),c=i*l-u*a,f=u*o-r*l,s=r*a-i*o,h=Math.sqrt(c*c+f*f+s*s),p=r*o+i*a+u*l,g=h&&-nn(p)/h,v=Math.atan2(h,p);Da+=g*c,Pa+=g*f,Ua+=g*s,Aa+=v,qa+=v*(r+(r=o)),Ta+=v*(i+(i=a)),Ra+=v*(u+(u=l)),kt(r,i,u)}var t,e,r,i,u;ja.point=function(o,a){t=o,e=a,ja.point=n,o*=Yo;var l=Math.cos(a*=Yo);r=l*Math.cos(o),i=l*Math.sin(o),u=Math.sin(a),kt(r,i,u)},ja.lineEnd=function(){n(t,e),ja.lineEnd=Et,ja.point=St}}function Ct(n,t){function e(e,r){return e=n(e,r),t(e[0],e[1])}return n.invert&&t.invert&&(e.invert=function(e,r){return e=t.invert(e,r),e&&n.invert(e[0],e[1])}),e}function zt(){return!0}function Lt(n,t,e,r,i){var u=[],o=[];if(n.forEach(function(n){if(!((t=n.length-1)<=0)){var t,e=n[0],r=n[t];if(wt(e,r)){i.lineStart();for(var a=0;t>a;++a)i.point((e=n[a])[0],e[1]);return void i.lineEnd()}var l=new Tt(e,n,null,!0),c=new Tt(e,null,l,!1);l.o=c,u.push(l),o.push(c),l=new Tt(r,n,null,!1),c=new Tt(r,null,l,!0),l.o=c,u.push(l),o.push(c)}}),o.sort(t),qt(u),qt(o),u.length){for(var a=0,l=e,c=o.length;c>a;++a)o[a].e=l=!l;for(var f,s,h=u[0];;){for(var p=h,g=!0;p.v;)if((p=p.n)===h)return;f=p.z,i.lineStart();do{if(p.v=p.o.v=!0,p.e){if(g)for(var a=0,c=f.length;c>a;++a)i.point((s=f[a])[0],s[1]);else r(p.x,p.n.x,1,i);p=p.n}else{if(g){f=p.p.z;for(var a=f.length-1;a>=0;--a)i.point((s=f[a])[0],s[1])}else r(p.x,p.p.x,-1,i);p=p.p}p=p.o,f=p.z,g=!g}while(!p.v);i.lineEnd()}}}function qt(n){if(t=n.length){for(var t,e,r=0,i=n[0];++r<t;)i.n=e=n[r],e.p=i,i=e;i.n=e=n[0],e.p=i}}function Tt(n,t,e,r){this.x=n,this.z=t,this.o=e,this.e=r,this.v=!1,this.n=this.p=null}function Rt(n,t,e,r){return function(i,u){function o(t,e){var r=i(t,e);n(t=r[0],e=r[1])&&u.point(t,e)}function a(n,t){var e=i(n,t);d.point(e[0],e[1])}function l(){m.point=a,d.lineStart()}function c(){m.point=o,d.lineEnd()}function f(n,t){v.push([n,t]);var e=i(n,t);x.point(e[0],e[1])}function s(){x.lineStart(),v=[]}function h(){f(v[0][0],v[0][1]),x.lineEnd();var n,t=x.clean(),e=M.buffer(),r=e.length;if(v.pop(),g.push(v),v=null,r)if(1&t){n=e[0];var i,r=n.length-1,o=-1;if(r>0){for(b||(u.polygonStart(),b=!0),u.lineStart();++o<r;)u.point((i=n[o])[0],i[1]);u.lineEnd()}}else r>1&&2&t&&e.push(e.pop().concat(e.shift())),p.push(e.filter(Dt))}var p,g,v,d=t(u),y=i.invert(r[0],r[1]),m={point:o,lineStart:l,lineEnd:c,polygonStart:function(){m.point=f,m.lineStart=s,m.lineEnd=h,p=[],g=[]},polygonEnd:function(){m.point=o,m.lineStart=l,m.lineEnd=c,p=ao.merge(p);var n=Ot(y,g);p.length?(b||(u.polygonStart(),b=!0),Lt(p,Ut,n,e,u)):n&&(b||(u.polygonStart(),b=!0),u.lineStart(),e(null,null,1,u),u.lineEnd()),b&&(u.polygonEnd(),b=!1),p=g=null},sphere:function(){u.polygonStart(),u.lineStart(),e(null,null,1,u),u.lineEnd(),u.polygonEnd()}},M=Pt(),x=t(M),b=!1;return m}}function Dt(n){return n.length>1}function Pt(){var n,t=[];return{lineStart:function(){t.push(n=[])},point:function(t,e){n.push([t,e])},lineEnd:b,buffer:function(){var e=t;return t=[],n=null,e},rejoin:function(){t.length>1&&t.push(t.pop().concat(t.shift()))}}}function Ut(n,t){return((n=n.x)[0]<0?n[1]-Io-Uo:Io-n[1])-((t=t.x)[0]<0?t[1]-Io-Uo:Io-t[1])}function jt(n){var t,e=NaN,r=NaN,i=NaN;return{lineStart:function(){n.lineStart(),t=1},point:function(u,o){var a=u>0?Fo:-Fo,l=xo(u-e);xo(l-Fo)<Uo?(n.point(e,r=(r+o)/2>0?Io:-Io),n.point(i,r),n.lineEnd(),n.lineStart(),n.point(a,r),n.point(u,r),t=0):i!==a&&l>=Fo&&(xo(e-i)<Uo&&(e-=i*Uo),xo(u-a)<Uo&&(u-=a*Uo),r=Ft(e,r,u,o),n.point(i,r),n.lineEnd(),n.lineStart(),n.point(a,r),t=0),n.point(e=u,r=o),i=a},lineEnd:function(){n.lineEnd(),e=r=NaN},clean:function(){return 2-t}}}function Ft(n,t,e,r){var i,u,o=Math.sin(n-e);return xo(o)>Uo?Math.atan((Math.sin(t)*(u=Math.cos(r))*Math.sin(e)-Math.sin(r)*(i=Math.cos(t))*Math.sin(n))/(i*u*o)):(t+r)/2}function Ht(n,t,e,r){var i;if(null==n)i=e*Io,r.point(-Fo,i),r.point(0,i),r.point(Fo,i),r.point(Fo,0),r.point(Fo,-i),r.point(0,-i),r.point(-Fo,-i),r.point(-Fo,0),r.point(-Fo,i);else if(xo(n[0]-t[0])>Uo){var u=n[0]<t[0]?Fo:-Fo;i=e*u/2,r.point(-u,i),r.point(0,i),r.point(u,i)}else r.point(t[0],t[1])}function Ot(n,t){var e=n[0],r=n[1],i=[Math.sin(e),-Math.cos(e),0],u=0,o=0;ka.reset();for(var a=0,l=t.length;l>a;++a){var c=t[a],f=c.length;if(f)for(var s=c[0],h=s[0],p=s[1]/2+Fo/4,g=Math.sin(p),v=Math.cos(p),d=1;;){d===f&&(d=0),n=c[d];var y=n[0],m=n[1]/2+Fo/4,M=Math.sin(m),x=Math.cos(m),b=y-h,_=b>=0?1:-1,w=_*b,S=w>Fo,k=g*M;if(ka.add(Math.atan2(k*_*Math.sin(w),v*x+k*Math.cos(w))),u+=S?b+_*Ho:b,S^h>=e^y>=e){var N=mt(dt(s),dt(n));bt(N);var E=mt(i,N);bt(E);var A=(S^b>=0?-1:1)*tn(E[2]);(r>A||r===A&&(N[0]||N[1]))&&(o+=S^b>=0?1:-1)}if(!d++)break;h=y,g=M,v=x,s=n}}return(-Uo>u||Uo>u&&-Uo>ka)^1&o}function It(n){function t(n,t){return Math.cos(n)*Math.cos(t)>u}function e(n){var e,u,l,c,f;return{lineStart:function(){c=l=!1,f=1},point:function(s,h){var p,g=[s,h],v=t(s,h),d=o?v?0:i(s,h):v?i(s+(0>s?Fo:-Fo),h):0;if(!e&&(c=l=v)&&n.lineStart(),v!==l&&(p=r(e,g),(wt(e,p)||wt(g,p))&&(g[0]+=Uo,g[1]+=Uo,v=t(g[0],g[1]))),v!==l)f=0,v?(n.lineStart(),p=r(g,e),n.point(p[0],p[1])):(p=r(e,g),n.point(p[0],p[1]),n.lineEnd()),e=p;else if(a&&e&&o^v){var y;d&u||!(y=r(g,e,!0))||(f=0,o?(n.lineStart(),n.point(y[0][0],y[0][1]),n.point(y[1][0],y[1][1]),n.lineEnd()):(n.point(y[1][0],y[1][1]),n.lineEnd(),n.lineStart(),n.point(y[0][0],y[0][1])))}!v||e&&wt(e,g)||n.point(g[0],g[1]),e=g,l=v,u=d},lineEnd:function(){l&&n.lineEnd(),e=null},clean:function(){return f|(c&&l)<<1}}}function r(n,t,e){var r=dt(n),i=dt(t),o=[1,0,0],a=mt(r,i),l=yt(a,a),c=a[0],f=l-c*c;if(!f)return!e&&n;var s=u*l/f,h=-u*c/f,p=mt(o,a),g=xt(o,s),v=xt(a,h);Mt(g,v);var d=p,y=yt(g,d),m=yt(d,d),M=y*y-m*(yt(g,g)-1);if(!(0>M)){var x=Math.sqrt(M),b=xt(d,(-y-x)/m);if(Mt(b,g),b=_t(b),!e)return b;var _,w=n[0],S=t[0],k=n[1],N=t[1];w>S&&(_=w,w=S,S=_);var E=S-w,A=xo(E-Fo)<Uo,C=A||Uo>E;if(!A&&k>N&&(_=k,k=N,N=_),C?A?k+N>0^b[1]<(xo(b[0]-w)<Uo?k:N):k<=b[1]&&b[1]<=N:E>Fo^(w<=b[0]&&b[0]<=S)){var z=xt(d,(-y+x)/m);return Mt(z,g),[b,_t(z)]}}}function i(t,e){var r=o?n:Fo-n,i=0;return-r>t?i|=1:t>r&&(i|=2),-r>e?i|=4:e>r&&(i|=8),i}var u=Math.cos(n),o=u>0,a=xo(u)>Uo,l=ve(n,6*Yo);return Rt(t,e,l,o?[0,-n]:[-Fo,n-Fo])}function Yt(n,t,e,r){return function(i){var u,o=i.a,a=i.b,l=o.x,c=o.y,f=a.x,s=a.y,h=0,p=1,g=f-l,v=s-c;if(u=n-l,g||!(u>0)){if(u/=g,0>g){if(h>u)return;p>u&&(p=u)}else if(g>0){if(u>p)return;u>h&&(h=u)}if(u=e-l,g||!(0>u)){if(u/=g,0>g){if(u>p)return;u>h&&(h=u)}else if(g>0){if(h>u)return;p>u&&(p=u)}if(u=t-c,v||!(u>0)){if(u/=v,0>v){if(h>u)return;p>u&&(p=u)}else if(v>0){if(u>p)return;u>h&&(h=u)}if(u=r-c,v||!(0>u)){if(u/=v,0>v){if(u>p)return;u>h&&(h=u)}else if(v>0){if(h>u)return;p>u&&(p=u)}return h>0&&(i.a={x:l+h*g,y:c+h*v}),1>p&&(i.b={x:l+p*g,y:c+p*v}),i}}}}}}function Zt(n,t,e,r){function i(r,i){return xo(r[0]-n)<Uo?i>0?0:3:xo(r[0]-e)<Uo?i>0?2:1:xo(r[1]-t)<Uo?i>0?1:0:i>0?3:2}function u(n,t){return o(n.x,t.x)}function o(n,t){var e=i(n,1),r=i(t,1);return e!==r?e-r:0===e?t[1]-n[1]:1===e?n[0]-t[0]:2===e?n[1]-t[1]:t[0]-n[0]}return function(a){function l(n){for(var t=0,e=d.length,r=n[1],i=0;e>i;++i)for(var u,o=1,a=d[i],l=a.length,c=a[0];l>o;++o)u=a[o],c[1]<=r?u[1]>r&&Q(c,u,n)>0&&++t:u[1]<=r&&Q(c,u,n)<0&&--t,c=u;return 0!==t}function c(u,a,l,c){var f=0,s=0;if(null==u||(f=i(u,l))!==(s=i(a,l))||o(u,a)<0^l>0){do c.point(0===f||3===f?n:e,f>1?r:t);while((f=(f+l+4)%4)!==s)}else c.point(a[0],a[1])}function f(i,u){return i>=n&&e>=i&&u>=t&&r>=u}function s(n,t){f(n,t)&&a.point(n,t)}function h(){C.point=g,d&&d.push(y=[]),S=!0,w=!1,b=_=NaN}function p(){v&&(g(m,M),x&&w&&E.rejoin(),v.push(E.buffer())),C.point=s,w&&a.lineEnd()}function g(n,t){n=Math.max(-Ha,Math.min(Ha,n)),t=Math.max(-Ha,Math.min(Ha,t));var e=f(n,t);if(d&&y.push([n,t]),S)m=n,M=t,x=e,S=!1,e&&(a.lineStart(),a.point(n,t));else if(e&&w)a.point(n,t);else{var r={a:{x:b,y:_},b:{x:n,y:t}};A(r)?(w||(a.lineStart(),a.point(r.a.x,r.a.y)),a.point(r.b.x,r.b.y),e||a.lineEnd(),k=!1):e&&(a.lineStart(),a.point(n,t),k=!1)}b=n,_=t,w=e}var v,d,y,m,M,x,b,_,w,S,k,N=a,E=Pt(),A=Yt(n,t,e,r),C={point:s,lineStart:h,lineEnd:p,polygonStart:function(){a=E,v=[],d=[],k=!0},polygonEnd:function(){a=N,v=ao.merge(v);var t=l([n,r]),e=k&&t,i=v.length;(e||i)&&(a.polygonStart(),e&&(a.lineStart(),c(null,null,1,a),a.lineEnd()),i&&Lt(v,u,t,c,a),a.polygonEnd()),v=d=y=null}};return C}}function Vt(n){var t=0,e=Fo/3,r=ae(n),i=r(t,e);return i.parallels=function(n){return arguments.length?r(t=n[0]*Fo/180,e=n[1]*Fo/180):[t/Fo*180,e/Fo*180]},i}function Xt(n,t){function e(n,t){var e=Math.sqrt(u-2*i*Math.sin(t))/i;return[e*Math.sin(n*=i),o-e*Math.cos(n)]}var r=Math.sin(n),i=(r+Math.sin(t))/2,u=1+r*(2*i-r),o=Math.sqrt(u)/i;return e.invert=function(n,t){var e=o-t;return[Math.atan2(n,e)/i,tn((u-(n*n+e*e)*i*i)/(2*i))]},e}function $t(){function n(n,t){Ia+=i*n-r*t,r=n,i=t}var t,e,r,i;$a.point=function(u,o){$a.point=n,t=r=u,e=i=o},$a.lineEnd=function(){n(t,e)}}function Bt(n,t){Ya>n&&(Ya=n),n>Va&&(Va=n),Za>t&&(Za=t),t>Xa&&(Xa=t)}function Wt(){function n(n,t){o.push("M",n,",",t,u)}function t(n,t){o.push("M",n,",",t),a.point=e}function e(n,t){o.push("L",n,",",t)}function r(){a.point=n}function i(){o.push("Z")}var u=Jt(4.5),o=[],a={point:n,lineStart:function(){a.point=t},lineEnd:r,polygonStart:function(){a.lineEnd=i},polygonEnd:function(){a.lineEnd=r,a.point=n},pointRadius:function(n){return u=Jt(n),a},result:function(){if(o.length){var n=o.join("");return o=[],n}}};return a}function Jt(n){return"m0,"+n+"a"+n+","+n+" 0 1,1 0,"+-2*n+"a"+n+","+n+" 0 1,1 0,"+2*n+"z"}function Gt(n,t){Ca+=n,za+=t,++La}function Kt(){function n(n,r){var i=n-t,u=r-e,o=Math.sqrt(i*i+u*u);qa+=o*(t+n)/2,Ta+=o*(e+r)/2,Ra+=o,Gt(t=n,e=r)}var t,e;Wa.point=function(r,i){Wa.point=n,Gt(t=r,e=i)}}function Qt(){Wa.point=Gt}function ne(){function n(n,t){var e=n-r,u=t-i,o=Math.sqrt(e*e+u*u);qa+=o*(r+n)/2,Ta+=o*(i+t)/2,Ra+=o,o=i*n-r*t,Da+=o*(r+n),Pa+=o*(i+t),Ua+=3*o,Gt(r=n,i=t)}var t,e,r,i;Wa.point=function(u,o){Wa.point=n,Gt(t=r=u,e=i=o)},Wa.lineEnd=function(){n(t,e)}}function te(n){function t(t,e){n.moveTo(t+o,e),n.arc(t,e,o,0,Ho)}function e(t,e){n.moveTo(t,e),a.point=r}function r(t,e){n.lineTo(t,e)}function i(){a.point=t}function u(){n.closePath()}var o=4.5,a={point:t,lineStart:function(){a.point=e},lineEnd:i,polygonStart:function(){a.lineEnd=u},polygonEnd:function(){a.lineEnd=i,a.point=t},pointRadius:function(n){return o=n,a},result:b};return a}function ee(n){function t(n){return(a?r:e)(n)}function e(t){return ue(t,function(e,r){e=n(e,r),t.point(e[0],e[1])})}function r(t){function e(e,r){e=n(e,r),t.point(e[0],e[1])}function r(){M=NaN,S.point=u,t.lineStart()}function u(e,r){var u=dt([e,r]),o=n(e,r);i(M,x,m,b,_,w,M=o[0],x=o[1],m=e,b=u[0],_=u[1],w=u[2],a,t),t.point(M,x)}function o(){S.point=e,t.lineEnd()}function l(){
-			r(),S.point=c,S.lineEnd=f}function c(n,t){u(s=n,h=t),p=M,g=x,v=b,d=_,y=w,S.point=u}function f(){i(M,x,m,b,_,w,p,g,s,v,d,y,a,t),S.lineEnd=o,o()}var s,h,p,g,v,d,y,m,M,x,b,_,w,S={point:e,lineStart:r,lineEnd:o,polygonStart:function(){t.polygonStart(),S.lineStart=l},polygonEnd:function(){t.polygonEnd(),S.lineStart=r}};return S}function i(t,e,r,a,l,c,f,s,h,p,g,v,d,y){var m=f-t,M=s-e,x=m*m+M*M;if(x>4*u&&d--){var b=a+p,_=l+g,w=c+v,S=Math.sqrt(b*b+_*_+w*w),k=Math.asin(w/=S),N=xo(xo(w)-1)<Uo||xo(r-h)<Uo?(r+h)/2:Math.atan2(_,b),E=n(N,k),A=E[0],C=E[1],z=A-t,L=C-e,q=M*z-m*L;(q*q/x>u||xo((m*z+M*L)/x-.5)>.3||o>a*p+l*g+c*v)&&(i(t,e,r,a,l,c,A,C,N,b/=S,_/=S,w,d,y),y.point(A,C),i(A,C,N,b,_,w,f,s,h,p,g,v,d,y))}}var u=.5,o=Math.cos(30*Yo),a=16;return t.precision=function(n){return arguments.length?(a=(u=n*n)>0&&16,t):Math.sqrt(u)},t}function re(n){var t=ee(function(t,e){return n([t*Zo,e*Zo])});return function(n){return le(t(n))}}function ie(n){this.stream=n}function ue(n,t){return{point:t,sphere:function(){n.sphere()},lineStart:function(){n.lineStart()},lineEnd:function(){n.lineEnd()},polygonStart:function(){n.polygonStart()},polygonEnd:function(){n.polygonEnd()}}}function oe(n){return ae(function(){return n})()}function ae(n){function t(n){return n=a(n[0]*Yo,n[1]*Yo),[n[0]*h+l,c-n[1]*h]}function e(n){return n=a.invert((n[0]-l)/h,(c-n[1])/h),n&&[n[0]*Zo,n[1]*Zo]}function r(){a=Ct(o=se(y,M,x),u);var n=u(v,d);return l=p-n[0]*h,c=g+n[1]*h,i()}function i(){return f&&(f.valid=!1,f=null),t}var u,o,a,l,c,f,s=ee(function(n,t){return n=u(n,t),[n[0]*h+l,c-n[1]*h]}),h=150,p=480,g=250,v=0,d=0,y=0,M=0,x=0,b=Fa,_=m,w=null,S=null;return t.stream=function(n){return f&&(f.valid=!1),f=le(b(o,s(_(n)))),f.valid=!0,f},t.clipAngle=function(n){return arguments.length?(b=null==n?(w=n,Fa):It((w=+n)*Yo),i()):w},t.clipExtent=function(n){return arguments.length?(S=n,_=n?Zt(n[0][0],n[0][1],n[1][0],n[1][1]):m,i()):S},t.scale=function(n){return arguments.length?(h=+n,r()):h},t.translate=function(n){return arguments.length?(p=+n[0],g=+n[1],r()):[p,g]},t.center=function(n){return arguments.length?(v=n[0]%360*Yo,d=n[1]%360*Yo,r()):[v*Zo,d*Zo]},t.rotate=function(n){return arguments.length?(y=n[0]%360*Yo,M=n[1]%360*Yo,x=n.length>2?n[2]%360*Yo:0,r()):[y*Zo,M*Zo,x*Zo]},ao.rebind(t,s,"precision"),function(){return u=n.apply(this,arguments),t.invert=u.invert&&e,r()}}function le(n){return ue(n,function(t,e){n.point(t*Yo,e*Yo)})}function ce(n,t){return[n,t]}function fe(n,t){return[n>Fo?n-Ho:-Fo>n?n+Ho:n,t]}function se(n,t,e){return n?t||e?Ct(pe(n),ge(t,e)):pe(n):t||e?ge(t,e):fe}function he(n){return function(t,e){return t+=n,[t>Fo?t-Ho:-Fo>t?t+Ho:t,e]}}function pe(n){var t=he(n);return t.invert=he(-n),t}function ge(n,t){function e(n,t){var e=Math.cos(t),a=Math.cos(n)*e,l=Math.sin(n)*e,c=Math.sin(t),f=c*r+a*i;return[Math.atan2(l*u-f*o,a*r-c*i),tn(f*u+l*o)]}var r=Math.cos(n),i=Math.sin(n),u=Math.cos(t),o=Math.sin(t);return e.invert=function(n,t){var e=Math.cos(t),a=Math.cos(n)*e,l=Math.sin(n)*e,c=Math.sin(t),f=c*u-l*o;return[Math.atan2(l*u+c*o,a*r+f*i),tn(f*r-a*i)]},e}function ve(n,t){var e=Math.cos(n),r=Math.sin(n);return function(i,u,o,a){var l=o*t;null!=i?(i=de(e,i),u=de(e,u),(o>0?u>i:i>u)&&(i+=o*Ho)):(i=n+o*Ho,u=n-.5*l);for(var c,f=i;o>0?f>u:u>f;f-=l)a.point((c=_t([e,-r*Math.cos(f),-r*Math.sin(f)]))[0],c[1])}}function de(n,t){var e=dt(t);e[0]-=n,bt(e);var r=nn(-e[1]);return((-e[2]<0?-r:r)+2*Math.PI-Uo)%(2*Math.PI)}function ye(n,t,e){var r=ao.range(n,t-Uo,e).concat(t);return function(n){return r.map(function(t){return[n,t]})}}function me(n,t,e){var r=ao.range(n,t-Uo,e).concat(t);return function(n){return r.map(function(t){return[t,n]})}}function Me(n){return n.source}function xe(n){return n.target}function be(n,t,e,r){var i=Math.cos(t),u=Math.sin(t),o=Math.cos(r),a=Math.sin(r),l=i*Math.cos(n),c=i*Math.sin(n),f=o*Math.cos(e),s=o*Math.sin(e),h=2*Math.asin(Math.sqrt(on(r-t)+i*o*on(e-n))),p=1/Math.sin(h),g=h?function(n){var t=Math.sin(n*=h)*p,e=Math.sin(h-n)*p,r=e*l+t*f,i=e*c+t*s,o=e*u+t*a;return[Math.atan2(i,r)*Zo,Math.atan2(o,Math.sqrt(r*r+i*i))*Zo]}:function(){return[n*Zo,t*Zo]};return g.distance=h,g}function _e(){function n(n,i){var u=Math.sin(i*=Yo),o=Math.cos(i),a=xo((n*=Yo)-t),l=Math.cos(a);Ja+=Math.atan2(Math.sqrt((a=o*Math.sin(a))*a+(a=r*u-e*o*l)*a),e*u+r*o*l),t=n,e=u,r=o}var t,e,r;Ga.point=function(i,u){t=i*Yo,e=Math.sin(u*=Yo),r=Math.cos(u),Ga.point=n},Ga.lineEnd=function(){Ga.point=Ga.lineEnd=b}}function we(n,t){function e(t,e){var r=Math.cos(t),i=Math.cos(e),u=n(r*i);return[u*i*Math.sin(t),u*Math.sin(e)]}return e.invert=function(n,e){var r=Math.sqrt(n*n+e*e),i=t(r),u=Math.sin(i),o=Math.cos(i);return[Math.atan2(n*u,r*o),Math.asin(r&&e*u/r)]},e}function Se(n,t){function e(n,t){o>0?-Io+Uo>t&&(t=-Io+Uo):t>Io-Uo&&(t=Io-Uo);var e=o/Math.pow(i(t),u);return[e*Math.sin(u*n),o-e*Math.cos(u*n)]}var r=Math.cos(n),i=function(n){return Math.tan(Fo/4+n/2)},u=n===t?Math.sin(n):Math.log(r/Math.cos(t))/Math.log(i(t)/i(n)),o=r*Math.pow(i(n),u)/u;return u?(e.invert=function(n,t){var e=o-t,r=K(u)*Math.sqrt(n*n+e*e);return[Math.atan2(n,e)/u,2*Math.atan(Math.pow(o/r,1/u))-Io]},e):Ne}function ke(n,t){function e(n,t){var e=u-t;return[e*Math.sin(i*n),u-e*Math.cos(i*n)]}var r=Math.cos(n),i=n===t?Math.sin(n):(r-Math.cos(t))/(t-n),u=r/i+n;return xo(i)<Uo?ce:(e.invert=function(n,t){var e=u-t;return[Math.atan2(n,e)/i,u-K(i)*Math.sqrt(n*n+e*e)]},e)}function Ne(n,t){return[n,Math.log(Math.tan(Fo/4+t/2))]}function Ee(n){var t,e=oe(n),r=e.scale,i=e.translate,u=e.clipExtent;return e.scale=function(){var n=r.apply(e,arguments);return n===e?t?e.clipExtent(null):e:n},e.translate=function(){var n=i.apply(e,arguments);return n===e?t?e.clipExtent(null):e:n},e.clipExtent=function(n){var o=u.apply(e,arguments);if(o===e){if(t=null==n){var a=Fo*r(),l=i();u([[l[0]-a,l[1]-a],[l[0]+a,l[1]+a]])}}else t&&(o=null);return o},e.clipExtent(null)}function Ae(n,t){return[Math.log(Math.tan(Fo/4+t/2)),-n]}function Ce(n){return n[0]}function ze(n){return n[1]}function Le(n){for(var t=n.length,e=[0,1],r=2,i=2;t>i;i++){for(;r>1&&Q(n[e[r-2]],n[e[r-1]],n[i])<=0;)--r;e[r++]=i}return e.slice(0,r)}function qe(n,t){return n[0]-t[0]||n[1]-t[1]}function Te(n,t,e){return(e[0]-t[0])*(n[1]-t[1])<(e[1]-t[1])*(n[0]-t[0])}function Re(n,t,e,r){var i=n[0],u=e[0],o=t[0]-i,a=r[0]-u,l=n[1],c=e[1],f=t[1]-l,s=r[1]-c,h=(a*(l-c)-s*(i-u))/(s*o-a*f);return[i+h*o,l+h*f]}function De(n){var t=n[0],e=n[n.length-1];return!(t[0]-e[0]||t[1]-e[1])}function Pe(){rr(this),this.edge=this.site=this.circle=null}function Ue(n){var t=cl.pop()||new Pe;return t.site=n,t}function je(n){Be(n),ol.remove(n),cl.push(n),rr(n)}function Fe(n){var t=n.circle,e=t.x,r=t.cy,i={x:e,y:r},u=n.P,o=n.N,a=[n];je(n);for(var l=u;l.circle&&xo(e-l.circle.x)<Uo&&xo(r-l.circle.cy)<Uo;)u=l.P,a.unshift(l),je(l),l=u;a.unshift(l),Be(l);for(var c=o;c.circle&&xo(e-c.circle.x)<Uo&&xo(r-c.circle.cy)<Uo;)o=c.N,a.push(c),je(c),c=o;a.push(c),Be(c);var f,s=a.length;for(f=1;s>f;++f)c=a[f],l=a[f-1],nr(c.edge,l.site,c.site,i);l=a[0],c=a[s-1],c.edge=Ke(l.site,c.site,null,i),$e(l),$e(c)}function He(n){for(var t,e,r,i,u=n.x,o=n.y,a=ol._;a;)if(r=Oe(a,o)-u,r>Uo)a=a.L;else{if(i=u-Ie(a,o),!(i>Uo)){r>-Uo?(t=a.P,e=a):i>-Uo?(t=a,e=a.N):t=e=a;break}if(!a.R){t=a;break}a=a.R}var l=Ue(n);if(ol.insert(t,l),t||e){if(t===e)return Be(t),e=Ue(t.site),ol.insert(l,e),l.edge=e.edge=Ke(t.site,l.site),$e(t),void $e(e);if(!e)return void(l.edge=Ke(t.site,l.site));Be(t),Be(e);var c=t.site,f=c.x,s=c.y,h=n.x-f,p=n.y-s,g=e.site,v=g.x-f,d=g.y-s,y=2*(h*d-p*v),m=h*h+p*p,M=v*v+d*d,x={x:(d*m-p*M)/y+f,y:(h*M-v*m)/y+s};nr(e.edge,c,g,x),l.edge=Ke(c,n,null,x),e.edge=Ke(n,g,null,x),$e(t),$e(e)}}function Oe(n,t){var e=n.site,r=e.x,i=e.y,u=i-t;if(!u)return r;var o=n.P;if(!o)return-(1/0);e=o.site;var a=e.x,l=e.y,c=l-t;if(!c)return a;var f=a-r,s=1/u-1/c,h=f/c;return s?(-h+Math.sqrt(h*h-2*s*(f*f/(-2*c)-l+c/2+i-u/2)))/s+r:(r+a)/2}function Ie(n,t){var e=n.N;if(e)return Oe(e,t);var r=n.site;return r.y===t?r.x:1/0}function Ye(n){this.site=n,this.edges=[]}function Ze(n){for(var t,e,r,i,u,o,a,l,c,f,s=n[0][0],h=n[1][0],p=n[0][1],g=n[1][1],v=ul,d=v.length;d--;)if(u=v[d],u&&u.prepare())for(a=u.edges,l=a.length,o=0;l>o;)f=a[o].end(),r=f.x,i=f.y,c=a[++o%l].start(),t=c.x,e=c.y,(xo(r-t)>Uo||xo(i-e)>Uo)&&(a.splice(o,0,new tr(Qe(u.site,f,xo(r-s)<Uo&&g-i>Uo?{x:s,y:xo(t-s)<Uo?e:g}:xo(i-g)<Uo&&h-r>Uo?{x:xo(e-g)<Uo?t:h,y:g}:xo(r-h)<Uo&&i-p>Uo?{x:h,y:xo(t-h)<Uo?e:p}:xo(i-p)<Uo&&r-s>Uo?{x:xo(e-p)<Uo?t:s,y:p}:null),u.site,null)),++l)}function Ve(n,t){return t.angle-n.angle}function Xe(){rr(this),this.x=this.y=this.arc=this.site=this.cy=null}function $e(n){var t=n.P,e=n.N;if(t&&e){var r=t.site,i=n.site,u=e.site;if(r!==u){var o=i.x,a=i.y,l=r.x-o,c=r.y-a,f=u.x-o,s=u.y-a,h=2*(l*s-c*f);if(!(h>=-jo)){var p=l*l+c*c,g=f*f+s*s,v=(s*p-c*g)/h,d=(l*g-f*p)/h,s=d+a,y=fl.pop()||new Xe;y.arc=n,y.site=i,y.x=v+o,y.y=s+Math.sqrt(v*v+d*d),y.cy=s,n.circle=y;for(var m=null,M=ll._;M;)if(y.y<M.y||y.y===M.y&&y.x<=M.x){if(!M.L){m=M.P;break}M=M.L}else{if(!M.R){m=M;break}M=M.R}ll.insert(m,y),m||(al=y)}}}}function Be(n){var t=n.circle;t&&(t.P||(al=t.N),ll.remove(t),fl.push(t),rr(t),n.circle=null)}function We(n){for(var t,e=il,r=Yt(n[0][0],n[0][1],n[1][0],n[1][1]),i=e.length;i--;)t=e[i],(!Je(t,n)||!r(t)||xo(t.a.x-t.b.x)<Uo&&xo(t.a.y-t.b.y)<Uo)&&(t.a=t.b=null,e.splice(i,1))}function Je(n,t){var e=n.b;if(e)return!0;var r,i,u=n.a,o=t[0][0],a=t[1][0],l=t[0][1],c=t[1][1],f=n.l,s=n.r,h=f.x,p=f.y,g=s.x,v=s.y,d=(h+g)/2,y=(p+v)/2;if(v===p){if(o>d||d>=a)return;if(h>g){if(u){if(u.y>=c)return}else u={x:d,y:l};e={x:d,y:c}}else{if(u){if(u.y<l)return}else u={x:d,y:c};e={x:d,y:l}}}else if(r=(h-g)/(v-p),i=y-r*d,-1>r||r>1)if(h>g){if(u){if(u.y>=c)return}else u={x:(l-i)/r,y:l};e={x:(c-i)/r,y:c}}else{if(u){if(u.y<l)return}else u={x:(c-i)/r,y:c};e={x:(l-i)/r,y:l}}else if(v>p){if(u){if(u.x>=a)return}else u={x:o,y:r*o+i};e={x:a,y:r*a+i}}else{if(u){if(u.x<o)return}else u={x:a,y:r*a+i};e={x:o,y:r*o+i}}return n.a=u,n.b=e,!0}function Ge(n,t){this.l=n,this.r=t,this.a=this.b=null}function Ke(n,t,e,r){var i=new Ge(n,t);return il.push(i),e&&nr(i,n,t,e),r&&nr(i,t,n,r),ul[n.i].edges.push(new tr(i,n,t)),ul[t.i].edges.push(new tr(i,t,n)),i}function Qe(n,t,e){var r=new Ge(n,null);return r.a=t,r.b=e,il.push(r),r}function nr(n,t,e,r){n.a||n.b?n.l===e?n.b=r:n.a=r:(n.a=r,n.l=t,n.r=e)}function tr(n,t,e){var r=n.a,i=n.b;this.edge=n,this.site=t,this.angle=e?Math.atan2(e.y-t.y,e.x-t.x):n.l===t?Math.atan2(i.x-r.x,r.y-i.y):Math.atan2(r.x-i.x,i.y-r.y)}function er(){this._=null}function rr(n){n.U=n.C=n.L=n.R=n.P=n.N=null}function ir(n,t){var e=t,r=t.R,i=e.U;i?i.L===e?i.L=r:i.R=r:n._=r,r.U=i,e.U=r,e.R=r.L,e.R&&(e.R.U=e),r.L=e}function ur(n,t){var e=t,r=t.L,i=e.U;i?i.L===e?i.L=r:i.R=r:n._=r,r.U=i,e.U=r,e.L=r.R,e.L&&(e.L.U=e),r.R=e}function or(n){for(;n.L;)n=n.L;return n}function ar(n,t){var e,r,i,u=n.sort(lr).pop();for(il=[],ul=new Array(n.length),ol=new er,ll=new er;;)if(i=al,u&&(!i||u.y<i.y||u.y===i.y&&u.x<i.x))u.x===e&&u.y===r||(ul[u.i]=new Ye(u),He(u),e=u.x,r=u.y),u=n.pop();else{if(!i)break;Fe(i.arc)}t&&(We(t),Ze(t));var o={cells:ul,edges:il};return ol=ll=il=ul=null,o}function lr(n,t){return t.y-n.y||t.x-n.x}function cr(n,t,e){return(n.x-e.x)*(t.y-n.y)-(n.x-t.x)*(e.y-n.y)}function fr(n){return n.x}function sr(n){return n.y}function hr(){return{leaf:!0,nodes:[],point:null,x:null,y:null}}function pr(n,t,e,r,i,u){if(!n(t,e,r,i,u)){var o=.5*(e+i),a=.5*(r+u),l=t.nodes;l[0]&&pr(n,l[0],e,r,o,a),l[1]&&pr(n,l[1],o,r,i,a),l[2]&&pr(n,l[2],e,a,o,u),l[3]&&pr(n,l[3],o,a,i,u)}}function gr(n,t,e,r,i,u,o){var a,l=1/0;return function c(n,f,s,h,p){if(!(f>u||s>o||r>h||i>p)){if(g=n.point){var g,v=t-n.x,d=e-n.y,y=v*v+d*d;if(l>y){var m=Math.sqrt(l=y);r=t-m,i=e-m,u=t+m,o=e+m,a=g}}for(var M=n.nodes,x=.5*(f+h),b=.5*(s+p),_=t>=x,w=e>=b,S=w<<1|_,k=S+4;k>S;++S)if(n=M[3&S])switch(3&S){case 0:c(n,f,s,x,b);break;case 1:c(n,x,s,h,b);break;case 2:c(n,f,b,x,p);break;case 3:c(n,x,b,h,p)}}}(n,r,i,u,o),a}function vr(n,t){n=ao.rgb(n),t=ao.rgb(t);var e=n.r,r=n.g,i=n.b,u=t.r-e,o=t.g-r,a=t.b-i;return function(n){return"#"+bn(Math.round(e+u*n))+bn(Math.round(r+o*n))+bn(Math.round(i+a*n))}}function dr(n,t){var e,r={},i={};for(e in n)e in t?r[e]=Mr(n[e],t[e]):i[e]=n[e];for(e in t)e in n||(i[e]=t[e]);return function(n){for(e in r)i[e]=r[e](n);return i}}function yr(n,t){return n=+n,t=+t,function(e){return n*(1-e)+t*e}}function mr(n,t){var e,r,i,u=hl.lastIndex=pl.lastIndex=0,o=-1,a=[],l=[];for(n+="",t+="";(e=hl.exec(n))&&(r=pl.exec(t));)(i=r.index)>u&&(i=t.slice(u,i),a[o]?a[o]+=i:a[++o]=i),(e=e[0])===(r=r[0])?a[o]?a[o]+=r:a[++o]=r:(a[++o]=null,l.push({i:o,x:yr(e,r)})),u=pl.lastIndex;return u<t.length&&(i=t.slice(u),a[o]?a[o]+=i:a[++o]=i),a.length<2?l[0]?(t=l[0].x,function(n){return t(n)+""}):function(){return t}:(t=l.length,function(n){for(var e,r=0;t>r;++r)a[(e=l[r]).i]=e.x(n);return a.join("")})}function Mr(n,t){for(var e,r=ao.interpolators.length;--r>=0&&!(e=ao.interpolators[r](n,t)););return e}function xr(n,t){var e,r=[],i=[],u=n.length,o=t.length,a=Math.min(n.length,t.length);for(e=0;a>e;++e)r.push(Mr(n[e],t[e]));for(;u>e;++e)i[e]=n[e];for(;o>e;++e)i[e]=t[e];return function(n){for(e=0;a>e;++e)i[e]=r[e](n);return i}}function br(n){return function(t){return 0>=t?0:t>=1?1:n(t)}}function _r(n){return function(t){return 1-n(1-t)}}function wr(n){return function(t){return.5*(.5>t?n(2*t):2-n(2-2*t))}}function Sr(n){return n*n}function kr(n){return n*n*n}function Nr(n){if(0>=n)return 0;if(n>=1)return 1;var t=n*n,e=t*n;return 4*(.5>n?e:3*(n-t)+e-.75)}function Er(n){return function(t){return Math.pow(t,n)}}function Ar(n){return 1-Math.cos(n*Io)}function Cr(n){return Math.pow(2,10*(n-1))}function zr(n){return 1-Math.sqrt(1-n*n)}function Lr(n,t){var e;return arguments.length<2&&(t=.45),arguments.length?e=t/Ho*Math.asin(1/n):(n=1,e=t/4),function(r){return 1+n*Math.pow(2,-10*r)*Math.sin((r-e)*Ho/t)}}function qr(n){return n||(n=1.70158),function(t){return t*t*((n+1)*t-n)}}function Tr(n){return 1/2.75>n?7.5625*n*n:2/2.75>n?7.5625*(n-=1.5/2.75)*n+.75:2.5/2.75>n?7.5625*(n-=2.25/2.75)*n+.9375:7.5625*(n-=2.625/2.75)*n+.984375}function Rr(n,t){n=ao.hcl(n),t=ao.hcl(t);var e=n.h,r=n.c,i=n.l,u=t.h-e,o=t.c-r,a=t.l-i;return isNaN(o)&&(o=0,r=isNaN(r)?t.c:r),isNaN(u)?(u=0,e=isNaN(e)?t.h:e):u>180?u-=360:-180>u&&(u+=360),function(n){return sn(e+u*n,r+o*n,i+a*n)+""}}function Dr(n,t){n=ao.hsl(n),t=ao.hsl(t);var e=n.h,r=n.s,i=n.l,u=t.h-e,o=t.s-r,a=t.l-i;return isNaN(o)&&(o=0,r=isNaN(r)?t.s:r),isNaN(u)?(u=0,e=isNaN(e)?t.h:e):u>180?u-=360:-180>u&&(u+=360),function(n){return cn(e+u*n,r+o*n,i+a*n)+""}}function Pr(n,t){n=ao.lab(n),t=ao.lab(t);var e=n.l,r=n.a,i=n.b,u=t.l-e,o=t.a-r,a=t.b-i;return function(n){return pn(e+u*n,r+o*n,i+a*n)+""}}function Ur(n,t){return t-=n,function(e){return Math.round(n+t*e)}}function jr(n){var t=[n.a,n.b],e=[n.c,n.d],r=Hr(t),i=Fr(t,e),u=Hr(Or(e,t,-i))||0;t[0]*e[1]<e[0]*t[1]&&(t[0]*=-1,t[1]*=-1,r*=-1,i*=-1),this.rotate=(r?Math.atan2(t[1],t[0]):Math.atan2(-e[0],e[1]))*Zo,this.translate=[n.e,n.f],this.scale=[r,u],this.skew=u?Math.atan2(i,u)*Zo:0}function Fr(n,t){return n[0]*t[0]+n[1]*t[1]}function Hr(n){var t=Math.sqrt(Fr(n,n));return t&&(n[0]/=t,n[1]/=t),t}function Or(n,t,e){return n[0]+=e*t[0],n[1]+=e*t[1],n}function Ir(n){return n.length?n.pop()+",":""}function Yr(n,t,e,r){if(n[0]!==t[0]||n[1]!==t[1]){var i=e.push("translate(",null,",",null,")");r.push({i:i-4,x:yr(n[0],t[0])},{i:i-2,x:yr(n[1],t[1])})}else(t[0]||t[1])&&e.push("translate("+t+")")}function Zr(n,t,e,r){n!==t?(n-t>180?t+=360:t-n>180&&(n+=360),r.push({i:e.push(Ir(e)+"rotate(",null,")")-2,x:yr(n,t)})):t&&e.push(Ir(e)+"rotate("+t+")")}function Vr(n,t,e,r){n!==t?r.push({i:e.push(Ir(e)+"skewX(",null,")")-2,x:yr(n,t)}):t&&e.push(Ir(e)+"skewX("+t+")")}function Xr(n,t,e,r){if(n[0]!==t[0]||n[1]!==t[1]){var i=e.push(Ir(e)+"scale(",null,",",null,")");r.push({i:i-4,x:yr(n[0],t[0])},{i:i-2,x:yr(n[1],t[1])})}else 1===t[0]&&1===t[1]||e.push(Ir(e)+"scale("+t+")")}function $r(n,t){var e=[],r=[];return n=ao.transform(n),t=ao.transform(t),Yr(n.translate,t.translate,e,r),Zr(n.rotate,t.rotate,e,r),Vr(n.skew,t.skew,e,r),Xr(n.scale,t.scale,e,r),n=t=null,function(n){for(var t,i=-1,u=r.length;++i<u;)e[(t=r[i]).i]=t.x(n);return e.join("")}}function Br(n,t){return t=(t-=n=+n)||1/t,function(e){return(e-n)/t}}function Wr(n,t){return t=(t-=n=+n)||1/t,function(e){return Math.max(0,Math.min(1,(e-n)/t))}}function Jr(n){for(var t=n.source,e=n.target,r=Kr(t,e),i=[t];t!==r;)t=t.parent,i.push(t);for(var u=i.length;e!==r;)i.splice(u,0,e),e=e.parent;return i}function Gr(n){for(var t=[],e=n.parent;null!=e;)t.push(n),n=e,e=e.parent;return t.push(n),t}function Kr(n,t){if(n===t)return n;for(var e=Gr(n),r=Gr(t),i=e.pop(),u=r.pop(),o=null;i===u;)o=i,i=e.pop(),u=r.pop();return o}function Qr(n){n.fixed|=2}function ni(n){n.fixed&=-7}function ti(n){n.fixed|=4,n.px=n.x,n.py=n.y}function ei(n){n.fixed&=-5}function ri(n,t,e){var r=0,i=0;if(n.charge=0,!n.leaf)for(var u,o=n.nodes,a=o.length,l=-1;++l<a;)u=o[l],null!=u&&(ri(u,t,e),n.charge+=u.charge,r+=u.charge*u.cx,i+=u.charge*u.cy);if(n.point){n.leaf||(n.point.x+=Math.random()-.5,n.point.y+=Math.random()-.5);var c=t*e[n.point.index];n.charge+=n.pointCharge=c,r+=c*n.point.x,i+=c*n.point.y}n.cx=r/n.charge,n.cy=i/n.charge}function ii(n,t){return ao.rebind(n,t,"sort","children","value"),n.nodes=n,n.links=fi,n}function ui(n,t){for(var e=[n];null!=(n=e.pop());)if(t(n),(i=n.children)&&(r=i.length))for(var r,i;--r>=0;)e.push(i[r])}function oi(n,t){for(var e=[n],r=[];null!=(n=e.pop());)if(r.push(n),(u=n.children)&&(i=u.length))for(var i,u,o=-1;++o<i;)e.push(u[o]);for(;null!=(n=r.pop());)t(n)}function ai(n){return n.children}function li(n){return n.value}function ci(n,t){return t.value-n.value}function fi(n){return ao.merge(n.map(function(n){return(n.children||[]).map(function(t){return{source:n,target:t}})}))}function si(n){return n.x}function hi(n){return n.y}function pi(n,t,e){n.y0=t,n.y=e}function gi(n){return ao.range(n.length)}function vi(n){for(var t=-1,e=n[0].length,r=[];++t<e;)r[t]=0;return r}function di(n){for(var t,e=1,r=0,i=n[0][1],u=n.length;u>e;++e)(t=n[e][1])>i&&(r=e,i=t);return r}function yi(n){return n.reduce(mi,0)}function mi(n,t){return n+t[1]}function Mi(n,t){return xi(n,Math.ceil(Math.log(t.length)/Math.LN2+1))}function xi(n,t){for(var e=-1,r=+n[0],i=(n[1]-r)/t,u=[];++e<=t;)u[e]=i*e+r;return u}function bi(n){return[ao.min(n),ao.max(n)]}function _i(n,t){return n.value-t.value}function wi(n,t){var e=n._pack_next;n._pack_next=t,t._pack_prev=n,t._pack_next=e,e._pack_prev=t}function Si(n,t){n._pack_next=t,t._pack_prev=n}function ki(n,t){var e=t.x-n.x,r=t.y-n.y,i=n.r+t.r;return.999*i*i>e*e+r*r}function Ni(n){function t(n){f=Math.min(n.x-n.r,f),s=Math.max(n.x+n.r,s),h=Math.min(n.y-n.r,h),p=Math.max(n.y+n.r,p)}if((e=n.children)&&(c=e.length)){var e,r,i,u,o,a,l,c,f=1/0,s=-(1/0),h=1/0,p=-(1/0);if(e.forEach(Ei),r=e[0],r.x=-r.r,r.y=0,t(r),c>1&&(i=e[1],i.x=i.r,i.y=0,t(i),c>2))for(u=e[2],zi(r,i,u),t(u),wi(r,u),r._pack_prev=u,wi(u,i),i=r._pack_next,o=3;c>o;o++){zi(r,i,u=e[o]);var g=0,v=1,d=1;for(a=i._pack_next;a!==i;a=a._pack_next,v++)if(ki(a,u)){g=1;break}if(1==g)for(l=r._pack_prev;l!==a._pack_prev&&!ki(l,u);l=l._pack_prev,d++);g?(d>v||v==d&&i.r<r.r?Si(r,i=a):Si(r=l,i),o--):(wi(r,u),i=u,t(u))}var y=(f+s)/2,m=(h+p)/2,M=0;for(o=0;c>o;o++)u=e[o],u.x-=y,u.y-=m,M=Math.max(M,u.r+Math.sqrt(u.x*u.x+u.y*u.y));n.r=M,e.forEach(Ai)}}function Ei(n){n._pack_next=n._pack_prev=n}function Ai(n){delete n._pack_next,delete n._pack_prev}function Ci(n,t,e,r){var i=n.children;if(n.x=t+=r*n.x,n.y=e+=r*n.y,n.r*=r,i)for(var u=-1,o=i.length;++u<o;)Ci(i[u],t,e,r)}function zi(n,t,e){var r=n.r+e.r,i=t.x-n.x,u=t.y-n.y;if(r&&(i||u)){var o=t.r+e.r,a=i*i+u*u;o*=o,r*=r;var l=.5+(r-o)/(2*a),c=Math.sqrt(Math.max(0,2*o*(r+a)-(r-=a)*r-o*o))/(2*a);e.x=n.x+l*i+c*u,e.y=n.y+l*u-c*i}else e.x=n.x+r,e.y=n.y}function Li(n,t){return n.parent==t.parent?1:2}function qi(n){var t=n.children;return t.length?t[0]:n.t}function Ti(n){var t,e=n.children;return(t=e.length)?e[t-1]:n.t}function Ri(n,t,e){var r=e/(t.i-n.i);t.c-=r,t.s+=e,n.c+=r,t.z+=e,t.m+=e}function Di(n){for(var t,e=0,r=0,i=n.children,u=i.length;--u>=0;)t=i[u],t.z+=e,t.m+=e,e+=t.s+(r+=t.c)}function Pi(n,t,e){return n.a.parent===t.parent?n.a:e}function Ui(n){return 1+ao.max(n,function(n){return n.y})}function ji(n){return n.reduce(function(n,t){return n+t.x},0)/n.length}function Fi(n){var t=n.children;return t&&t.length?Fi(t[0]):n}function Hi(n){var t,e=n.children;return e&&(t=e.length)?Hi(e[t-1]):n}function Oi(n){return{x:n.x,y:n.y,dx:n.dx,dy:n.dy}}function Ii(n,t){var e=n.x+t[3],r=n.y+t[0],i=n.dx-t[1]-t[3],u=n.dy-t[0]-t[2];return 0>i&&(e+=i/2,i=0),0>u&&(r+=u/2,u=0),{x:e,y:r,dx:i,dy:u}}function Yi(n){var t=n[0],e=n[n.length-1];return e>t?[t,e]:[e,t]}function Zi(n){return n.rangeExtent?n.rangeExtent():Yi(n.range())}function Vi(n,t,e,r){var i=e(n[0],n[1]),u=r(t[0],t[1]);return function(n){return u(i(n))}}function Xi(n,t){var e,r=0,i=n.length-1,u=n[r],o=n[i];return u>o&&(e=r,r=i,i=e,e=u,u=o,o=e),n[r]=t.floor(u),n[i]=t.ceil(o),n}function $i(n){return n?{floor:function(t){return Math.floor(t/n)*n},ceil:function(t){return Math.ceil(t/n)*n}}:Sl}function Bi(n,t,e,r){var i=[],u=[],o=0,a=Math.min(n.length,t.length)-1;for(n[a]<n[0]&&(n=n.slice().reverse(),t=t.slice().reverse());++o<=a;)i.push(e(n[o-1],n[o])),u.push(r(t[o-1],t[o]));return function(t){var e=ao.bisect(n,t,1,a)-1;return u[e](i[e](t))}}function Wi(n,t,e,r){function i(){var i=Math.min(n.length,t.length)>2?Bi:Vi,l=r?Wr:Br;return o=i(n,t,l,e),a=i(t,n,l,Mr),u}function u(n){return o(n)}var o,a;return u.invert=function(n){return a(n)},u.domain=function(t){return arguments.length?(n=t.map(Number),i()):n},u.range=function(n){return arguments.length?(t=n,i()):t},u.rangeRound=function(n){return u.range(n).interpolate(Ur)},u.clamp=function(n){return arguments.length?(r=n,i()):r},u.interpolate=function(n){return arguments.length?(e=n,i()):e},u.ticks=function(t){return Qi(n,t)},u.tickFormat=function(t,e){return nu(n,t,e)},u.nice=function(t){return Gi(n,t),i()},u.copy=function(){return Wi(n,t,e,r)},i()}function Ji(n,t){return ao.rebind(n,t,"range","rangeRound","interpolate","clamp")}function Gi(n,t){return Xi(n,$i(Ki(n,t)[2])),Xi(n,$i(Ki(n,t)[2])),n}function Ki(n,t){null==t&&(t=10);var e=Yi(n),r=e[1]-e[0],i=Math.pow(10,Math.floor(Math.log(r/t)/Math.LN10)),u=t/r*i;return.15>=u?i*=10:.35>=u?i*=5:.75>=u&&(i*=2),e[0]=Math.ceil(e[0]/i)*i,e[1]=Math.floor(e[1]/i)*i+.5*i,e[2]=i,e}function Qi(n,t){return ao.range.apply(ao,Ki(n,t))}function nu(n,t,e){var r=Ki(n,t);if(e){var i=ha.exec(e);if(i.shift(),"s"===i[8]){var u=ao.formatPrefix(Math.max(xo(r[0]),xo(r[1])));return i[7]||(i[7]="."+tu(u.scale(r[2]))),i[8]="f",e=ao.format(i.join("")),function(n){return e(u.scale(n))+u.symbol}}i[7]||(i[7]="."+eu(i[8],r)),e=i.join("")}else e=",."+tu(r[2])+"f";return ao.format(e)}function tu(n){return-Math.floor(Math.log(n)/Math.LN10+.01)}function eu(n,t){var e=tu(t[2]);return n in kl?Math.abs(e-tu(Math.max(xo(t[0]),xo(t[1]))))+ +("e"!==n):e-2*("%"===n)}function ru(n,t,e,r){function i(n){return(e?Math.log(0>n?0:n):-Math.log(n>0?0:-n))/Math.log(t)}function u(n){return e?Math.pow(t,n):-Math.pow(t,-n)}function o(t){return n(i(t))}return o.invert=function(t){return u(n.invert(t))},o.domain=function(t){return arguments.length?(e=t[0]>=0,n.domain((r=t.map(Number)).map(i)),o):r},o.base=function(e){return arguments.length?(t=+e,n.domain(r.map(i)),o):t},o.nice=function(){var t=Xi(r.map(i),e?Math:El);return n.domain(t),r=t.map(u),o},o.ticks=function(){var n=Yi(r),o=[],a=n[0],l=n[1],c=Math.floor(i(a)),f=Math.ceil(i(l)),s=t%1?2:t;if(isFinite(f-c)){if(e){for(;f>c;c++)for(var h=1;s>h;h++)o.push(u(c)*h);o.push(u(c))}else for(o.push(u(c));c++<f;)for(var h=s-1;h>0;h--)o.push(u(c)*h);for(c=0;o[c]<a;c++);for(f=o.length;o[f-1]>l;f--);o=o.slice(c,f)}return o},o.tickFormat=function(n,e){if(!arguments.length)return Nl;arguments.length<2?e=Nl:"function"!=typeof e&&(e=ao.format(e));var r=Math.max(1,t*n/o.ticks().length);return function(n){var o=n/u(Math.round(i(n)));return t-.5>o*t&&(o*=t),r>=o?e(n):""}},o.copy=function(){return ru(n.copy(),t,e,r)},Ji(o,n)}function iu(n,t,e){function r(t){return n(i(t))}var i=uu(t),u=uu(1/t);return r.invert=function(t){return u(n.invert(t))},r.domain=function(t){return arguments.length?(n.domain((e=t.map(Number)).map(i)),r):e},r.ticks=function(n){return Qi(e,n)},r.tickFormat=function(n,t){return nu(e,n,t)},r.nice=function(n){return r.domain(Gi(e,n))},r.exponent=function(o){return arguments.length?(i=uu(t=o),u=uu(1/t),n.domain(e.map(i)),r):t},r.copy=function(){return iu(n.copy(),t,e)},Ji(r,n)}function uu(n){return function(t){return 0>t?-Math.pow(-t,n):Math.pow(t,n)}}function ou(n,t){function e(e){return u[((i.get(e)||("range"===t.t?i.set(e,n.push(e)):NaN))-1)%u.length]}function r(t,e){return ao.range(n.length).map(function(n){return t+e*n})}var i,u,o;return e.domain=function(r){if(!arguments.length)return n;n=[],i=new c;for(var u,o=-1,a=r.length;++o<a;)i.has(u=r[o])||i.set(u,n.push(u));return e[t.t].apply(e,t.a)},e.range=function(n){return arguments.length?(u=n,o=0,t={t:"range",a:arguments},e):u},e.rangePoints=function(i,a){arguments.length<2&&(a=0);var l=i[0],c=i[1],f=n.length<2?(l=(l+c)/2,0):(c-l)/(n.length-1+a);return u=r(l+f*a/2,f),o=0,t={t:"rangePoints",a:arguments},e},e.rangeRoundPoints=function(i,a){arguments.length<2&&(a=0);var l=i[0],c=i[1],f=n.length<2?(l=c=Math.round((l+c)/2),0):(c-l)/(n.length-1+a)|0;return u=r(l+Math.round(f*a/2+(c-l-(n.length-1+a)*f)/2),f),o=0,t={t:"rangeRoundPoints",a:arguments},e},e.rangeBands=function(i,a,l){arguments.length<2&&(a=0),arguments.length<3&&(l=a);var c=i[1]<i[0],f=i[c-0],s=i[1-c],h=(s-f)/(n.length-a+2*l);return u=r(f+h*l,h),c&&u.reverse(),o=h*(1-a),t={t:"rangeBands",a:arguments},e},e.rangeRoundBands=function(i,a,l){arguments.length<2&&(a=0),arguments.length<3&&(l=a);var c=i[1]<i[0],f=i[c-0],s=i[1-c],h=Math.floor((s-f)/(n.length-a+2*l));return u=r(f+Math.round((s-f-(n.length-a)*h)/2),h),c&&u.reverse(),o=Math.round(h*(1-a)),t={t:"rangeRoundBands",a:arguments},e},e.rangeBand=function(){return o},e.rangeExtent=function(){return Yi(t.a[0])},e.copy=function(){return ou(n,t)},e.domain(n)}function au(n,t){function u(){var e=0,r=t.length;for(a=[];++e<r;)a[e-1]=ao.quantile(n,e/r);return o}function o(n){return isNaN(n=+n)?void 0:t[ao.bisect(a,n)]}var a;return o.domain=function(t){return arguments.length?(n=t.map(r).filter(i).sort(e),u()):n},o.range=function(n){return arguments.length?(t=n,u()):t},o.quantiles=function(){return a},o.invertExtent=function(e){return e=t.indexOf(e),0>e?[NaN,NaN]:[e>0?a[e-1]:n[0],e<a.length?a[e]:n[n.length-1]]},o.copy=function(){return au(n,t)},u()}function lu(n,t,e){function r(t){return e[Math.max(0,Math.min(o,Math.floor(u*(t-n))))]}function i(){return u=e.length/(t-n),o=e.length-1,r}var u,o;return r.domain=function(e){return arguments.length?(n=+e[0],t=+e[e.length-1],i()):[n,t]},r.range=function(n){return arguments.length?(e=n,i()):e},r.invertExtent=function(t){return t=e.indexOf(t),t=0>t?NaN:t/u+n,[t,t+1/u]},r.copy=function(){return lu(n,t,e)},i()}function cu(n,t){function e(e){return e>=e?t[ao.bisect(n,e)]:void 0}return e.domain=function(t){return arguments.length?(n=t,e):n},e.range=function(n){return arguments.length?(t=n,e):t},e.invertExtent=function(e){return e=t.indexOf(e),[n[e-1],n[e]]},e.copy=function(){return cu(n,t)},e}function fu(n){function t(n){return+n}return t.invert=t,t.domain=t.range=function(e){return arguments.length?(n=e.map(t),t):n},t.ticks=function(t){return Qi(n,t)},t.tickFormat=function(t,e){return nu(n,t,e)},t.copy=function(){return fu(n)},t}function su(){return 0}function hu(n){return n.innerRadius}function pu(n){return n.outerRadius}function gu(n){return n.startAngle}function vu(n){return n.endAngle}function du(n){return n&&n.padAngle}function yu(n,t,e,r){return(n-e)*t-(t-r)*n>0?0:1}function mu(n,t,e,r,i){var u=n[0]-t[0],o=n[1]-t[1],a=(i?r:-r)/Math.sqrt(u*u+o*o),l=a*o,c=-a*u,f=n[0]+l,s=n[1]+c,h=t[0]+l,p=t[1]+c,g=(f+h)/2,v=(s+p)/2,d=h-f,y=p-s,m=d*d+y*y,M=e-r,x=f*p-h*s,b=(0>y?-1:1)*Math.sqrt(Math.max(0,M*M*m-x*x)),_=(x*y-d*b)/m,w=(-x*d-y*b)/m,S=(x*y+d*b)/m,k=(-x*d+y*b)/m,N=_-g,E=w-v,A=S-g,C=k-v;return N*N+E*E>A*A+C*C&&(_=S,w=k),[[_-l,w-c],[_*e/M,w*e/M]]}function Mu(n){function t(t){function o(){c.push("M",u(n(f),a))}for(var l,c=[],f=[],s=-1,h=t.length,p=En(e),g=En(r);++s<h;)i.call(this,l=t[s],s)?f.push([+p.call(this,l,s),+g.call(this,l,s)]):f.length&&(o(),f=[]);return f.length&&o(),c.length?c.join(""):null}var e=Ce,r=ze,i=zt,u=xu,o=u.key,a=.7;return t.x=function(n){return arguments.length?(e=n,t):e},t.y=function(n){return arguments.length?(r=n,t):r},t.defined=function(n){return arguments.length?(i=n,t):i},t.interpolate=function(n){return arguments.length?(o="function"==typeof n?u=n:(u=Tl.get(n)||xu).key,t):o},t.tension=function(n){return arguments.length?(a=n,t):a},t}function xu(n){return n.length>1?n.join("L"):n+"Z"}function bu(n){return n.join("L")+"Z"}function _u(n){for(var t=0,e=n.length,r=n[0],i=[r[0],",",r[1]];++t<e;)i.push("H",(r[0]+(r=n[t])[0])/2,"V",r[1]);return e>1&&i.push("H",r[0]),i.join("")}function wu(n){for(var t=0,e=n.length,r=n[0],i=[r[0],",",r[1]];++t<e;)i.push("V",(r=n[t])[1],"H",r[0]);return i.join("")}function Su(n){for(var t=0,e=n.length,r=n[0],i=[r[0],",",r[1]];++t<e;)i.push("H",(r=n[t])[0],"V",r[1]);return i.join("")}function ku(n,t){return n.length<4?xu(n):n[1]+Au(n.slice(1,-1),Cu(n,t))}function Nu(n,t){return n.length<3?bu(n):n[0]+Au((n.push(n[0]),n),Cu([n[n.length-2]].concat(n,[n[1]]),t))}function Eu(n,t){return n.length<3?xu(n):n[0]+Au(n,Cu(n,t))}function Au(n,t){if(t.length<1||n.length!=t.length&&n.length!=t.length+2)return xu(n);var e=n.length!=t.length,r="",i=n[0],u=n[1],o=t[0],a=o,l=1;if(e&&(r+="Q"+(u[0]-2*o[0]/3)+","+(u[1]-2*o[1]/3)+","+u[0]+","+u[1],i=n[1],l=2),t.length>1){a=t[1],u=n[l],l++,r+="C"+(i[0]+o[0])+","+(i[1]+o[1])+","+(u[0]-a[0])+","+(u[1]-a[1])+","+u[0]+","+u[1];for(var c=2;c<t.length;c++,l++)u=n[l],a=t[c],r+="S"+(u[0]-a[0])+","+(u[1]-a[1])+","+u[0]+","+u[1]}if(e){var f=n[l];r+="Q"+(u[0]+2*a[0]/3)+","+(u[1]+2*a[1]/3)+","+f[0]+","+f[1]}return r}function Cu(n,t){for(var e,r=[],i=(1-t)/2,u=n[0],o=n[1],a=1,l=n.length;++a<l;)e=u,u=o,o=n[a],r.push([i*(o[0]-e[0]),i*(o[1]-e[1])]);return r}function zu(n){if(n.length<3)return xu(n);var t=1,e=n.length,r=n[0],i=r[0],u=r[1],o=[i,i,i,(r=n[1])[0]],a=[u,u,u,r[1]],l=[i,",",u,"L",Ru(Pl,o),",",Ru(Pl,a)];for(n.push(n[e-1]);++t<=e;)r=n[t],o.shift(),o.push(r[0]),a.shift(),a.push(r[1]),Du(l,o,a);return n.pop(),l.push("L",r),l.join("")}function Lu(n){if(n.length<4)return xu(n);for(var t,e=[],r=-1,i=n.length,u=[0],o=[0];++r<3;)t=n[r],u.push(t[0]),o.push(t[1]);for(e.push(Ru(Pl,u)+","+Ru(Pl,o)),--r;++r<i;)t=n[r],u.shift(),u.push(t[0]),o.shift(),o.push(t[1]),Du(e,u,o);return e.join("")}function qu(n){for(var t,e,r=-1,i=n.length,u=i+4,o=[],a=[];++r<4;)e=n[r%i],o.push(e[0]),a.push(e[1]);for(t=[Ru(Pl,o),",",Ru(Pl,a)],--r;++r<u;)e=n[r%i],o.shift(),o.push(e[0]),a.shift(),a.push(e[1]),Du(t,o,a);return t.join("")}function Tu(n,t){var e=n.length-1;if(e)for(var r,i,u=n[0][0],o=n[0][1],a=n[e][0]-u,l=n[e][1]-o,c=-1;++c<=e;)r=n[c],i=c/e,r[0]=t*r[0]+(1-t)*(u+i*a),r[1]=t*r[1]+(1-t)*(o+i*l);return zu(n)}function Ru(n,t){return n[0]*t[0]+n[1]*t[1]+n[2]*t[2]+n[3]*t[3]}function Du(n,t,e){n.push("C",Ru(Rl,t),",",Ru(Rl,e),",",Ru(Dl,t),",",Ru(Dl,e),",",Ru(Pl,t),",",Ru(Pl,e))}function Pu(n,t){return(t[1]-n[1])/(t[0]-n[0])}function Uu(n){for(var t=0,e=n.length-1,r=[],i=n[0],u=n[1],o=r[0]=Pu(i,u);++t<e;)r[t]=(o+(o=Pu(i=u,u=n[t+1])))/2;return r[t]=o,r}function ju(n){for(var t,e,r,i,u=[],o=Uu(n),a=-1,l=n.length-1;++a<l;)t=Pu(n[a],n[a+1]),xo(t)<Uo?o[a]=o[a+1]=0:(e=o[a]/t,r=o[a+1]/t,i=e*e+r*r,i>9&&(i=3*t/Math.sqrt(i),o[a]=i*e,o[a+1]=i*r));for(a=-1;++a<=l;)i=(n[Math.min(l,a+1)][0]-n[Math.max(0,a-1)][0])/(6*(1+o[a]*o[a])),u.push([i||0,o[a]*i||0]);return u}function Fu(n){return n.length<3?xu(n):n[0]+Au(n,ju(n))}function Hu(n){for(var t,e,r,i=-1,u=n.length;++i<u;)t=n[i],e=t[0],r=t[1]-Io,t[0]=e*Math.cos(r),t[1]=e*Math.sin(r);return n}function Ou(n){function t(t){function l(){v.push("M",a(n(y),s),f,c(n(d.reverse()),s),"Z")}for(var h,p,g,v=[],d=[],y=[],m=-1,M=t.length,x=En(e),b=En(i),_=e===r?function(){
-			return p}:En(r),w=i===u?function(){return g}:En(u);++m<M;)o.call(this,h=t[m],m)?(d.push([p=+x.call(this,h,m),g=+b.call(this,h,m)]),y.push([+_.call(this,h,m),+w.call(this,h,m)])):d.length&&(l(),d=[],y=[]);return d.length&&l(),v.length?v.join(""):null}var e=Ce,r=Ce,i=0,u=ze,o=zt,a=xu,l=a.key,c=a,f="L",s=.7;return t.x=function(n){return arguments.length?(e=r=n,t):r},t.x0=function(n){return arguments.length?(e=n,t):e},t.x1=function(n){return arguments.length?(r=n,t):r},t.y=function(n){return arguments.length?(i=u=n,t):u},t.y0=function(n){return arguments.length?(i=n,t):i},t.y1=function(n){return arguments.length?(u=n,t):u},t.defined=function(n){return arguments.length?(o=n,t):o},t.interpolate=function(n){return arguments.length?(l="function"==typeof n?a=n:(a=Tl.get(n)||xu).key,c=a.reverse||a,f=a.closed?"M":"L",t):l},t.tension=function(n){return arguments.length?(s=n,t):s},t}function Iu(n){return n.radius}function Yu(n){return[n.x,n.y]}function Zu(n){return function(){var t=n.apply(this,arguments),e=t[0],r=t[1]-Io;return[e*Math.cos(r),e*Math.sin(r)]}}function Vu(){return 64}function Xu(){return"circle"}function $u(n){var t=Math.sqrt(n/Fo);return"M0,"+t+"A"+t+","+t+" 0 1,1 0,"+-t+"A"+t+","+t+" 0 1,1 0,"+t+"Z"}function Bu(n){return function(){var t,e,r;(t=this[n])&&(r=t[e=t.active])&&(r.timer.c=null,r.timer.t=NaN,--t.count?delete t[e]:delete this[n],t.active+=.5,r.event&&r.event.interrupt.call(this,this.__data__,r.index))}}function Wu(n,t,e){return ko(n,Yl),n.namespace=t,n.id=e,n}function Ju(n,t,e,r){var i=n.id,u=n.namespace;return Y(n,"function"==typeof e?function(n,o,a){n[u][i].tween.set(t,r(e.call(n,n.__data__,o,a)))}:(e=r(e),function(n){n[u][i].tween.set(t,e)}))}function Gu(n){return null==n&&(n=""),function(){this.textContent=n}}function Ku(n){return null==n?"__transition__":"__transition_"+n+"__"}function Qu(n,t,e,r,i){function u(n){var t=v.delay;return f.t=t+l,n>=t?o(n-t):void(f.c=o)}function o(e){var i=g.active,u=g[i];u&&(u.timer.c=null,u.timer.t=NaN,--g.count,delete g[i],u.event&&u.event.interrupt.call(n,n.__data__,u.index));for(var o in g)if(r>+o){var c=g[o];c.timer.c=null,c.timer.t=NaN,--g.count,delete g[o]}f.c=a,qn(function(){return f.c&&a(e||1)&&(f.c=null,f.t=NaN),1},0,l),g.active=r,v.event&&v.event.start.call(n,n.__data__,t),p=[],v.tween.forEach(function(e,r){(r=r.call(n,n.__data__,t))&&p.push(r)}),h=v.ease,s=v.duration}function a(i){for(var u=i/s,o=h(u),a=p.length;a>0;)p[--a].call(n,o);return u>=1?(v.event&&v.event.end.call(n,n.__data__,t),--g.count?delete g[r]:delete n[e],1):void 0}var l,f,s,h,p,g=n[e]||(n[e]={active:0,count:0}),v=g[r];v||(l=i.time,f=qn(u,0,l),v=g[r]={tween:new c,time:l,timer:f,delay:i.delay,duration:i.duration,ease:i.ease,index:t},i=null,++g.count)}function no(n,t,e){n.attr("transform",function(n){var r=t(n);return"translate("+(isFinite(r)?r:e(n))+",0)"})}function to(n,t,e){n.attr("transform",function(n){var r=t(n);return"translate(0,"+(isFinite(r)?r:e(n))+")"})}function eo(n){return n.toISOString()}function ro(n,t,e){function r(t){return n(t)}function i(n,e){var r=n[1]-n[0],i=r/e,u=ao.bisect(Kl,i);return u==Kl.length?[t.year,Ki(n.map(function(n){return n/31536e6}),e)[2]]:u?t[i/Kl[u-1]<Kl[u]/i?u-1:u]:[tc,Ki(n,e)[2]]}return r.invert=function(t){return io(n.invert(t))},r.domain=function(t){return arguments.length?(n.domain(t),r):n.domain().map(io)},r.nice=function(n,t){function e(e){return!isNaN(e)&&!n.range(e,io(+e+1),t).length}var u=r.domain(),o=Yi(u),a=null==n?i(o,10):"number"==typeof n&&i(o,n);return a&&(n=a[0],t=a[1]),r.domain(Xi(u,t>1?{floor:function(t){for(;e(t=n.floor(t));)t=io(t-1);return t},ceil:function(t){for(;e(t=n.ceil(t));)t=io(+t+1);return t}}:n))},r.ticks=function(n,t){var e=Yi(r.domain()),u=null==n?i(e,10):"number"==typeof n?i(e,n):!n.range&&[{range:n},t];return u&&(n=u[0],t=u[1]),n.range(e[0],io(+e[1]+1),1>t?1:t)},r.tickFormat=function(){return e},r.copy=function(){return ro(n.copy(),t,e)},Ji(r,n)}function io(n){return new Date(n)}function uo(n){return JSON.parse(n.responseText)}function oo(n){var t=fo.createRange();return t.selectNode(fo.body),t.createContextualFragment(n.responseText)}var ao={version:"3.5.17"},lo=[].slice,co=function(n){return lo.call(n)},fo=this.document;if(fo)try{co(fo.documentElement.childNodes)[0].nodeType}catch(so){co=function(n){for(var t=n.length,e=new Array(t);t--;)e[t]=n[t];return e}}if(Date.now||(Date.now=function(){return+new Date}),fo)try{fo.createElement("DIV").style.setProperty("opacity",0,"")}catch(ho){var po=this.Element.prototype,go=po.setAttribute,vo=po.setAttributeNS,yo=this.CSSStyleDeclaration.prototype,mo=yo.setProperty;po.setAttribute=function(n,t){go.call(this,n,t+"")},po.setAttributeNS=function(n,t,e){vo.call(this,n,t,e+"")},yo.setProperty=function(n,t,e){mo.call(this,n,t+"",e)}}ao.ascending=e,ao.descending=function(n,t){return n>t?-1:t>n?1:t>=n?0:NaN},ao.min=function(n,t){var e,r,i=-1,u=n.length;if(1===arguments.length){for(;++i<u;)if(null!=(r=n[i])&&r>=r){e=r;break}for(;++i<u;)null!=(r=n[i])&&e>r&&(e=r)}else{for(;++i<u;)if(null!=(r=t.call(n,n[i],i))&&r>=r){e=r;break}for(;++i<u;)null!=(r=t.call(n,n[i],i))&&e>r&&(e=r)}return e},ao.max=function(n,t){var e,r,i=-1,u=n.length;if(1===arguments.length){for(;++i<u;)if(null!=(r=n[i])&&r>=r){e=r;break}for(;++i<u;)null!=(r=n[i])&&r>e&&(e=r)}else{for(;++i<u;)if(null!=(r=t.call(n,n[i],i))&&r>=r){e=r;break}for(;++i<u;)null!=(r=t.call(n,n[i],i))&&r>e&&(e=r)}return e},ao.extent=function(n,t){var e,r,i,u=-1,o=n.length;if(1===arguments.length){for(;++u<o;)if(null!=(r=n[u])&&r>=r){e=i=r;break}for(;++u<o;)null!=(r=n[u])&&(e>r&&(e=r),r>i&&(i=r))}else{for(;++u<o;)if(null!=(r=t.call(n,n[u],u))&&r>=r){e=i=r;break}for(;++u<o;)null!=(r=t.call(n,n[u],u))&&(e>r&&(e=r),r>i&&(i=r))}return[e,i]},ao.sum=function(n,t){var e,r=0,u=n.length,o=-1;if(1===arguments.length)for(;++o<u;)i(e=+n[o])&&(r+=e);else for(;++o<u;)i(e=+t.call(n,n[o],o))&&(r+=e);return r},ao.mean=function(n,t){var e,u=0,o=n.length,a=-1,l=o;if(1===arguments.length)for(;++a<o;)i(e=r(n[a]))?u+=e:--l;else for(;++a<o;)i(e=r(t.call(n,n[a],a)))?u+=e:--l;return l?u/l:void 0},ao.quantile=function(n,t){var e=(n.length-1)*t+1,r=Math.floor(e),i=+n[r-1],u=e-r;return u?i+u*(n[r]-i):i},ao.median=function(n,t){var u,o=[],a=n.length,l=-1;if(1===arguments.length)for(;++l<a;)i(u=r(n[l]))&&o.push(u);else for(;++l<a;)i(u=r(t.call(n,n[l],l)))&&o.push(u);return o.length?ao.quantile(o.sort(e),.5):void 0},ao.variance=function(n,t){var e,u,o=n.length,a=0,l=0,c=-1,f=0;if(1===arguments.length)for(;++c<o;)i(e=r(n[c]))&&(u=e-a,a+=u/++f,l+=u*(e-a));else for(;++c<o;)i(e=r(t.call(n,n[c],c)))&&(u=e-a,a+=u/++f,l+=u*(e-a));return f>1?l/(f-1):void 0},ao.deviation=function(){var n=ao.variance.apply(this,arguments);return n?Math.sqrt(n):n};var Mo=u(e);ao.bisectLeft=Mo.left,ao.bisect=ao.bisectRight=Mo.right,ao.bisector=function(n){return u(1===n.length?function(t,r){return e(n(t),r)}:n)},ao.shuffle=function(n,t,e){(u=arguments.length)<3&&(e=n.length,2>u&&(t=0));for(var r,i,u=e-t;u;)i=Math.random()*u--|0,r=n[u+t],n[u+t]=n[i+t],n[i+t]=r;return n},ao.permute=function(n,t){for(var e=t.length,r=new Array(e);e--;)r[e]=n[t[e]];return r},ao.pairs=function(n){for(var t,e=0,r=n.length-1,i=n[0],u=new Array(0>r?0:r);r>e;)u[e]=[t=i,i=n[++e]];return u},ao.transpose=function(n){if(!(i=n.length))return[];for(var t=-1,e=ao.min(n,o),r=new Array(e);++t<e;)for(var i,u=-1,a=r[t]=new Array(i);++u<i;)a[u]=n[u][t];return r},ao.zip=function(){return ao.transpose(arguments)},ao.keys=function(n){var t=[];for(var e in n)t.push(e);return t},ao.values=function(n){var t=[];for(var e in n)t.push(n[e]);return t},ao.entries=function(n){var t=[];for(var e in n)t.push({key:e,value:n[e]});return t},ao.merge=function(n){for(var t,e,r,i=n.length,u=-1,o=0;++u<i;)o+=n[u].length;for(e=new Array(o);--i>=0;)for(r=n[i],t=r.length;--t>=0;)e[--o]=r[t];return e};var xo=Math.abs;ao.range=function(n,t,e){if(arguments.length<3&&(e=1,arguments.length<2&&(t=n,n=0)),(t-n)/e===1/0)throw new Error("infinite range");var r,i=[],u=a(xo(e)),o=-1;if(n*=u,t*=u,e*=u,0>e)for(;(r=n+e*++o)>t;)i.push(r/u);else for(;(r=n+e*++o)<t;)i.push(r/u);return i},ao.map=function(n,t){var e=new c;if(n instanceof c)n.forEach(function(n,t){e.set(n,t)});else if(Array.isArray(n)){var r,i=-1,u=n.length;if(1===arguments.length)for(;++i<u;)e.set(i,n[i]);else for(;++i<u;)e.set(t.call(n,r=n[i],i),r)}else for(var o in n)e.set(o,n[o]);return e};var bo="__proto__",_o="\x00";l(c,{has:h,get:function(n){return this._[f(n)]},set:function(n,t){return this._[f(n)]=t},remove:p,keys:g,values:function(){var n=[];for(var t in this._)n.push(this._[t]);return n},entries:function(){var n=[];for(var t in this._)n.push({key:s(t),value:this._[t]});return n},size:v,empty:d,forEach:function(n){for(var t in this._)n.call(this,s(t),this._[t])}}),ao.nest=function(){function n(t,o,a){if(a>=u.length)return r?r.call(i,o):e?o.sort(e):o;for(var l,f,s,h,p=-1,g=o.length,v=u[a++],d=new c;++p<g;)(h=d.get(l=v(f=o[p])))?h.push(f):d.set(l,[f]);return t?(f=t(),s=function(e,r){f.set(e,n(t,r,a))}):(f={},s=function(e,r){f[e]=n(t,r,a)}),d.forEach(s),f}function t(n,e){if(e>=u.length)return n;var r=[],i=o[e++];return n.forEach(function(n,i){r.push({key:n,values:t(i,e)})}),i?r.sort(function(n,t){return i(n.key,t.key)}):r}var e,r,i={},u=[],o=[];return i.map=function(t,e){return n(e,t,0)},i.entries=function(e){return t(n(ao.map,e,0),0)},i.key=function(n){return u.push(n),i},i.sortKeys=function(n){return o[u.length-1]=n,i},i.sortValues=function(n){return e=n,i},i.rollup=function(n){return r=n,i},i},ao.set=function(n){var t=new y;if(n)for(var e=0,r=n.length;r>e;++e)t.add(n[e]);return t},l(y,{has:h,add:function(n){return this._[f(n+="")]=!0,n},remove:p,values:g,size:v,empty:d,forEach:function(n){for(var t in this._)n.call(this,s(t))}}),ao.behavior={},ao.rebind=function(n,t){for(var e,r=1,i=arguments.length;++r<i;)n[e=arguments[r]]=M(n,t,t[e]);return n};var wo=["webkit","ms","moz","Moz","o","O"];ao.dispatch=function(){for(var n=new _,t=-1,e=arguments.length;++t<e;)n[arguments[t]]=w(n);return n},_.prototype.on=function(n,t){var e=n.indexOf("."),r="";if(e>=0&&(r=n.slice(e+1),n=n.slice(0,e)),n)return arguments.length<2?this[n].on(r):this[n].on(r,t);if(2===arguments.length){if(null==t)for(n in this)this.hasOwnProperty(n)&&this[n].on(r,null);return this}},ao.event=null,ao.requote=function(n){return n.replace(So,"\\$&")};var So=/[\\\^\$\*\+\?\|\[\]\(\)\.\{\}]/g,ko={}.__proto__?function(n,t){n.__proto__=t}:function(n,t){for(var e in t)n[e]=t[e]},No=function(n,t){return t.querySelector(n)},Eo=function(n,t){return t.querySelectorAll(n)},Ao=function(n,t){var e=n.matches||n[x(n,"matchesSelector")];return(Ao=function(n,t){return e.call(n,t)})(n,t)};"function"==typeof Sizzle&&(No=function(n,t){return Sizzle(n,t)[0]||null},Eo=Sizzle,Ao=Sizzle.matchesSelector),ao.selection=function(){return ao.select(fo.documentElement)};var Co=ao.selection.prototype=[];Co.select=function(n){var t,e,r,i,u=[];n=A(n);for(var o=-1,a=this.length;++o<a;){u.push(t=[]),t.parentNode=(r=this[o]).parentNode;for(var l=-1,c=r.length;++l<c;)(i=r[l])?(t.push(e=n.call(i,i.__data__,l,o)),e&&"__data__"in i&&(e.__data__=i.__data__)):t.push(null)}return E(u)},Co.selectAll=function(n){var t,e,r=[];n=C(n);for(var i=-1,u=this.length;++i<u;)for(var o=this[i],a=-1,l=o.length;++a<l;)(e=o[a])&&(r.push(t=co(n.call(e,e.__data__,a,i))),t.parentNode=e);return E(r)};var zo="http://www.w3.org/1999/xhtml",Lo={svg:"http://www.w3.org/2000/svg",xhtml:zo,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};ao.ns={prefix:Lo,qualify:function(n){var t=n.indexOf(":"),e=n;return t>=0&&"xmlns"!==(e=n.slice(0,t))&&(n=n.slice(t+1)),Lo.hasOwnProperty(e)?{space:Lo[e],local:n}:n}},Co.attr=function(n,t){if(arguments.length<2){if("string"==typeof n){var e=this.node();return n=ao.ns.qualify(n),n.local?e.getAttributeNS(n.space,n.local):e.getAttribute(n)}for(t in n)this.each(z(t,n[t]));return this}return this.each(z(n,t))},Co.classed=function(n,t){if(arguments.length<2){if("string"==typeof n){var e=this.node(),r=(n=T(n)).length,i=-1;if(t=e.classList){for(;++i<r;)if(!t.contains(n[i]))return!1}else for(t=e.getAttribute("class");++i<r;)if(!q(n[i]).test(t))return!1;return!0}for(t in n)this.each(R(t,n[t]));return this}return this.each(R(n,t))},Co.style=function(n,e,r){var i=arguments.length;if(3>i){if("string"!=typeof n){2>i&&(e="");for(r in n)this.each(P(r,n[r],e));return this}if(2>i){var u=this.node();return t(u).getComputedStyle(u,null).getPropertyValue(n)}r=""}return this.each(P(n,e,r))},Co.property=function(n,t){if(arguments.length<2){if("string"==typeof n)return this.node()[n];for(t in n)this.each(U(t,n[t]));return this}return this.each(U(n,t))},Co.text=function(n){return arguments.length?this.each("function"==typeof n?function(){var t=n.apply(this,arguments);this.textContent=null==t?"":t}:null==n?function(){this.textContent=""}:function(){this.textContent=n}):this.node().textContent},Co.html=function(n){return arguments.length?this.each("function"==typeof n?function(){var t=n.apply(this,arguments);this.innerHTML=null==t?"":t}:null==n?function(){this.innerHTML=""}:function(){this.innerHTML=n}):this.node().innerHTML},Co.append=function(n){return n=j(n),this.select(function(){return this.appendChild(n.apply(this,arguments))})},Co.insert=function(n,t){return n=j(n),t=A(t),this.select(function(){return this.insertBefore(n.apply(this,arguments),t.apply(this,arguments)||null)})},Co.remove=function(){return this.each(F)},Co.data=function(n,t){function e(n,e){var r,i,u,o=n.length,s=e.length,h=Math.min(o,s),p=new Array(s),g=new Array(s),v=new Array(o);if(t){var d,y=new c,m=new Array(o);for(r=-1;++r<o;)(i=n[r])&&(y.has(d=t.call(i,i.__data__,r))?v[r]=i:y.set(d,i),m[r]=d);for(r=-1;++r<s;)(i=y.get(d=t.call(e,u=e[r],r)))?i!==!0&&(p[r]=i,i.__data__=u):g[r]=H(u),y.set(d,!0);for(r=-1;++r<o;)r in m&&y.get(m[r])!==!0&&(v[r]=n[r])}else{for(r=-1;++r<h;)i=n[r],u=e[r],i?(i.__data__=u,p[r]=i):g[r]=H(u);for(;s>r;++r)g[r]=H(e[r]);for(;o>r;++r)v[r]=n[r]}g.update=p,g.parentNode=p.parentNode=v.parentNode=n.parentNode,a.push(g),l.push(p),f.push(v)}var r,i,u=-1,o=this.length;if(!arguments.length){for(n=new Array(o=(r=this[0]).length);++u<o;)(i=r[u])&&(n[u]=i.__data__);return n}var a=Z([]),l=E([]),f=E([]);if("function"==typeof n)for(;++u<o;)e(r=this[u],n.call(r,r.parentNode.__data__,u));else for(;++u<o;)e(r=this[u],n);return l.enter=function(){return a},l.exit=function(){return f},l},Co.datum=function(n){return arguments.length?this.property("__data__",n):this.property("__data__")},Co.filter=function(n){var t,e,r,i=[];"function"!=typeof n&&(n=O(n));for(var u=0,o=this.length;o>u;u++){i.push(t=[]),t.parentNode=(e=this[u]).parentNode;for(var a=0,l=e.length;l>a;a++)(r=e[a])&&n.call(r,r.__data__,a,u)&&t.push(r)}return E(i)},Co.order=function(){for(var n=-1,t=this.length;++n<t;)for(var e,r=this[n],i=r.length-1,u=r[i];--i>=0;)(e=r[i])&&(u&&u!==e.nextSibling&&u.parentNode.insertBefore(e,u),u=e);return this},Co.sort=function(n){n=I.apply(this,arguments);for(var t=-1,e=this.length;++t<e;)this[t].sort(n);return this.order()},Co.each=function(n){return Y(this,function(t,e,r){n.call(t,t.__data__,e,r)})},Co.call=function(n){var t=co(arguments);return n.apply(t[0]=this,t),this},Co.empty=function(){return!this.node()},Co.node=function(){for(var n=0,t=this.length;t>n;n++)for(var e=this[n],r=0,i=e.length;i>r;r++){var u=e[r];if(u)return u}return null},Co.size=function(){var n=0;return Y(this,function(){++n}),n};var qo=[];ao.selection.enter=Z,ao.selection.enter.prototype=qo,qo.append=Co.append,qo.empty=Co.empty,qo.node=Co.node,qo.call=Co.call,qo.size=Co.size,qo.select=function(n){for(var t,e,r,i,u,o=[],a=-1,l=this.length;++a<l;){r=(i=this[a]).update,o.push(t=[]),t.parentNode=i.parentNode;for(var c=-1,f=i.length;++c<f;)(u=i[c])?(t.push(r[c]=e=n.call(i.parentNode,u.__data__,c,a)),e.__data__=u.__data__):t.push(null)}return E(o)},qo.insert=function(n,t){return arguments.length<2&&(t=V(this)),Co.insert.call(this,n,t)},ao.select=function(t){var e;return"string"==typeof t?(e=[No(t,fo)],e.parentNode=fo.documentElement):(e=[t],e.parentNode=n(t)),E([e])},ao.selectAll=function(n){var t;return"string"==typeof n?(t=co(Eo(n,fo)),t.parentNode=fo.documentElement):(t=co(n),t.parentNode=null),E([t])},Co.on=function(n,t,e){var r=arguments.length;if(3>r){if("string"!=typeof n){2>r&&(t=!1);for(e in n)this.each(X(e,n[e],t));return this}if(2>r)return(r=this.node()["__on"+n])&&r._;e=!1}return this.each(X(n,t,e))};var To=ao.map({mouseenter:"mouseover",mouseleave:"mouseout"});fo&&To.forEach(function(n){"on"+n in fo&&To.remove(n)});var Ro,Do=0;ao.mouse=function(n){return J(n,k())};var Po=this.navigator&&/WebKit/.test(this.navigator.userAgent)?-1:0;ao.touch=function(n,t,e){if(arguments.length<3&&(e=t,t=k().changedTouches),t)for(var r,i=0,u=t.length;u>i;++i)if((r=t[i]).identifier===e)return J(n,r)},ao.behavior.drag=function(){function n(){this.on("mousedown.drag",u).on("touchstart.drag",o)}function e(n,t,e,u,o){return function(){function a(){var n,e,r=t(h,v);r&&(n=r[0]-M[0],e=r[1]-M[1],g|=n|e,M=r,p({type:"drag",x:r[0]+c[0],y:r[1]+c[1],dx:n,dy:e}))}function l(){t(h,v)&&(y.on(u+d,null).on(o+d,null),m(g),p({type:"dragend"}))}var c,f=this,s=ao.event.target.correspondingElement||ao.event.target,h=f.parentNode,p=r.of(f,arguments),g=0,v=n(),d=".drag"+(null==v?"":"-"+v),y=ao.select(e(s)).on(u+d,a).on(o+d,l),m=W(s),M=t(h,v);i?(c=i.apply(f,arguments),c=[c.x-M[0],c.y-M[1]]):c=[0,0],p({type:"dragstart"})}}var r=N(n,"drag","dragstart","dragend"),i=null,u=e(b,ao.mouse,t,"mousemove","mouseup"),o=e(G,ao.touch,m,"touchmove","touchend");return n.origin=function(t){return arguments.length?(i=t,n):i},ao.rebind(n,r,"on")},ao.touches=function(n,t){return arguments.length<2&&(t=k().touches),t?co(t).map(function(t){var e=J(n,t);return e.identifier=t.identifier,e}):[]};var Uo=1e-6,jo=Uo*Uo,Fo=Math.PI,Ho=2*Fo,Oo=Ho-Uo,Io=Fo/2,Yo=Fo/180,Zo=180/Fo,Vo=Math.SQRT2,Xo=2,$o=4;ao.interpolateZoom=function(n,t){var e,r,i=n[0],u=n[1],o=n[2],a=t[0],l=t[1],c=t[2],f=a-i,s=l-u,h=f*f+s*s;if(jo>h)r=Math.log(c/o)/Vo,e=function(n){return[i+n*f,u+n*s,o*Math.exp(Vo*n*r)]};else{var p=Math.sqrt(h),g=(c*c-o*o+$o*h)/(2*o*Xo*p),v=(c*c-o*o-$o*h)/(2*c*Xo*p),d=Math.log(Math.sqrt(g*g+1)-g),y=Math.log(Math.sqrt(v*v+1)-v);r=(y-d)/Vo,e=function(n){var t=n*r,e=rn(d),a=o/(Xo*p)*(e*un(Vo*t+d)-en(d));return[i+a*f,u+a*s,o*e/rn(Vo*t+d)]}}return e.duration=1e3*r,e},ao.behavior.zoom=function(){function n(n){n.on(L,s).on(Wo+".zoom",p).on("dblclick.zoom",g).on(R,h)}function e(n){return[(n[0]-k.x)/k.k,(n[1]-k.y)/k.k]}function r(n){return[n[0]*k.k+k.x,n[1]*k.k+k.y]}function i(n){k.k=Math.max(A[0],Math.min(A[1],n))}function u(n,t){t=r(t),k.x+=n[0]-t[0],k.y+=n[1]-t[1]}function o(t,e,r,o){t.__chart__={x:k.x,y:k.y,k:k.k},i(Math.pow(2,o)),u(d=e,r),t=ao.select(t),C>0&&(t=t.transition().duration(C)),t.call(n.event)}function a(){b&&b.domain(x.range().map(function(n){return(n-k.x)/k.k}).map(x.invert)),w&&w.domain(_.range().map(function(n){return(n-k.y)/k.k}).map(_.invert))}function l(n){z++||n({type:"zoomstart"})}function c(n){a(),n({type:"zoom",scale:k.k,translate:[k.x,k.y]})}function f(n){--z||(n({type:"zoomend"}),d=null)}function s(){function n(){a=1,u(ao.mouse(i),h),c(o)}function r(){s.on(q,null).on(T,null),p(a),f(o)}var i=this,o=D.of(i,arguments),a=0,s=ao.select(t(i)).on(q,n).on(T,r),h=e(ao.mouse(i)),p=W(i);Il.call(i),l(o)}function h(){function n(){var n=ao.touches(g);return p=k.k,n.forEach(function(n){n.identifier in d&&(d[n.identifier]=e(n))}),n}function t(){var t=ao.event.target;ao.select(t).on(x,r).on(b,a),_.push(t);for(var e=ao.event.changedTouches,i=0,u=e.length;u>i;++i)d[e[i].identifier]=null;var l=n(),c=Date.now();if(1===l.length){if(500>c-M){var f=l[0];o(g,f,d[f.identifier],Math.floor(Math.log(k.k)/Math.LN2)+1),S()}M=c}else if(l.length>1){var f=l[0],s=l[1],h=f[0]-s[0],p=f[1]-s[1];y=h*h+p*p}}function r(){var n,t,e,r,o=ao.touches(g);Il.call(g);for(var a=0,l=o.length;l>a;++a,r=null)if(e=o[a],r=d[e.identifier]){if(t)break;n=e,t=r}if(r){var f=(f=e[0]-n[0])*f+(f=e[1]-n[1])*f,s=y&&Math.sqrt(f/y);n=[(n[0]+e[0])/2,(n[1]+e[1])/2],t=[(t[0]+r[0])/2,(t[1]+r[1])/2],i(s*p)}M=null,u(n,t),c(v)}function a(){if(ao.event.touches.length){for(var t=ao.event.changedTouches,e=0,r=t.length;r>e;++e)delete d[t[e].identifier];for(var i in d)return void n()}ao.selectAll(_).on(m,null),w.on(L,s).on(R,h),N(),f(v)}var p,g=this,v=D.of(g,arguments),d={},y=0,m=".zoom-"+ao.event.changedTouches[0].identifier,x="touchmove"+m,b="touchend"+m,_=[],w=ao.select(g),N=W(g);t(),l(v),w.on(L,null).on(R,t)}function p(){var n=D.of(this,arguments);m?clearTimeout(m):(Il.call(this),v=e(d=y||ao.mouse(this)),l(n)),m=setTimeout(function(){m=null,f(n)},50),S(),i(Math.pow(2,.002*Bo())*k.k),u(d,v),c(n)}function g(){var n=ao.mouse(this),t=Math.log(k.k)/Math.LN2;o(this,n,e(n),ao.event.shiftKey?Math.ceil(t)-1:Math.floor(t)+1)}var v,d,y,m,M,x,b,_,w,k={x:0,y:0,k:1},E=[960,500],A=Jo,C=250,z=0,L="mousedown.zoom",q="mousemove.zoom",T="mouseup.zoom",R="touchstart.zoom",D=N(n,"zoomstart","zoom","zoomend");return Wo||(Wo="onwheel"in fo?(Bo=function(){return-ao.event.deltaY*(ao.event.deltaMode?120:1)},"wheel"):"onmousewheel"in fo?(Bo=function(){return ao.event.wheelDelta},"mousewheel"):(Bo=function(){return-ao.event.detail},"MozMousePixelScroll")),n.event=function(n){n.each(function(){var n=D.of(this,arguments),t=k;Hl?ao.select(this).transition().each("start.zoom",function(){k=this.__chart__||{x:0,y:0,k:1},l(n)}).tween("zoom:zoom",function(){var e=E[0],r=E[1],i=d?d[0]:e/2,u=d?d[1]:r/2,o=ao.interpolateZoom([(i-k.x)/k.k,(u-k.y)/k.k,e/k.k],[(i-t.x)/t.k,(u-t.y)/t.k,e/t.k]);return function(t){var r=o(t),a=e/r[2];this.__chart__=k={x:i-r[0]*a,y:u-r[1]*a,k:a},c(n)}}).each("interrupt.zoom",function(){f(n)}).each("end.zoom",function(){f(n)}):(this.__chart__=k,l(n),c(n),f(n))})},n.translate=function(t){return arguments.length?(k={x:+t[0],y:+t[1],k:k.k},a(),n):[k.x,k.y]},n.scale=function(t){return arguments.length?(k={x:k.x,y:k.y,k:null},i(+t),a(),n):k.k},n.scaleExtent=function(t){return arguments.length?(A=null==t?Jo:[+t[0],+t[1]],n):A},n.center=function(t){return arguments.length?(y=t&&[+t[0],+t[1]],n):y},n.size=function(t){return arguments.length?(E=t&&[+t[0],+t[1]],n):E},n.duration=function(t){return arguments.length?(C=+t,n):C},n.x=function(t){return arguments.length?(b=t,x=t.copy(),k={x:0,y:0,k:1},n):b},n.y=function(t){return arguments.length?(w=t,_=t.copy(),k={x:0,y:0,k:1},n):w},ao.rebind(n,D,"on")};var Bo,Wo,Jo=[0,1/0];ao.color=an,an.prototype.toString=function(){return this.rgb()+""},ao.hsl=ln;var Go=ln.prototype=new an;Go.brighter=function(n){return n=Math.pow(.7,arguments.length?n:1),new ln(this.h,this.s,this.l/n)},Go.darker=function(n){return n=Math.pow(.7,arguments.length?n:1),new ln(this.h,this.s,n*this.l)},Go.rgb=function(){return cn(this.h,this.s,this.l)},ao.hcl=fn;var Ko=fn.prototype=new an;Ko.brighter=function(n){return new fn(this.h,this.c,Math.min(100,this.l+Qo*(arguments.length?n:1)))},Ko.darker=function(n){return new fn(this.h,this.c,Math.max(0,this.l-Qo*(arguments.length?n:1)))},Ko.rgb=function(){return sn(this.h,this.c,this.l).rgb()},ao.lab=hn;var Qo=18,na=.95047,ta=1,ea=1.08883,ra=hn.prototype=new an;ra.brighter=function(n){return new hn(Math.min(100,this.l+Qo*(arguments.length?n:1)),this.a,this.b)},ra.darker=function(n){return new hn(Math.max(0,this.l-Qo*(arguments.length?n:1)),this.a,this.b)},ra.rgb=function(){return pn(this.l,this.a,this.b)},ao.rgb=mn;var ia=mn.prototype=new an;ia.brighter=function(n){n=Math.pow(.7,arguments.length?n:1);var t=this.r,e=this.g,r=this.b,i=30;return t||e||r?(t&&i>t&&(t=i),e&&i>e&&(e=i),r&&i>r&&(r=i),new mn(Math.min(255,t/n),Math.min(255,e/n),Math.min(255,r/n))):new mn(i,i,i)},ia.darker=function(n){return n=Math.pow(.7,arguments.length?n:1),new mn(n*this.r,n*this.g,n*this.b)},ia.hsl=function(){return wn(this.r,this.g,this.b)},ia.toString=function(){return"#"+bn(this.r)+bn(this.g)+bn(this.b)};var ua=ao.map({aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074});ua.forEach(function(n,t){ua.set(n,Mn(t))}),ao.functor=En,ao.xhr=An(m),ao.dsv=function(n,t){function e(n,e,u){arguments.length<3&&(u=e,e=null);var o=Cn(n,t,null==e?r:i(e),u);return o.row=function(n){return arguments.length?o.response(null==(e=n)?r:i(n)):e},o}function r(n){return e.parse(n.responseText)}function i(n){return function(t){return e.parse(t.responseText,n)}}function u(t){return t.map(o).join(n)}function o(n){return a.test(n)?'"'+n.replace(/\"/g,'""')+'"':n}var a=new RegExp('["'+n+"\n]"),l=n.charCodeAt(0);return e.parse=function(n,t){var r;return e.parseRows(n,function(n,e){if(r)return r(n,e-1);var i=new Function("d","return {"+n.map(function(n,t){return JSON.stringify(n)+": d["+t+"]"}).join(",")+"}");r=t?function(n,e){return t(i(n),e)}:i})},e.parseRows=function(n,t){function e(){if(f>=c)return o;if(i)return i=!1,u;var t=f;if(34===n.charCodeAt(t)){for(var e=t;e++<c;)if(34===n.charCodeAt(e)){if(34!==n.charCodeAt(e+1))break;++e}f=e+2;var r=n.charCodeAt(e+1);return 13===r?(i=!0,10===n.charCodeAt(e+2)&&++f):10===r&&(i=!0),n.slice(t+1,e).replace(/""/g,'"')}for(;c>f;){var r=n.charCodeAt(f++),a=1;if(10===r)i=!0;else if(13===r)i=!0,10===n.charCodeAt(f)&&(++f,++a);else if(r!==l)continue;return n.slice(t,f-a)}return n.slice(t)}for(var r,i,u={},o={},a=[],c=n.length,f=0,s=0;(r=e())!==o;){for(var h=[];r!==u&&r!==o;)h.push(r),r=e();t&&null==(h=t(h,s++))||a.push(h)}return a},e.format=function(t){if(Array.isArray(t[0]))return e.formatRows(t);var r=new y,i=[];return t.forEach(function(n){for(var t in n)r.has(t)||i.push(r.add(t))}),[i.map(o).join(n)].concat(t.map(function(t){return i.map(function(n){return o(t[n])}).join(n)})).join("\n")},e.formatRows=function(n){return n.map(u).join("\n")},e},ao.csv=ao.dsv(",","text/csv"),ao.tsv=ao.dsv("	","text/tab-separated-values");var oa,aa,la,ca,fa=this[x(this,"requestAnimationFrame")]||function(n){setTimeout(n,17)};ao.timer=function(){qn.apply(this,arguments)},ao.timer.flush=function(){Rn(),Dn()},ao.round=function(n,t){return t?Math.round(n*(t=Math.pow(10,t)))/t:Math.round(n)};var sa=["y","z","a","f","p","n","\xb5","m","","k","M","G","T","P","E","Z","Y"].map(Un);ao.formatPrefix=function(n,t){var e=0;return(n=+n)&&(0>n&&(n*=-1),t&&(n=ao.round(n,Pn(n,t))),e=1+Math.floor(1e-12+Math.log(n)/Math.LN10),e=Math.max(-24,Math.min(24,3*Math.floor((e-1)/3)))),sa[8+e/3]};var ha=/(?:([^{])?([<>=^]))?([+\- ])?([$#])?(0)?(\d+)?(,)?(\.-?\d+)?([a-z%])?/i,pa=ao.map({b:function(n){return n.toString(2)},c:function(n){return String.fromCharCode(n)},o:function(n){return n.toString(8)},x:function(n){return n.toString(16)},X:function(n){return n.toString(16).toUpperCase()},g:function(n,t){return n.toPrecision(t)},e:function(n,t){return n.toExponential(t)},f:function(n,t){return n.toFixed(t)},r:function(n,t){return(n=ao.round(n,Pn(n,t))).toFixed(Math.max(0,Math.min(20,Pn(n*(1+1e-15),t))))}}),ga=ao.time={},va=Date;Hn.prototype={getDate:function(){return this._.getUTCDate()},getDay:function(){return this._.getUTCDay()},getFullYear:function(){return this._.getUTCFullYear()},getHours:function(){return this._.getUTCHours()},getMilliseconds:function(){return this._.getUTCMilliseconds()},getMinutes:function(){return this._.getUTCMinutes()},getMonth:function(){return this._.getUTCMonth()},getSeconds:function(){return this._.getUTCSeconds()},getTime:function(){return this._.getTime()},getTimezoneOffset:function(){return 0},valueOf:function(){return this._.valueOf()},setDate:function(){da.setUTCDate.apply(this._,arguments)},setDay:function(){da.setUTCDay.apply(this._,arguments)},setFullYear:function(){da.setUTCFullYear.apply(this._,arguments)},setHours:function(){da.setUTCHours.apply(this._,arguments)},setMilliseconds:function(){da.setUTCMilliseconds.apply(this._,arguments)},setMinutes:function(){da.setUTCMinutes.apply(this._,arguments)},setMonth:function(){da.setUTCMonth.apply(this._,arguments)},setSeconds:function(){da.setUTCSeconds.apply(this._,arguments)},setTime:function(){da.setTime.apply(this._,arguments)}};var da=Date.prototype;ga.year=On(function(n){return n=ga.day(n),n.setMonth(0,1),n},function(n,t){n.setFullYear(n.getFullYear()+t)},function(n){return n.getFullYear()}),ga.years=ga.year.range,ga.years.utc=ga.year.utc.range,ga.day=On(function(n){var t=new va(2e3,0);return t.setFullYear(n.getFullYear(),n.getMonth(),n.getDate()),t},function(n,t){n.setDate(n.getDate()+t)},function(n){return n.getDate()-1}),ga.days=ga.day.range,ga.days.utc=ga.day.utc.range,ga.dayOfYear=function(n){var t=ga.year(n);return Math.floor((n-t-6e4*(n.getTimezoneOffset()-t.getTimezoneOffset()))/864e5)},["sunday","monday","tuesday","wednesday","thursday","friday","saturday"].forEach(function(n,t){t=7-t;var e=ga[n]=On(function(n){return(n=ga.day(n)).setDate(n.getDate()-(n.getDay()+t)%7),n},function(n,t){n.setDate(n.getDate()+7*Math.floor(t))},function(n){var e=ga.year(n).getDay();return Math.floor((ga.dayOfYear(n)+(e+t)%7)/7)-(e!==t)});ga[n+"s"]=e.range,ga[n+"s"].utc=e.utc.range,ga[n+"OfYear"]=function(n){var e=ga.year(n).getDay();return Math.floor((ga.dayOfYear(n)+(e+t)%7)/7)}}),ga.week=ga.sunday,ga.weeks=ga.sunday.range,ga.weeks.utc=ga.sunday.utc.range,ga.weekOfYear=ga.sundayOfYear;var ya={"-":"",_:" ",0:"0"},ma=/^\s*\d+/,Ma=/^%/;ao.locale=function(n){return{numberFormat:jn(n),timeFormat:Yn(n)}};var xa=ao.locale({decimal:".",thousands:",",grouping:[3],currency:["$",""],dateTime:"%a %b %e %X %Y",date:"%m/%d/%Y",time:"%H:%M:%S",periods:["AM","PM"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],
-			shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]});ao.format=xa.numberFormat,ao.geo={},ft.prototype={s:0,t:0,add:function(n){st(n,this.t,ba),st(ba.s,this.s,this),this.s?this.t+=ba.t:this.s=ba.t},reset:function(){this.s=this.t=0},valueOf:function(){return this.s}};var ba=new ft;ao.geo.stream=function(n,t){n&&_a.hasOwnProperty(n.type)?_a[n.type](n,t):ht(n,t)};var _a={Feature:function(n,t){ht(n.geometry,t)},FeatureCollection:function(n,t){for(var e=n.features,r=-1,i=e.length;++r<i;)ht(e[r].geometry,t)}},wa={Sphere:function(n,t){t.sphere()},Point:function(n,t){n=n.coordinates,t.point(n[0],n[1],n[2])},MultiPoint:function(n,t){for(var e=n.coordinates,r=-1,i=e.length;++r<i;)n=e[r],t.point(n[0],n[1],n[2])},LineString:function(n,t){pt(n.coordinates,t,0)},MultiLineString:function(n,t){for(var e=n.coordinates,r=-1,i=e.length;++r<i;)pt(e[r],t,0)},Polygon:function(n,t){gt(n.coordinates,t)},MultiPolygon:function(n,t){for(var e=n.coordinates,r=-1,i=e.length;++r<i;)gt(e[r],t)},GeometryCollection:function(n,t){for(var e=n.geometries,r=-1,i=e.length;++r<i;)ht(e[r],t)}};ao.geo.area=function(n){return Sa=0,ao.geo.stream(n,Na),Sa};var Sa,ka=new ft,Na={sphere:function(){Sa+=4*Fo},point:b,lineStart:b,lineEnd:b,polygonStart:function(){ka.reset(),Na.lineStart=vt},polygonEnd:function(){var n=2*ka;Sa+=0>n?4*Fo+n:n,Na.lineStart=Na.lineEnd=Na.point=b}};ao.geo.bounds=function(){function n(n,t){M.push(x=[f=n,h=n]),s>t&&(s=t),t>p&&(p=t)}function t(t,e){var r=dt([t*Yo,e*Yo]);if(y){var i=mt(y,r),u=[i[1],-i[0],0],o=mt(u,i);bt(o),o=_t(o);var l=t-g,c=l>0?1:-1,v=o[0]*Zo*c,d=xo(l)>180;if(d^(v>c*g&&c*t>v)){var m=o[1]*Zo;m>p&&(p=m)}else if(v=(v+360)%360-180,d^(v>c*g&&c*t>v)){var m=-o[1]*Zo;s>m&&(s=m)}else s>e&&(s=e),e>p&&(p=e);d?g>t?a(f,t)>a(f,h)&&(h=t):a(t,h)>a(f,h)&&(f=t):h>=f?(f>t&&(f=t),t>h&&(h=t)):t>g?a(f,t)>a(f,h)&&(h=t):a(t,h)>a(f,h)&&(f=t)}else n(t,e);y=r,g=t}function e(){b.point=t}function r(){x[0]=f,x[1]=h,b.point=n,y=null}function i(n,e){if(y){var r=n-g;m+=xo(r)>180?r+(r>0?360:-360):r}else v=n,d=e;Na.point(n,e),t(n,e)}function u(){Na.lineStart()}function o(){i(v,d),Na.lineEnd(),xo(m)>Uo&&(f=-(h=180)),x[0]=f,x[1]=h,y=null}function a(n,t){return(t-=n)<0?t+360:t}function l(n,t){return n[0]-t[0]}function c(n,t){return t[0]<=t[1]?t[0]<=n&&n<=t[1]:n<t[0]||t[1]<n}var f,s,h,p,g,v,d,y,m,M,x,b={point:n,lineStart:e,lineEnd:r,polygonStart:function(){b.point=i,b.lineStart=u,b.lineEnd=o,m=0,Na.polygonStart()},polygonEnd:function(){Na.polygonEnd(),b.point=n,b.lineStart=e,b.lineEnd=r,0>ka?(f=-(h=180),s=-(p=90)):m>Uo?p=90:-Uo>m&&(s=-90),x[0]=f,x[1]=h}};return function(n){p=h=-(f=s=1/0),M=[],ao.geo.stream(n,b);var t=M.length;if(t){M.sort(l);for(var e,r=1,i=M[0],u=[i];t>r;++r)e=M[r],c(e[0],i)||c(e[1],i)?(a(i[0],e[1])>a(i[0],i[1])&&(i[1]=e[1]),a(e[0],i[1])>a(i[0],i[1])&&(i[0]=e[0])):u.push(i=e);for(var o,e,g=-(1/0),t=u.length-1,r=0,i=u[t];t>=r;i=e,++r)e=u[r],(o=a(i[1],e[0]))>g&&(g=o,f=e[0],h=i[1])}return M=x=null,f===1/0||s===1/0?[[NaN,NaN],[NaN,NaN]]:[[f,s],[h,p]]}}(),ao.geo.centroid=function(n){Ea=Aa=Ca=za=La=qa=Ta=Ra=Da=Pa=Ua=0,ao.geo.stream(n,ja);var t=Da,e=Pa,r=Ua,i=t*t+e*e+r*r;return jo>i&&(t=qa,e=Ta,r=Ra,Uo>Aa&&(t=Ca,e=za,r=La),i=t*t+e*e+r*r,jo>i)?[NaN,NaN]:[Math.atan2(e,t)*Zo,tn(r/Math.sqrt(i))*Zo]};var Ea,Aa,Ca,za,La,qa,Ta,Ra,Da,Pa,Ua,ja={sphere:b,point:St,lineStart:Nt,lineEnd:Et,polygonStart:function(){ja.lineStart=At},polygonEnd:function(){ja.lineStart=Nt}},Fa=Rt(zt,jt,Ht,[-Fo,-Fo/2]),Ha=1e9;ao.geo.clipExtent=function(){var n,t,e,r,i,u,o={stream:function(n){return i&&(i.valid=!1),i=u(n),i.valid=!0,i},extent:function(a){return arguments.length?(u=Zt(n=+a[0][0],t=+a[0][1],e=+a[1][0],r=+a[1][1]),i&&(i.valid=!1,i=null),o):[[n,t],[e,r]]}};return o.extent([[0,0],[960,500]])},(ao.geo.conicEqualArea=function(){return Vt(Xt)}).raw=Xt,ao.geo.albers=function(){return ao.geo.conicEqualArea().rotate([96,0]).center([-.6,38.7]).parallels([29.5,45.5]).scale(1070)},ao.geo.albersUsa=function(){function n(n){var u=n[0],o=n[1];return t=null,e(u,o),t||(r(u,o),t)||i(u,o),t}var t,e,r,i,u=ao.geo.albers(),o=ao.geo.conicEqualArea().rotate([154,0]).center([-2,58.5]).parallels([55,65]),a=ao.geo.conicEqualArea().rotate([157,0]).center([-3,19.9]).parallels([8,18]),l={point:function(n,e){t=[n,e]}};return n.invert=function(n){var t=u.scale(),e=u.translate(),r=(n[0]-e[0])/t,i=(n[1]-e[1])/t;return(i>=.12&&.234>i&&r>=-.425&&-.214>r?o:i>=.166&&.234>i&&r>=-.214&&-.115>r?a:u).invert(n)},n.stream=function(n){var t=u.stream(n),e=o.stream(n),r=a.stream(n);return{point:function(n,i){t.point(n,i),e.point(n,i),r.point(n,i)},sphere:function(){t.sphere(),e.sphere(),r.sphere()},lineStart:function(){t.lineStart(),e.lineStart(),r.lineStart()},lineEnd:function(){t.lineEnd(),e.lineEnd(),r.lineEnd()},polygonStart:function(){t.polygonStart(),e.polygonStart(),r.polygonStart()},polygonEnd:function(){t.polygonEnd(),e.polygonEnd(),r.polygonEnd()}}},n.precision=function(t){return arguments.length?(u.precision(t),o.precision(t),a.precision(t),n):u.precision()},n.scale=function(t){return arguments.length?(u.scale(t),o.scale(.35*t),a.scale(t),n.translate(u.translate())):u.scale()},n.translate=function(t){if(!arguments.length)return u.translate();var c=u.scale(),f=+t[0],s=+t[1];return e=u.translate(t).clipExtent([[f-.455*c,s-.238*c],[f+.455*c,s+.238*c]]).stream(l).point,r=o.translate([f-.307*c,s+.201*c]).clipExtent([[f-.425*c+Uo,s+.12*c+Uo],[f-.214*c-Uo,s+.234*c-Uo]]).stream(l).point,i=a.translate([f-.205*c,s+.212*c]).clipExtent([[f-.214*c+Uo,s+.166*c+Uo],[f-.115*c-Uo,s+.234*c-Uo]]).stream(l).point,n},n.scale(1070)};var Oa,Ia,Ya,Za,Va,Xa,$a={point:b,lineStart:b,lineEnd:b,polygonStart:function(){Ia=0,$a.lineStart=$t},polygonEnd:function(){$a.lineStart=$a.lineEnd=$a.point=b,Oa+=xo(Ia/2)}},Ba={point:Bt,lineStart:b,lineEnd:b,polygonStart:b,polygonEnd:b},Wa={point:Gt,lineStart:Kt,lineEnd:Qt,polygonStart:function(){Wa.lineStart=ne},polygonEnd:function(){Wa.point=Gt,Wa.lineStart=Kt,Wa.lineEnd=Qt}};ao.geo.path=function(){function n(n){return n&&("function"==typeof a&&u.pointRadius(+a.apply(this,arguments)),o&&o.valid||(o=i(u)),ao.geo.stream(n,o)),u.result()}function t(){return o=null,n}var e,r,i,u,o,a=4.5;return n.area=function(n){return Oa=0,ao.geo.stream(n,i($a)),Oa},n.centroid=function(n){return Ca=za=La=qa=Ta=Ra=Da=Pa=Ua=0,ao.geo.stream(n,i(Wa)),Ua?[Da/Ua,Pa/Ua]:Ra?[qa/Ra,Ta/Ra]:La?[Ca/La,za/La]:[NaN,NaN]},n.bounds=function(n){return Va=Xa=-(Ya=Za=1/0),ao.geo.stream(n,i(Ba)),[[Ya,Za],[Va,Xa]]},n.projection=function(n){return arguments.length?(i=(e=n)?n.stream||re(n):m,t()):e},n.context=function(n){return arguments.length?(u=null==(r=n)?new Wt:new te(n),"function"!=typeof a&&u.pointRadius(a),t()):r},n.pointRadius=function(t){return arguments.length?(a="function"==typeof t?t:(u.pointRadius(+t),+t),n):a},n.projection(ao.geo.albersUsa()).context(null)},ao.geo.transform=function(n){return{stream:function(t){var e=new ie(t);for(var r in n)e[r]=n[r];return e}}},ie.prototype={point:function(n,t){this.stream.point(n,t)},sphere:function(){this.stream.sphere()},lineStart:function(){this.stream.lineStart()},lineEnd:function(){this.stream.lineEnd()},polygonStart:function(){this.stream.polygonStart()},polygonEnd:function(){this.stream.polygonEnd()}},ao.geo.projection=oe,ao.geo.projectionMutator=ae,(ao.geo.equirectangular=function(){return oe(ce)}).raw=ce.invert=ce,ao.geo.rotation=function(n){function t(t){return t=n(t[0]*Yo,t[1]*Yo),t[0]*=Zo,t[1]*=Zo,t}return n=se(n[0]%360*Yo,n[1]*Yo,n.length>2?n[2]*Yo:0),t.invert=function(t){return t=n.invert(t[0]*Yo,t[1]*Yo),t[0]*=Zo,t[1]*=Zo,t},t},fe.invert=ce,ao.geo.circle=function(){function n(){var n="function"==typeof r?r.apply(this,arguments):r,t=se(-n[0]*Yo,-n[1]*Yo,0).invert,i=[];return e(null,null,1,{point:function(n,e){i.push(n=t(n,e)),n[0]*=Zo,n[1]*=Zo}}),{type:"Polygon",coordinates:[i]}}var t,e,r=[0,0],i=6;return n.origin=function(t){return arguments.length?(r=t,n):r},n.angle=function(r){return arguments.length?(e=ve((t=+r)*Yo,i*Yo),n):t},n.precision=function(r){return arguments.length?(e=ve(t*Yo,(i=+r)*Yo),n):i},n.angle(90)},ao.geo.distance=function(n,t){var e,r=(t[0]-n[0])*Yo,i=n[1]*Yo,u=t[1]*Yo,o=Math.sin(r),a=Math.cos(r),l=Math.sin(i),c=Math.cos(i),f=Math.sin(u),s=Math.cos(u);return Math.atan2(Math.sqrt((e=s*o)*e+(e=c*f-l*s*a)*e),l*f+c*s*a)},ao.geo.graticule=function(){function n(){return{type:"MultiLineString",coordinates:t()}}function t(){return ao.range(Math.ceil(u/d)*d,i,d).map(h).concat(ao.range(Math.ceil(c/y)*y,l,y).map(p)).concat(ao.range(Math.ceil(r/g)*g,e,g).filter(function(n){return xo(n%d)>Uo}).map(f)).concat(ao.range(Math.ceil(a/v)*v,o,v).filter(function(n){return xo(n%y)>Uo}).map(s))}var e,r,i,u,o,a,l,c,f,s,h,p,g=10,v=g,d=90,y=360,m=2.5;return n.lines=function(){return t().map(function(n){return{type:"LineString",coordinates:n}})},n.outline=function(){return{type:"Polygon",coordinates:[h(u).concat(p(l).slice(1),h(i).reverse().slice(1),p(c).reverse().slice(1))]}},n.extent=function(t){return arguments.length?n.majorExtent(t).minorExtent(t):n.minorExtent()},n.majorExtent=function(t){return arguments.length?(u=+t[0][0],i=+t[1][0],c=+t[0][1],l=+t[1][1],u>i&&(t=u,u=i,i=t),c>l&&(t=c,c=l,l=t),n.precision(m)):[[u,c],[i,l]]},n.minorExtent=function(t){return arguments.length?(r=+t[0][0],e=+t[1][0],a=+t[0][1],o=+t[1][1],r>e&&(t=r,r=e,e=t),a>o&&(t=a,a=o,o=t),n.precision(m)):[[r,a],[e,o]]},n.step=function(t){return arguments.length?n.majorStep(t).minorStep(t):n.minorStep()},n.majorStep=function(t){return arguments.length?(d=+t[0],y=+t[1],n):[d,y]},n.minorStep=function(t){return arguments.length?(g=+t[0],v=+t[1],n):[g,v]},n.precision=function(t){return arguments.length?(m=+t,f=ye(a,o,90),s=me(r,e,m),h=ye(c,l,90),p=me(u,i,m),n):m},n.majorExtent([[-180,-90+Uo],[180,90-Uo]]).minorExtent([[-180,-80-Uo],[180,80+Uo]])},ao.geo.greatArc=function(){function n(){return{type:"LineString",coordinates:[t||r.apply(this,arguments),e||i.apply(this,arguments)]}}var t,e,r=Me,i=xe;return n.distance=function(){return ao.geo.distance(t||r.apply(this,arguments),e||i.apply(this,arguments))},n.source=function(e){return arguments.length?(r=e,t="function"==typeof e?null:e,n):r},n.target=function(t){return arguments.length?(i=t,e="function"==typeof t?null:t,n):i},n.precision=function(){return arguments.length?n:0},n},ao.geo.interpolate=function(n,t){return be(n[0]*Yo,n[1]*Yo,t[0]*Yo,t[1]*Yo)},ao.geo.length=function(n){return Ja=0,ao.geo.stream(n,Ga),Ja};var Ja,Ga={sphere:b,point:b,lineStart:_e,lineEnd:b,polygonStart:b,polygonEnd:b},Ka=we(function(n){return Math.sqrt(2/(1+n))},function(n){return 2*Math.asin(n/2)});(ao.geo.azimuthalEqualArea=function(){return oe(Ka)}).raw=Ka;var Qa=we(function(n){var t=Math.acos(n);return t&&t/Math.sin(t)},m);(ao.geo.azimuthalEquidistant=function(){return oe(Qa)}).raw=Qa,(ao.geo.conicConformal=function(){return Vt(Se)}).raw=Se,(ao.geo.conicEquidistant=function(){return Vt(ke)}).raw=ke;var nl=we(function(n){return 1/n},Math.atan);(ao.geo.gnomonic=function(){return oe(nl)}).raw=nl,Ne.invert=function(n,t){return[n,2*Math.atan(Math.exp(t))-Io]},(ao.geo.mercator=function(){return Ee(Ne)}).raw=Ne;var tl=we(function(){return 1},Math.asin);(ao.geo.orthographic=function(){return oe(tl)}).raw=tl;var el=we(function(n){return 1/(1+n)},function(n){return 2*Math.atan(n)});(ao.geo.stereographic=function(){return oe(el)}).raw=el,Ae.invert=function(n,t){return[-t,2*Math.atan(Math.exp(n))-Io]},(ao.geo.transverseMercator=function(){var n=Ee(Ae),t=n.center,e=n.rotate;return n.center=function(n){return n?t([-n[1],n[0]]):(n=t(),[n[1],-n[0]])},n.rotate=function(n){return n?e([n[0],n[1],n.length>2?n[2]+90:90]):(n=e(),[n[0],n[1],n[2]-90])},e([0,0,90])}).raw=Ae,ao.geom={},ao.geom.hull=function(n){function t(n){if(n.length<3)return[];var t,i=En(e),u=En(r),o=n.length,a=[],l=[];for(t=0;o>t;t++)a.push([+i.call(this,n[t],t),+u.call(this,n[t],t),t]);for(a.sort(qe),t=0;o>t;t++)l.push([a[t][0],-a[t][1]]);var c=Le(a),f=Le(l),s=f[0]===c[0],h=f[f.length-1]===c[c.length-1],p=[];for(t=c.length-1;t>=0;--t)p.push(n[a[c[t]][2]]);for(t=+s;t<f.length-h;++t)p.push(n[a[f[t]][2]]);return p}var e=Ce,r=ze;return arguments.length?t(n):(t.x=function(n){return arguments.length?(e=n,t):e},t.y=function(n){return arguments.length?(r=n,t):r},t)},ao.geom.polygon=function(n){return ko(n,rl),n};var rl=ao.geom.polygon.prototype=[];rl.area=function(){for(var n,t=-1,e=this.length,r=this[e-1],i=0;++t<e;)n=r,r=this[t],i+=n[1]*r[0]-n[0]*r[1];return.5*i},rl.centroid=function(n){var t,e,r=-1,i=this.length,u=0,o=0,a=this[i-1];for(arguments.length||(n=-1/(6*this.area()));++r<i;)t=a,a=this[r],e=t[0]*a[1]-a[0]*t[1],u+=(t[0]+a[0])*e,o+=(t[1]+a[1])*e;return[u*n,o*n]},rl.clip=function(n){for(var t,e,r,i,u,o,a=De(n),l=-1,c=this.length-De(this),f=this[c-1];++l<c;){for(t=n.slice(),n.length=0,i=this[l],u=t[(r=t.length-a)-1],e=-1;++e<r;)o=t[e],Te(o,f,i)?(Te(u,f,i)||n.push(Re(u,o,f,i)),n.push(o)):Te(u,f,i)&&n.push(Re(u,o,f,i)),u=o;a&&n.push(n[0]),f=i}return n};var il,ul,ol,al,ll,cl=[],fl=[];Ye.prototype.prepare=function(){for(var n,t=this.edges,e=t.length;e--;)n=t[e].edge,n.b&&n.a||t.splice(e,1);return t.sort(Ve),t.length},tr.prototype={start:function(){return this.edge.l===this.site?this.edge.a:this.edge.b},end:function(){return this.edge.l===this.site?this.edge.b:this.edge.a}},er.prototype={insert:function(n,t){var e,r,i;if(n){if(t.P=n,t.N=n.N,n.N&&(n.N.P=t),n.N=t,n.R){for(n=n.R;n.L;)n=n.L;n.L=t}else n.R=t;e=n}else this._?(n=or(this._),t.P=null,t.N=n,n.P=n.L=t,e=n):(t.P=t.N=null,this._=t,e=null);for(t.L=t.R=null,t.U=e,t.C=!0,n=t;e&&e.C;)r=e.U,e===r.L?(i=r.R,i&&i.C?(e.C=i.C=!1,r.C=!0,n=r):(n===e.R&&(ir(this,e),n=e,e=n.U),e.C=!1,r.C=!0,ur(this,r))):(i=r.L,i&&i.C?(e.C=i.C=!1,r.C=!0,n=r):(n===e.L&&(ur(this,e),n=e,e=n.U),e.C=!1,r.C=!0,ir(this,r))),e=n.U;this._.C=!1},remove:function(n){n.N&&(n.N.P=n.P),n.P&&(n.P.N=n.N),n.N=n.P=null;var t,e,r,i=n.U,u=n.L,o=n.R;if(e=u?o?or(o):u:o,i?i.L===n?i.L=e:i.R=e:this._=e,u&&o?(r=e.C,e.C=n.C,e.L=u,u.U=e,e!==o?(i=e.U,e.U=n.U,n=e.R,i.L=n,e.R=o,o.U=e):(e.U=i,i=e,n=e.R)):(r=n.C,n=e),n&&(n.U=i),!r){if(n&&n.C)return void(n.C=!1);do{if(n===this._)break;if(n===i.L){if(t=i.R,t.C&&(t.C=!1,i.C=!0,ir(this,i),t=i.R),t.L&&t.L.C||t.R&&t.R.C){t.R&&t.R.C||(t.L.C=!1,t.C=!0,ur(this,t),t=i.R),t.C=i.C,i.C=t.R.C=!1,ir(this,i),n=this._;break}}else if(t=i.L,t.C&&(t.C=!1,i.C=!0,ur(this,i),t=i.L),t.L&&t.L.C||t.R&&t.R.C){t.L&&t.L.C||(t.R.C=!1,t.C=!0,ir(this,t),t=i.L),t.C=i.C,i.C=t.L.C=!1,ur(this,i),n=this._;break}t.C=!0,n=i,i=i.U}while(!n.C);n&&(n.C=!1)}}},ao.geom.voronoi=function(n){function t(n){var t=new Array(n.length),r=a[0][0],i=a[0][1],u=a[1][0],o=a[1][1];return ar(e(n),a).cells.forEach(function(e,a){var l=e.edges,c=e.site,f=t[a]=l.length?l.map(function(n){var t=n.start();return[t.x,t.y]}):c.x>=r&&c.x<=u&&c.y>=i&&c.y<=o?[[r,o],[u,o],[u,i],[r,i]]:[];f.point=n[a]}),t}function e(n){return n.map(function(n,t){return{x:Math.round(u(n,t)/Uo)*Uo,y:Math.round(o(n,t)/Uo)*Uo,i:t}})}var r=Ce,i=ze,u=r,o=i,a=sl;return n?t(n):(t.links=function(n){return ar(e(n)).edges.filter(function(n){return n.l&&n.r}).map(function(t){return{source:n[t.l.i],target:n[t.r.i]}})},t.triangles=function(n){var t=[];return ar(e(n)).cells.forEach(function(e,r){for(var i,u,o=e.site,a=e.edges.sort(Ve),l=-1,c=a.length,f=a[c-1].edge,s=f.l===o?f.r:f.l;++l<c;)i=f,u=s,f=a[l].edge,s=f.l===o?f.r:f.l,r<u.i&&r<s.i&&cr(o,u,s)<0&&t.push([n[r],n[u.i],n[s.i]])}),t},t.x=function(n){return arguments.length?(u=En(r=n),t):r},t.y=function(n){return arguments.length?(o=En(i=n),t):i},t.clipExtent=function(n){return arguments.length?(a=null==n?sl:n,t):a===sl?null:a},t.size=function(n){return arguments.length?t.clipExtent(n&&[[0,0],n]):a===sl?null:a&&a[1]},t)};var sl=[[-1e6,-1e6],[1e6,1e6]];ao.geom.delaunay=function(n){return ao.geom.voronoi().triangles(n)},ao.geom.quadtree=function(n,t,e,r,i){function u(n){function u(n,t,e,r,i,u,o,a){if(!isNaN(e)&&!isNaN(r))if(n.leaf){var l=n.x,f=n.y;if(null!=l)if(xo(l-e)+xo(f-r)<.01)c(n,t,e,r,i,u,o,a);else{var s=n.point;n.x=n.y=n.point=null,c(n,s,l,f,i,u,o,a),c(n,t,e,r,i,u,o,a)}else n.x=e,n.y=r,n.point=t}else c(n,t,e,r,i,u,o,a)}function c(n,t,e,r,i,o,a,l){var c=.5*(i+a),f=.5*(o+l),s=e>=c,h=r>=f,p=h<<1|s;n.leaf=!1,n=n.nodes[p]||(n.nodes[p]=hr()),s?i=c:a=c,h?o=f:l=f,u(n,t,e,r,i,o,a,l)}var f,s,h,p,g,v,d,y,m,M=En(a),x=En(l);if(null!=t)v=t,d=e,y=r,m=i;else if(y=m=-(v=d=1/0),s=[],h=[],g=n.length,o)for(p=0;g>p;++p)f=n[p],f.x<v&&(v=f.x),f.y<d&&(d=f.y),f.x>y&&(y=f.x),f.y>m&&(m=f.y),s.push(f.x),h.push(f.y);else for(p=0;g>p;++p){var b=+M(f=n[p],p),_=+x(f,p);v>b&&(v=b),d>_&&(d=_),b>y&&(y=b),_>m&&(m=_),s.push(b),h.push(_)}var w=y-v,S=m-d;w>S?m=d+w:y=v+S;var k=hr();if(k.add=function(n){u(k,n,+M(n,++p),+x(n,p),v,d,y,m)},k.visit=function(n){pr(n,k,v,d,y,m)},k.find=function(n){return gr(k,n[0],n[1],v,d,y,m)},p=-1,null==t){for(;++p<g;)u(k,n[p],s[p],h[p],v,d,y,m);--p}else n.forEach(k.add);return s=h=n=f=null,k}var o,a=Ce,l=ze;return(o=arguments.length)?(a=fr,l=sr,3===o&&(i=e,r=t,e=t=0),u(n)):(u.x=function(n){return arguments.length?(a=n,u):a},u.y=function(n){return arguments.length?(l=n,u):l},u.extent=function(n){return arguments.length?(null==n?t=e=r=i=null:(t=+n[0][0],e=+n[0][1],r=+n[1][0],i=+n[1][1]),u):null==t?null:[[t,e],[r,i]]},u.size=function(n){return arguments.length?(null==n?t=e=r=i=null:(t=e=0,r=+n[0],i=+n[1]),u):null==t?null:[r-t,i-e]},u)},ao.interpolateRgb=vr,ao.interpolateObject=dr,ao.interpolateNumber=yr,ao.interpolateString=mr;var hl=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,pl=new RegExp(hl.source,"g");ao.interpolate=Mr,ao.interpolators=[function(n,t){var e=typeof t;return("string"===e?ua.has(t.toLowerCase())||/^(#|rgb\(|hsl\()/i.test(t)?vr:mr:t instanceof an?vr:Array.isArray(t)?xr:"object"===e&&isNaN(t)?dr:yr)(n,t)}],ao.interpolateArray=xr;var gl=function(){return m},vl=ao.map({linear:gl,poly:Er,quad:function(){return Sr},cubic:function(){return kr},sin:function(){return Ar},exp:function(){return Cr},circle:function(){return zr},elastic:Lr,back:qr,bounce:function(){return Tr}}),dl=ao.map({"in":m,out:_r,"in-out":wr,"out-in":function(n){return wr(_r(n))}});ao.ease=function(n){var t=n.indexOf("-"),e=t>=0?n.slice(0,t):n,r=t>=0?n.slice(t+1):"in";return e=vl.get(e)||gl,r=dl.get(r)||m,br(r(e.apply(null,lo.call(arguments,1))))},ao.interpolateHcl=Rr,ao.interpolateHsl=Dr,ao.interpolateLab=Pr,ao.interpolateRound=Ur,ao.transform=function(n){var t=fo.createElementNS(ao.ns.prefix.svg,"g");return(ao.transform=function(n){if(null!=n){t.setAttribute("transform",n);var e=t.transform.baseVal.consolidate()}return new jr(e?e.matrix:yl)})(n)},jr.prototype.toString=function(){return"translate("+this.translate+")rotate("+this.rotate+")skewX("+this.skew+")scale("+this.scale+")"};var yl={a:1,b:0,c:0,d:1,e:0,f:0};ao.interpolateTransform=$r,ao.layout={},ao.layout.bundle=function(){return function(n){for(var t=[],e=-1,r=n.length;++e<r;)t.push(Jr(n[e]));return t}},ao.layout.chord=function(){function n(){var n,c,s,h,p,g={},v=[],d=ao.range(u),y=[];for(e=[],r=[],n=0,h=-1;++h<u;){for(c=0,p=-1;++p<u;)c+=i[h][p];v.push(c),y.push(ao.range(u)),n+=c}for(o&&d.sort(function(n,t){return o(v[n],v[t])}),a&&y.forEach(function(n,t){n.sort(function(n,e){return a(i[t][n],i[t][e])})}),n=(Ho-f*u)/n,c=0,h=-1;++h<u;){for(s=c,p=-1;++p<u;){var m=d[h],M=y[m][p],x=i[m][M],b=c,_=c+=x*n;g[m+"-"+M]={index:m,subindex:M,startAngle:b,endAngle:_,value:x}}r[m]={index:m,startAngle:s,endAngle:c,value:v[m]},c+=f}for(h=-1;++h<u;)for(p=h-1;++p<u;){var w=g[h+"-"+p],S=g[p+"-"+h];(w.value||S.value)&&e.push(w.value<S.value?{source:S,target:w}:{source:w,target:S})}l&&t()}function t(){e.sort(function(n,t){return l((n.source.value+n.target.value)/2,(t.source.value+t.target.value)/2)})}var e,r,i,u,o,a,l,c={},f=0;return c.matrix=function(n){return arguments.length?(u=(i=n)&&i.length,e=r=null,c):i},c.padding=function(n){return arguments.length?(f=n,e=r=null,c):f},c.sortGroups=function(n){return arguments.length?(o=n,e=r=null,c):o},c.sortSubgroups=function(n){return arguments.length?(a=n,e=null,c):a},c.sortChords=function(n){return arguments.length?(l=n,e&&t(),c):l},c.chords=function(){return e||n(),e},c.groups=function(){return r||n(),r},c},ao.layout.force=function(){function n(n){return function(t,e,r,i){if(t.point!==n){var u=t.cx-n.x,o=t.cy-n.y,a=i-e,l=u*u+o*o;if(l>a*a/y){if(v>l){var c=t.charge/l;n.px-=u*c,n.py-=o*c}return!0}if(t.point&&l&&v>l){var c=t.pointCharge/l;n.px-=u*c,n.py-=o*c}}return!t.charge}}function t(n){n.px=ao.event.x,n.py=ao.event.y,l.resume()}var e,r,i,u,o,a,l={},c=ao.dispatch("start","tick","end"),f=[1,1],s=.9,h=ml,p=Ml,g=-30,v=xl,d=.1,y=.64,M=[],x=[];return l.tick=function(){if((i*=.99)<.005)return e=null,c.end({type:"end",alpha:i=0}),!0;var t,r,l,h,p,v,y,m,b,_=M.length,w=x.length;for(r=0;w>r;++r)l=x[r],h=l.source,p=l.target,m=p.x-h.x,b=p.y-h.y,(v=m*m+b*b)&&(v=i*o[r]*((v=Math.sqrt(v))-u[r])/v,m*=v,b*=v,p.x-=m*(y=h.weight+p.weight?h.weight/(h.weight+p.weight):.5),p.y-=b*y,h.x+=m*(y=1-y),h.y+=b*y);if((y=i*d)&&(m=f[0]/2,b=f[1]/2,r=-1,y))for(;++r<_;)l=M[r],l.x+=(m-l.x)*y,l.y+=(b-l.y)*y;if(g)for(ri(t=ao.geom.quadtree(M),i,a),r=-1;++r<_;)(l=M[r]).fixed||t.visit(n(l));for(r=-1;++r<_;)l=M[r],l.fixed?(l.x=l.px,l.y=l.py):(l.x-=(l.px-(l.px=l.x))*s,l.y-=(l.py-(l.py=l.y))*s);c.tick({type:"tick",alpha:i})},l.nodes=function(n){return arguments.length?(M=n,l):M},l.links=function(n){return arguments.length?(x=n,l):x},l.size=function(n){return arguments.length?(f=n,l):f},l.linkDistance=function(n){return arguments.length?(h="function"==typeof n?n:+n,l):h},l.distance=l.linkDistance,l.linkStrength=function(n){return arguments.length?(p="function"==typeof n?n:+n,l):p},l.friction=function(n){return arguments.length?(s=+n,l):s},l.charge=function(n){return arguments.length?(g="function"==typeof n?n:+n,l):g},l.chargeDistance=function(n){return arguments.length?(v=n*n,l):Math.sqrt(v)},l.gravity=function(n){return arguments.length?(d=+n,l):d},l.theta=function(n){return arguments.length?(y=n*n,l):Math.sqrt(y)},l.alpha=function(n){return arguments.length?(n=+n,i?n>0?i=n:(e.c=null,e.t=NaN,e=null,c.end({type:"end",alpha:i=0})):n>0&&(c.start({type:"start",alpha:i=n}),e=qn(l.tick)),l):i},l.start=function(){function n(n,r){if(!e){for(e=new Array(i),l=0;i>l;++l)e[l]=[];for(l=0;c>l;++l){var u=x[l];e[u.source.index].push(u.target),e[u.target.index].push(u.source)}}for(var o,a=e[t],l=-1,f=a.length;++l<f;)if(!isNaN(o=a[l][n]))return o;return Math.random()*r}var t,e,r,i=M.length,c=x.length,s=f[0],v=f[1];for(t=0;i>t;++t)(r=M[t]).index=t,r.weight=0;for(t=0;c>t;++t)r=x[t],"number"==typeof r.source&&(r.source=M[r.source]),"number"==typeof r.target&&(r.target=M[r.target]),++r.source.weight,++r.target.weight;for(t=0;i>t;++t)r=M[t],isNaN(r.x)&&(r.x=n("x",s)),isNaN(r.y)&&(r.y=n("y",v)),isNaN(r.px)&&(r.px=r.x),isNaN(r.py)&&(r.py=r.y);if(u=[],"function"==typeof h)for(t=0;c>t;++t)u[t]=+h.call(this,x[t],t);else for(t=0;c>t;++t)u[t]=h;if(o=[],"function"==typeof p)for(t=0;c>t;++t)o[t]=+p.call(this,x[t],t);else for(t=0;c>t;++t)o[t]=p;if(a=[],"function"==typeof g)for(t=0;i>t;++t)a[t]=+g.call(this,M[t],t);else for(t=0;i>t;++t)a[t]=g;return l.resume()},l.resume=function(){return l.alpha(.1)},l.stop=function(){return l.alpha(0)},l.drag=function(){return r||(r=ao.behavior.drag().origin(m).on("dragstart.force",Qr).on("drag.force",t).on("dragend.force",ni)),arguments.length?void this.on("mouseover.force",ti).on("mouseout.force",ei).call(r):r},ao.rebind(l,c,"on")};var ml=20,Ml=1,xl=1/0;ao.layout.hierarchy=function(){function n(i){var u,o=[i],a=[];for(i.depth=0;null!=(u=o.pop());)if(a.push(u),(c=e.call(n,u,u.depth))&&(l=c.length)){for(var l,c,f;--l>=0;)o.push(f=c[l]),f.parent=u,f.depth=u.depth+1;r&&(u.value=0),u.children=c}else r&&(u.value=+r.call(n,u,u.depth)||0),delete u.children;return oi(i,function(n){var e,i;t&&(e=n.children)&&e.sort(t),r&&(i=n.parent)&&(i.value+=n.value)}),a}var t=ci,e=ai,r=li;return n.sort=function(e){return arguments.length?(t=e,n):t},n.children=function(t){return arguments.length?(e=t,n):e},n.value=function(t){return arguments.length?(r=t,n):r},n.revalue=function(t){return r&&(ui(t,function(n){n.children&&(n.value=0)}),oi(t,function(t){var e;t.children||(t.value=+r.call(n,t,t.depth)||0),(e=t.parent)&&(e.value+=t.value)})),t},n},ao.layout.partition=function(){function n(t,e,r,i){var u=t.children;if(t.x=e,t.y=t.depth*i,t.dx=r,t.dy=i,u&&(o=u.length)){var o,a,l,c=-1;for(r=t.value?r/t.value:0;++c<o;)n(a=u[c],e,l=a.value*r,i),e+=l}}function t(n){var e=n.children,r=0;if(e&&(i=e.length))for(var i,u=-1;++u<i;)r=Math.max(r,t(e[u]));return 1+r}function e(e,u){var o=r.call(this,e,u);return n(o[0],0,i[0],i[1]/t(o[0])),o}var r=ao.layout.hierarchy(),i=[1,1];return e.size=function(n){return arguments.length?(i=n,e):i},ii(e,r)},ao.layout.pie=function(){function n(o){var a,l=o.length,c=o.map(function(e,r){return+t.call(n,e,r)}),f=+("function"==typeof r?r.apply(this,arguments):r),s=("function"==typeof i?i.apply(this,arguments):i)-f,h=Math.min(Math.abs(s)/l,+("function"==typeof u?u.apply(this,arguments):u)),p=h*(0>s?-1:1),g=ao.sum(c),v=g?(s-l*p)/g:0,d=ao.range(l),y=[];return null!=e&&d.sort(e===bl?function(n,t){return c[t]-c[n]}:function(n,t){return e(o[n],o[t])}),d.forEach(function(n){y[n]={data:o[n],value:a=c[n],startAngle:f,endAngle:f+=a*v+p,padAngle:h}}),y}var t=Number,e=bl,r=0,i=Ho,u=0;return n.value=function(e){return arguments.length?(t=e,n):t},n.sort=function(t){return arguments.length?(e=t,n):e},n.startAngle=function(t){return arguments.length?(r=t,n):r},n.endAngle=function(t){return arguments.length?(i=t,n):i},n.padAngle=function(t){return arguments.length?(u=t,n):u},n};var bl={};ao.layout.stack=function(){function n(a,l){if(!(h=a.length))return a;var c=a.map(function(e,r){return t.call(n,e,r)}),f=c.map(function(t){return t.map(function(t,e){return[u.call(n,t,e),o.call(n,t,e)]})}),s=e.call(n,f,l);c=ao.permute(c,s),f=ao.permute(f,s);var h,p,g,v,d=r.call(n,f,l),y=c[0].length;for(g=0;y>g;++g)for(i.call(n,c[0][g],v=d[g],f[0][g][1]),p=1;h>p;++p)i.call(n,c[p][g],v+=f[p-1][g][1],f[p][g][1]);return a}var t=m,e=gi,r=vi,i=pi,u=si,o=hi;return n.values=function(e){return arguments.length?(t=e,n):t},n.order=function(t){return arguments.length?(e="function"==typeof t?t:_l.get(t)||gi,n):e},n.offset=function(t){return arguments.length?(r="function"==typeof t?t:wl.get(t)||vi,n):r},n.x=function(t){return arguments.length?(u=t,n):u},n.y=function(t){return arguments.length?(o=t,n):o},n.out=function(t){return arguments.length?(i=t,n):i},n};var _l=ao.map({"inside-out":function(n){var t,e,r=n.length,i=n.map(di),u=n.map(yi),o=ao.range(r).sort(function(n,t){return i[n]-i[t]}),a=0,l=0,c=[],f=[];for(t=0;r>t;++t)e=o[t],l>a?(a+=u[e],c.push(e)):(l+=u[e],f.push(e));return f.reverse().concat(c)},reverse:function(n){return ao.range(n.length).reverse()},"default":gi}),wl=ao.map({silhouette:function(n){var t,e,r,i=n.length,u=n[0].length,o=[],a=0,l=[];for(e=0;u>e;++e){for(t=0,r=0;i>t;t++)r+=n[t][e][1];r>a&&(a=r),o.push(r)}for(e=0;u>e;++e)l[e]=(a-o[e])/2;return l},wiggle:function(n){var t,e,r,i,u,o,a,l,c,f=n.length,s=n[0],h=s.length,p=[];for(p[0]=l=c=0,e=1;h>e;++e){for(t=0,i=0;f>t;++t)i+=n[t][e][1];for(t=0,u=0,a=s[e][0]-s[e-1][0];f>t;++t){for(r=0,o=(n[t][e][1]-n[t][e-1][1])/(2*a);t>r;++r)o+=(n[r][e][1]-n[r][e-1][1])/a;u+=o*n[t][e][1]}p[e]=l-=i?u/i*a:0,c>l&&(c=l)}for(e=0;h>e;++e)p[e]-=c;return p},expand:function(n){var t,e,r,i=n.length,u=n[0].length,o=1/i,a=[];for(e=0;u>e;++e){for(t=0,r=0;i>t;t++)r+=n[t][e][1];if(r)for(t=0;i>t;t++)n[t][e][1]/=r;else for(t=0;i>t;t++)n[t][e][1]=o}for(e=0;u>e;++e)a[e]=0;return a},zero:vi});ao.layout.histogram=function(){function n(n,u){for(var o,a,l=[],c=n.map(e,this),f=r.call(this,c,u),s=i.call(this,f,c,u),u=-1,h=c.length,p=s.length-1,g=t?1:1/h;++u<p;)o=l[u]=[],o.dx=s[u+1]-(o.x=s[u]),o.y=0;if(p>0)for(u=-1;++u<h;)a=c[u],a>=f[0]&&a<=f[1]&&(o=l[ao.bisect(s,a,1,p)-1],o.y+=g,o.push(n[u]));return l}var t=!0,e=Number,r=bi,i=Mi;return n.value=function(t){return arguments.length?(e=t,n):e},n.range=function(t){return arguments.length?(r=En(t),n):r},n.bins=function(t){return arguments.length?(i="number"==typeof t?function(n){return xi(n,t)}:En(t),n):i},n.frequency=function(e){return arguments.length?(t=!!e,n):t},n},ao.layout.pack=function(){function n(n,u){var o=e.call(this,n,u),a=o[0],l=i[0],c=i[1],f=null==t?Math.sqrt:"function"==typeof t?t:function(){return t};if(a.x=a.y=0,oi(a,function(n){n.r=+f(n.value)}),oi(a,Ni),r){var s=r*(t?1:Math.max(2*a.r/l,2*a.r/c))/2;oi(a,function(n){n.r+=s}),oi(a,Ni),oi(a,function(n){n.r-=s})}return Ci(a,l/2,c/2,t?1:1/Math.max(2*a.r/l,2*a.r/c)),o}var t,e=ao.layout.hierarchy().sort(_i),r=0,i=[1,1];return n.size=function(t){return arguments.length?(i=t,n):i},n.radius=function(e){return arguments.length?(t=null==e||"function"==typeof e?e:+e,n):t},n.padding=function(t){return arguments.length?(r=+t,n):r},ii(n,e)},ao.layout.tree=function(){function n(n,i){var f=o.call(this,n,i),s=f[0],h=t(s);if(oi(h,e),h.parent.m=-h.z,ui(h,r),c)ui(s,u);else{var p=s,g=s,v=s;ui(s,function(n){n.x<p.x&&(p=n),n.x>g.x&&(g=n),n.depth>v.depth&&(v=n)});var d=a(p,g)/2-p.x,y=l[0]/(g.x+a(g,p)/2+d),m=l[1]/(v.depth||1);ui(s,function(n){n.x=(n.x+d)*y,n.y=n.depth*m})}return f}function t(n){for(var t,e={A:null,children:[n]},r=[e];null!=(t=r.pop());)for(var i,u=t.children,o=0,a=u.length;a>o;++o)r.push((u[o]=i={_:u[o],parent:t,children:(i=u[o].children)&&i.slice()||[],A:null,a:null,z:0,m:0,c:0,s:0,t:null,i:o}).a=i);return e.children[0]}function e(n){var t=n.children,e=n.parent.children,r=n.i?e[n.i-1]:null;if(t.length){Di(n);var u=(t[0].z+t[t.length-1].z)/2;r?(n.z=r.z+a(n._,r._),n.m=n.z-u):n.z=u}else r&&(n.z=r.z+a(n._,r._));n.parent.A=i(n,r,n.parent.A||e[0])}function r(n){n._.x=n.z+n.parent.m,n.m+=n.parent.m}function i(n,t,e){if(t){for(var r,i=n,u=n,o=t,l=i.parent.children[0],c=i.m,f=u.m,s=o.m,h=l.m;o=Ti(o),i=qi(i),o&&i;)l=qi(l),u=Ti(u),u.a=n,r=o.z+s-i.z-c+a(o._,i._),r>0&&(Ri(Pi(o,n,e),n,r),c+=r,f+=r),s+=o.m,c+=i.m,h+=l.m,f+=u.m;o&&!Ti(u)&&(u.t=o,u.m+=s-f),i&&!qi(l)&&(l.t=i,l.m+=c-h,e=n)}return e}function u(n){n.x*=l[0],n.y=n.depth*l[1]}var o=ao.layout.hierarchy().sort(null).value(null),a=Li,l=[1,1],c=null;return n.separation=function(t){return arguments.length?(a=t,n):a},n.size=function(t){return arguments.length?(c=null==(l=t)?u:null,n):c?null:l},n.nodeSize=function(t){return arguments.length?(c=null==(l=t)?null:u,n):c?l:null},ii(n,o)},ao.layout.cluster=function(){function n(n,u){var o,a=t.call(this,n,u),l=a[0],c=0;oi(l,function(n){var t=n.children;t&&t.length?(n.x=ji(t),n.y=Ui(t)):(n.x=o?c+=e(n,o):0,n.y=0,o=n)});var f=Fi(l),s=Hi(l),h=f.x-e(f,s)/2,p=s.x+e(s,f)/2;return oi(l,i?function(n){n.x=(n.x-l.x)*r[0],n.y=(l.y-n.y)*r[1]}:function(n){n.x=(n.x-h)/(p-h)*r[0],n.y=(1-(l.y?n.y/l.y:1))*r[1]}),a}var t=ao.layout.hierarchy().sort(null).value(null),e=Li,r=[1,1],i=!1;return n.separation=function(t){return arguments.length?(e=t,n):e},n.size=function(t){return arguments.length?(i=null==(r=t),n):i?null:r},n.nodeSize=function(t){return arguments.length?(i=null!=(r=t),n):i?r:null},ii(n,t)},ao.layout.treemap=function(){function n(n,t){for(var e,r,i=-1,u=n.length;++i<u;)r=(e=n[i]).value*(0>t?0:t),e.area=isNaN(r)||0>=r?0:r}function t(e){var u=e.children;if(u&&u.length){var o,a,l,c=s(e),f=[],h=u.slice(),g=1/0,v="slice"===p?c.dx:"dice"===p?c.dy:"slice-dice"===p?1&e.depth?c.dy:c.dx:Math.min(c.dx,c.dy);for(n(h,c.dx*c.dy/e.value),f.area=0;(l=h.length)>0;)f.push(o=h[l-1]),f.area+=o.area,"squarify"!==p||(a=r(f,v))<=g?(h.pop(),g=a):(f.area-=f.pop().area,i(f,v,c,!1),v=Math.min(c.dx,c.dy),f.length=f.area=0,g=1/0);f.length&&(i(f,v,c,!0),f.length=f.area=0),u.forEach(t)}}function e(t){var r=t.children;if(r&&r.length){var u,o=s(t),a=r.slice(),l=[];for(n(a,o.dx*o.dy/t.value),l.area=0;u=a.pop();)l.push(u),l.area+=u.area,null!=u.z&&(i(l,u.z?o.dx:o.dy,o,!a.length),l.length=l.area=0);r.forEach(e)}}function r(n,t){for(var e,r=n.area,i=0,u=1/0,o=-1,a=n.length;++o<a;)(e=n[o].area)&&(u>e&&(u=e),e>i&&(i=e));return r*=r,t*=t,r?Math.max(t*i*g/r,r/(t*u*g)):1/0}function i(n,t,e,r){var i,u=-1,o=n.length,a=e.x,c=e.y,f=t?l(n.area/t):0;
-			if(t==e.dx){for((r||f>e.dy)&&(f=e.dy);++u<o;)i=n[u],i.x=a,i.y=c,i.dy=f,a+=i.dx=Math.min(e.x+e.dx-a,f?l(i.area/f):0);i.z=!0,i.dx+=e.x+e.dx-a,e.y+=f,e.dy-=f}else{for((r||f>e.dx)&&(f=e.dx);++u<o;)i=n[u],i.x=a,i.y=c,i.dx=f,c+=i.dy=Math.min(e.y+e.dy-c,f?l(i.area/f):0);i.z=!1,i.dy+=e.y+e.dy-c,e.x+=f,e.dx-=f}}function u(r){var i=o||a(r),u=i[0];return u.x=u.y=0,u.value?(u.dx=c[0],u.dy=c[1]):u.dx=u.dy=0,o&&a.revalue(u),n([u],u.dx*u.dy/u.value),(o?e:t)(u),h&&(o=i),i}var o,a=ao.layout.hierarchy(),l=Math.round,c=[1,1],f=null,s=Oi,h=!1,p="squarify",g=.5*(1+Math.sqrt(5));return u.size=function(n){return arguments.length?(c=n,u):c},u.padding=function(n){function t(t){var e=n.call(u,t,t.depth);return null==e?Oi(t):Ii(t,"number"==typeof e?[e,e,e,e]:e)}function e(t){return Ii(t,n)}if(!arguments.length)return f;var r;return s=null==(f=n)?Oi:"function"==(r=typeof n)?t:"number"===r?(n=[n,n,n,n],e):e,u},u.round=function(n){return arguments.length?(l=n?Math.round:Number,u):l!=Number},u.sticky=function(n){return arguments.length?(h=n,o=null,u):h},u.ratio=function(n){return arguments.length?(g=n,u):g},u.mode=function(n){return arguments.length?(p=n+"",u):p},ii(u,a)},ao.random={normal:function(n,t){var e=arguments.length;return 2>e&&(t=1),1>e&&(n=0),function(){var e,r,i;do e=2*Math.random()-1,r=2*Math.random()-1,i=e*e+r*r;while(!i||i>1);return n+t*e*Math.sqrt(-2*Math.log(i)/i)}},logNormal:function(){var n=ao.random.normal.apply(ao,arguments);return function(){return Math.exp(n())}},bates:function(n){var t=ao.random.irwinHall(n);return function(){return t()/n}},irwinHall:function(n){return function(){for(var t=0,e=0;n>e;e++)t+=Math.random();return t}}},ao.scale={};var Sl={floor:m,ceil:m};ao.scale.linear=function(){return Wi([0,1],[0,1],Mr,!1)};var kl={s:1,g:1,p:1,r:1,e:1};ao.scale.log=function(){return ru(ao.scale.linear().domain([0,1]),10,!0,[1,10])};var Nl=ao.format(".0e"),El={floor:function(n){return-Math.ceil(-n)},ceil:function(n){return-Math.floor(-n)}};ao.scale.pow=function(){return iu(ao.scale.linear(),1,[0,1])},ao.scale.sqrt=function(){return ao.scale.pow().exponent(.5)},ao.scale.ordinal=function(){return ou([],{t:"range",a:[[]]})},ao.scale.category10=function(){return ao.scale.ordinal().range(Al)},ao.scale.category20=function(){return ao.scale.ordinal().range(Cl)},ao.scale.category20b=function(){return ao.scale.ordinal().range(zl)},ao.scale.category20c=function(){return ao.scale.ordinal().range(Ll)};var Al=[2062260,16744206,2924588,14034728,9725885,9197131,14907330,8355711,12369186,1556175].map(xn),Cl=[2062260,11454440,16744206,16759672,2924588,10018698,14034728,16750742,9725885,12955861,9197131,12885140,14907330,16234194,8355711,13092807,12369186,14408589,1556175,10410725].map(xn),zl=[3750777,5395619,7040719,10264286,6519097,9216594,11915115,13556636,9202993,12426809,15186514,15190932,8666169,11356490,14049643,15177372,8077683,10834324,13528509,14589654].map(xn),Ll=[3244733,7057110,10406625,13032431,15095053,16616764,16625259,16634018,3253076,7652470,10607003,13101504,7695281,10394312,12369372,14342891,6513507,9868950,12434877,14277081].map(xn);ao.scale.quantile=function(){return au([],[])},ao.scale.quantize=function(){return lu(0,1,[0,1])},ao.scale.threshold=function(){return cu([.5],[0,1])},ao.scale.identity=function(){return fu([0,1])},ao.svg={},ao.svg.arc=function(){function n(){var n=Math.max(0,+e.apply(this,arguments)),c=Math.max(0,+r.apply(this,arguments)),f=o.apply(this,arguments)-Io,s=a.apply(this,arguments)-Io,h=Math.abs(s-f),p=f>s?0:1;if(n>c&&(g=c,c=n,n=g),h>=Oo)return t(c,p)+(n?t(n,1-p):"")+"Z";var g,v,d,y,m,M,x,b,_,w,S,k,N=0,E=0,A=[];if((y=(+l.apply(this,arguments)||0)/2)&&(d=u===ql?Math.sqrt(n*n+c*c):+u.apply(this,arguments),p||(E*=-1),c&&(E=tn(d/c*Math.sin(y))),n&&(N=tn(d/n*Math.sin(y)))),c){m=c*Math.cos(f+E),M=c*Math.sin(f+E),x=c*Math.cos(s-E),b=c*Math.sin(s-E);var C=Math.abs(s-f-2*E)<=Fo?0:1;if(E&&yu(m,M,x,b)===p^C){var z=(f+s)/2;m=c*Math.cos(z),M=c*Math.sin(z),x=b=null}}else m=M=0;if(n){_=n*Math.cos(s-N),w=n*Math.sin(s-N),S=n*Math.cos(f+N),k=n*Math.sin(f+N);var L=Math.abs(f-s+2*N)<=Fo?0:1;if(N&&yu(_,w,S,k)===1-p^L){var q=(f+s)/2;_=n*Math.cos(q),w=n*Math.sin(q),S=k=null}}else _=w=0;if(h>Uo&&(g=Math.min(Math.abs(c-n)/2,+i.apply(this,arguments)))>.001){v=c>n^p?0:1;var T=g,R=g;if(Fo>h){var D=null==S?[_,w]:null==x?[m,M]:Re([m,M],[S,k],[x,b],[_,w]),P=m-D[0],U=M-D[1],j=x-D[0],F=b-D[1],H=1/Math.sin(Math.acos((P*j+U*F)/(Math.sqrt(P*P+U*U)*Math.sqrt(j*j+F*F)))/2),O=Math.sqrt(D[0]*D[0]+D[1]*D[1]);R=Math.min(g,(n-O)/(H-1)),T=Math.min(g,(c-O)/(H+1))}if(null!=x){var I=mu(null==S?[_,w]:[S,k],[m,M],c,T,p),Y=mu([x,b],[_,w],c,T,p);g===T?A.push("M",I[0],"A",T,",",T," 0 0,",v," ",I[1],"A",c,",",c," 0 ",1-p^yu(I[1][0],I[1][1],Y[1][0],Y[1][1]),",",p," ",Y[1],"A",T,",",T," 0 0,",v," ",Y[0]):A.push("M",I[0],"A",T,",",T," 0 1,",v," ",Y[0])}else A.push("M",m,",",M);if(null!=S){var Z=mu([m,M],[S,k],n,-R,p),V=mu([_,w],null==x?[m,M]:[x,b],n,-R,p);g===R?A.push("L",V[0],"A",R,",",R," 0 0,",v," ",V[1],"A",n,",",n," 0 ",p^yu(V[1][0],V[1][1],Z[1][0],Z[1][1]),",",1-p," ",Z[1],"A",R,",",R," 0 0,",v," ",Z[0]):A.push("L",V[0],"A",R,",",R," 0 0,",v," ",Z[0])}else A.push("L",_,",",w)}else A.push("M",m,",",M),null!=x&&A.push("A",c,",",c," 0 ",C,",",p," ",x,",",b),A.push("L",_,",",w),null!=S&&A.push("A",n,",",n," 0 ",L,",",1-p," ",S,",",k);return A.push("Z"),A.join("")}function t(n,t){return"M0,"+n+"A"+n+","+n+" 0 1,"+t+" 0,"+-n+"A"+n+","+n+" 0 1,"+t+" 0,"+n}var e=hu,r=pu,i=su,u=ql,o=gu,a=vu,l=du;return n.innerRadius=function(t){return arguments.length?(e=En(t),n):e},n.outerRadius=function(t){return arguments.length?(r=En(t),n):r},n.cornerRadius=function(t){return arguments.length?(i=En(t),n):i},n.padRadius=function(t){return arguments.length?(u=t==ql?ql:En(t),n):u},n.startAngle=function(t){return arguments.length?(o=En(t),n):o},n.endAngle=function(t){return arguments.length?(a=En(t),n):a},n.padAngle=function(t){return arguments.length?(l=En(t),n):l},n.centroid=function(){var n=(+e.apply(this,arguments)+ +r.apply(this,arguments))/2,t=(+o.apply(this,arguments)+ +a.apply(this,arguments))/2-Io;return[Math.cos(t)*n,Math.sin(t)*n]},n};var ql="auto";ao.svg.line=function(){return Mu(m)};var Tl=ao.map({linear:xu,"linear-closed":bu,step:_u,"step-before":wu,"step-after":Su,basis:zu,"basis-open":Lu,"basis-closed":qu,bundle:Tu,cardinal:Eu,"cardinal-open":ku,"cardinal-closed":Nu,monotone:Fu});Tl.forEach(function(n,t){t.key=n,t.closed=/-closed$/.test(n)});var Rl=[0,2/3,1/3,0],Dl=[0,1/3,2/3,0],Pl=[0,1/6,2/3,1/6];ao.svg.line.radial=function(){var n=Mu(Hu);return n.radius=n.x,delete n.x,n.angle=n.y,delete n.y,n},wu.reverse=Su,Su.reverse=wu,ao.svg.area=function(){return Ou(m)},ao.svg.area.radial=function(){var n=Ou(Hu);return n.radius=n.x,delete n.x,n.innerRadius=n.x0,delete n.x0,n.outerRadius=n.x1,delete n.x1,n.angle=n.y,delete n.y,n.startAngle=n.y0,delete n.y0,n.endAngle=n.y1,delete n.y1,n},ao.svg.chord=function(){function n(n,a){var l=t(this,u,n,a),c=t(this,o,n,a);return"M"+l.p0+r(l.r,l.p1,l.a1-l.a0)+(e(l,c)?i(l.r,l.p1,l.r,l.p0):i(l.r,l.p1,c.r,c.p0)+r(c.r,c.p1,c.a1-c.a0)+i(c.r,c.p1,l.r,l.p0))+"Z"}function t(n,t,e,r){var i=t.call(n,e,r),u=a.call(n,i,r),o=l.call(n,i,r)-Io,f=c.call(n,i,r)-Io;return{r:u,a0:o,a1:f,p0:[u*Math.cos(o),u*Math.sin(o)],p1:[u*Math.cos(f),u*Math.sin(f)]}}function e(n,t){return n.a0==t.a0&&n.a1==t.a1}function r(n,t,e){return"A"+n+","+n+" 0 "+ +(e>Fo)+",1 "+t}function i(n,t,e,r){return"Q 0,0 "+r}var u=Me,o=xe,a=Iu,l=gu,c=vu;return n.radius=function(t){return arguments.length?(a=En(t),n):a},n.source=function(t){return arguments.length?(u=En(t),n):u},n.target=function(t){return arguments.length?(o=En(t),n):o},n.startAngle=function(t){return arguments.length?(l=En(t),n):l},n.endAngle=function(t){return arguments.length?(c=En(t),n):c},n},ao.svg.diagonal=function(){function n(n,i){var u=t.call(this,n,i),o=e.call(this,n,i),a=(u.y+o.y)/2,l=[u,{x:u.x,y:a},{x:o.x,y:a},o];return l=l.map(r),"M"+l[0]+"C"+l[1]+" "+l[2]+" "+l[3]}var t=Me,e=xe,r=Yu;return n.source=function(e){return arguments.length?(t=En(e),n):t},n.target=function(t){return arguments.length?(e=En(t),n):e},n.projection=function(t){return arguments.length?(r=t,n):r},n},ao.svg.diagonal.radial=function(){var n=ao.svg.diagonal(),t=Yu,e=n.projection;return n.projection=function(n){return arguments.length?e(Zu(t=n)):t},n},ao.svg.symbol=function(){function n(n,r){return(Ul.get(t.call(this,n,r))||$u)(e.call(this,n,r))}var t=Xu,e=Vu;return n.type=function(e){return arguments.length?(t=En(e),n):t},n.size=function(t){return arguments.length?(e=En(t),n):e},n};var Ul=ao.map({circle:$u,cross:function(n){var t=Math.sqrt(n/5)/2;return"M"+-3*t+","+-t+"H"+-t+"V"+-3*t+"H"+t+"V"+-t+"H"+3*t+"V"+t+"H"+t+"V"+3*t+"H"+-t+"V"+t+"H"+-3*t+"Z"},diamond:function(n){var t=Math.sqrt(n/(2*Fl)),e=t*Fl;return"M0,"+-t+"L"+e+",0 0,"+t+" "+-e+",0Z"},square:function(n){var t=Math.sqrt(n)/2;return"M"+-t+","+-t+"L"+t+","+-t+" "+t+","+t+" "+-t+","+t+"Z"},"triangle-down":function(n){var t=Math.sqrt(n/jl),e=t*jl/2;return"M0,"+e+"L"+t+","+-e+" "+-t+","+-e+"Z"},"triangle-up":function(n){var t=Math.sqrt(n/jl),e=t*jl/2;return"M0,"+-e+"L"+t+","+e+" "+-t+","+e+"Z"}});ao.svg.symbolTypes=Ul.keys();var jl=Math.sqrt(3),Fl=Math.tan(30*Yo);Co.transition=function(n){for(var t,e,r=Hl||++Zl,i=Ku(n),u=[],o=Ol||{time:Date.now(),ease:Nr,delay:0,duration:250},a=-1,l=this.length;++a<l;){u.push(t=[]);for(var c=this[a],f=-1,s=c.length;++f<s;)(e=c[f])&&Qu(e,f,i,r,o),t.push(e)}return Wu(u,i,r)},Co.interrupt=function(n){return this.each(null==n?Il:Bu(Ku(n)))};var Hl,Ol,Il=Bu(Ku()),Yl=[],Zl=0;Yl.call=Co.call,Yl.empty=Co.empty,Yl.node=Co.node,Yl.size=Co.size,ao.transition=function(n,t){return n&&n.transition?Hl?n.transition(t):n:ao.selection().transition(n)},ao.transition.prototype=Yl,Yl.select=function(n){var t,e,r,i=this.id,u=this.namespace,o=[];n=A(n);for(var a=-1,l=this.length;++a<l;){o.push(t=[]);for(var c=this[a],f=-1,s=c.length;++f<s;)(r=c[f])&&(e=n.call(r,r.__data__,f,a))?("__data__"in r&&(e.__data__=r.__data__),Qu(e,f,u,i,r[u][i]),t.push(e)):t.push(null)}return Wu(o,u,i)},Yl.selectAll=function(n){var t,e,r,i,u,o=this.id,a=this.namespace,l=[];n=C(n);for(var c=-1,f=this.length;++c<f;)for(var s=this[c],h=-1,p=s.length;++h<p;)if(r=s[h]){u=r[a][o],e=n.call(r,r.__data__,h,c),l.push(t=[]);for(var g=-1,v=e.length;++g<v;)(i=e[g])&&Qu(i,g,a,o,u),t.push(i)}return Wu(l,a,o)},Yl.filter=function(n){var t,e,r,i=[];"function"!=typeof n&&(n=O(n));for(var u=0,o=this.length;o>u;u++){i.push(t=[]);for(var e=this[u],a=0,l=e.length;l>a;a++)(r=e[a])&&n.call(r,r.__data__,a,u)&&t.push(r)}return Wu(i,this.namespace,this.id)},Yl.tween=function(n,t){var e=this.id,r=this.namespace;return arguments.length<2?this.node()[r][e].tween.get(n):Y(this,null==t?function(t){t[r][e].tween.remove(n)}:function(i){i[r][e].tween.set(n,t)})},Yl.attr=function(n,t){function e(){this.removeAttribute(a)}function r(){this.removeAttributeNS(a.space,a.local)}function i(n){return null==n?e:(n+="",function(){var t,e=this.getAttribute(a);return e!==n&&(t=o(e,n),function(n){this.setAttribute(a,t(n))})})}function u(n){return null==n?r:(n+="",function(){var t,e=this.getAttributeNS(a.space,a.local);return e!==n&&(t=o(e,n),function(n){this.setAttributeNS(a.space,a.local,t(n))})})}if(arguments.length<2){for(t in n)this.attr(t,n[t]);return this}var o="transform"==n?$r:Mr,a=ao.ns.qualify(n);return Ju(this,"attr."+n,t,a.local?u:i)},Yl.attrTween=function(n,t){function e(n,e){var r=t.call(this,n,e,this.getAttribute(i));return r&&function(n){this.setAttribute(i,r(n))}}function r(n,e){var r=t.call(this,n,e,this.getAttributeNS(i.space,i.local));return r&&function(n){this.setAttributeNS(i.space,i.local,r(n))}}var i=ao.ns.qualify(n);return this.tween("attr."+n,i.local?r:e)},Yl.style=function(n,e,r){function i(){this.style.removeProperty(n)}function u(e){return null==e?i:(e+="",function(){var i,u=t(this).getComputedStyle(this,null).getPropertyValue(n);return u!==e&&(i=Mr(u,e),function(t){this.style.setProperty(n,i(t),r)})})}var o=arguments.length;if(3>o){if("string"!=typeof n){2>o&&(e="");for(r in n)this.style(r,n[r],e);return this}r=""}return Ju(this,"style."+n,e,u)},Yl.styleTween=function(n,e,r){function i(i,u){var o=e.call(this,i,u,t(this).getComputedStyle(this,null).getPropertyValue(n));return o&&function(t){this.style.setProperty(n,o(t),r)}}return arguments.length<3&&(r=""),this.tween("style."+n,i)},Yl.text=function(n){return Ju(this,"text",n,Gu)},Yl.remove=function(){var n=this.namespace;return this.each("end.transition",function(){var t;this[n].count<2&&(t=this.parentNode)&&t.removeChild(this)})},Yl.ease=function(n){var t=this.id,e=this.namespace;return arguments.length<1?this.node()[e][t].ease:("function"!=typeof n&&(n=ao.ease.apply(ao,arguments)),Y(this,function(r){r[e][t].ease=n}))},Yl.delay=function(n){var t=this.id,e=this.namespace;return arguments.length<1?this.node()[e][t].delay:Y(this,"function"==typeof n?function(r,i,u){r[e][t].delay=+n.call(r,r.__data__,i,u)}:(n=+n,function(r){r[e][t].delay=n}))},Yl.duration=function(n){var t=this.id,e=this.namespace;return arguments.length<1?this.node()[e][t].duration:Y(this,"function"==typeof n?function(r,i,u){r[e][t].duration=Math.max(1,n.call(r,r.__data__,i,u))}:(n=Math.max(1,n),function(r){r[e][t].duration=n}))},Yl.each=function(n,t){var e=this.id,r=this.namespace;if(arguments.length<2){var i=Ol,u=Hl;try{Hl=e,Y(this,function(t,i,u){Ol=t[r][e],n.call(t,t.__data__,i,u)})}finally{Ol=i,Hl=u}}else Y(this,function(i){var u=i[r][e];(u.event||(u.event=ao.dispatch("start","end","interrupt"))).on(n,t)});return this},Yl.transition=function(){for(var n,t,e,r,i=this.id,u=++Zl,o=this.namespace,a=[],l=0,c=this.length;c>l;l++){a.push(n=[]);for(var t=this[l],f=0,s=t.length;s>f;f++)(e=t[f])&&(r=e[o][i],Qu(e,f,o,u,{time:r.time,ease:r.ease,delay:r.delay+r.duration,duration:r.duration})),n.push(e)}return Wu(a,o,u)},ao.svg.axis=function(){function n(n){n.each(function(){var n,c=ao.select(this),f=this.__chart__||e,s=this.__chart__=e.copy(),h=null==l?s.ticks?s.ticks.apply(s,a):s.domain():l,p=null==t?s.tickFormat?s.tickFormat.apply(s,a):m:t,g=c.selectAll(".tick").data(h,s),v=g.enter().insert("g",".domain").attr("class","tick").style("opacity",Uo),d=ao.transition(g.exit()).style("opacity",Uo).remove(),y=ao.transition(g.order()).style("opacity",1),M=Math.max(i,0)+o,x=Zi(s),b=c.selectAll(".domain").data([0]),_=(b.enter().append("path").attr("class","domain"),ao.transition(b));v.append("line"),v.append("text");var w,S,k,N,E=v.select("line"),A=y.select("line"),C=g.select("text").text(p),z=v.select("text"),L=y.select("text"),q="top"===r||"left"===r?-1:1;if("bottom"===r||"top"===r?(n=no,w="x",k="y",S="x2",N="y2",C.attr("dy",0>q?"0em":".71em").style("text-anchor","middle"),_.attr("d","M"+x[0]+","+q*u+"V0H"+x[1]+"V"+q*u)):(n=to,w="y",k="x",S="y2",N="x2",C.attr("dy",".32em").style("text-anchor",0>q?"end":"start"),_.attr("d","M"+q*u+","+x[0]+"H0V"+x[1]+"H"+q*u)),E.attr(N,q*i),z.attr(k,q*M),A.attr(S,0).attr(N,q*i),L.attr(w,0).attr(k,q*M),s.rangeBand){var T=s,R=T.rangeBand()/2;f=s=function(n){return T(n)+R}}else f.rangeBand?f=s:d.call(n,s,f);v.call(n,f,s),y.call(n,s,s)})}var t,e=ao.scale.linear(),r=Vl,i=6,u=6,o=3,a=[10],l=null;return n.scale=function(t){return arguments.length?(e=t,n):e},n.orient=function(t){return arguments.length?(r=t in Xl?t+"":Vl,n):r},n.ticks=function(){return arguments.length?(a=co(arguments),n):a},n.tickValues=function(t){return arguments.length?(l=t,n):l},n.tickFormat=function(e){return arguments.length?(t=e,n):t},n.tickSize=function(t){var e=arguments.length;return e?(i=+t,u=+arguments[e-1],n):i},n.innerTickSize=function(t){return arguments.length?(i=+t,n):i},n.outerTickSize=function(t){return arguments.length?(u=+t,n):u},n.tickPadding=function(t){return arguments.length?(o=+t,n):o},n.tickSubdivide=function(){return arguments.length&&n},n};var Vl="bottom",Xl={top:1,right:1,bottom:1,left:1};ao.svg.brush=function(){function n(t){t.each(function(){var t=ao.select(this).style("pointer-events","all").style("-webkit-tap-highlight-color","rgba(0,0,0,0)").on("mousedown.brush",u).on("touchstart.brush",u),o=t.selectAll(".background").data([0]);o.enter().append("rect").attr("class","background").style("visibility","hidden").style("cursor","crosshair"),t.selectAll(".extent").data([0]).enter().append("rect").attr("class","extent").style("cursor","move");var a=t.selectAll(".resize").data(v,m);a.exit().remove(),a.enter().append("g").attr("class",function(n){return"resize "+n}).style("cursor",function(n){return $l[n]}).append("rect").attr("x",function(n){return/[ew]$/.test(n)?-3:null}).attr("y",function(n){return/^[ns]/.test(n)?-3:null}).attr("width",6).attr("height",6).style("visibility","hidden"),a.style("display",n.empty()?"none":null);var l,s=ao.transition(t),h=ao.transition(o);c&&(l=Zi(c),h.attr("x",l[0]).attr("width",l[1]-l[0]),r(s)),f&&(l=Zi(f),h.attr("y",l[0]).attr("height",l[1]-l[0]),i(s)),e(s)})}function e(n){n.selectAll(".resize").attr("transform",function(n){return"translate("+s[+/e$/.test(n)]+","+h[+/^s/.test(n)]+")"})}function r(n){n.select(".extent").attr("x",s[0]),n.selectAll(".extent,.n>rect,.s>rect").attr("width",s[1]-s[0])}function i(n){n.select(".extent").attr("y",h[0]),n.selectAll(".extent,.e>rect,.w>rect").attr("height",h[1]-h[0])}function u(){function u(){32==ao.event.keyCode&&(C||(M=null,L[0]-=s[1],L[1]-=h[1],C=2),S())}function v(){32==ao.event.keyCode&&2==C&&(L[0]+=s[1],L[1]+=h[1],C=0,S())}function d(){var n=ao.mouse(b),t=!1;x&&(n[0]+=x[0],n[1]+=x[1]),C||(ao.event.altKey?(M||(M=[(s[0]+s[1])/2,(h[0]+h[1])/2]),L[0]=s[+(n[0]<M[0])],L[1]=h[+(n[1]<M[1])]):M=null),E&&y(n,c,0)&&(r(k),t=!0),A&&y(n,f,1)&&(i(k),t=!0),t&&(e(k),w({type:"brush",mode:C?"move":"resize"}))}function y(n,t,e){var r,i,u=Zi(t),l=u[0],c=u[1],f=L[e],v=e?h:s,d=v[1]-v[0];return C&&(l-=f,c-=d+f),r=(e?g:p)?Math.max(l,Math.min(c,n[e])):n[e],C?i=(r+=f)+d:(M&&(f=Math.max(l,Math.min(c,2*M[e]-r))),r>f?(i=r,r=f):i=f),v[0]!=r||v[1]!=i?(e?a=null:o=null,v[0]=r,v[1]=i,!0):void 0}function m(){d(),k.style("pointer-events","all").selectAll(".resize").style("display",n.empty()?"none":null),ao.select("body").style("cursor",null),q.on("mousemove.brush",null).on("mouseup.brush",null).on("touchmove.brush",null).on("touchend.brush",null).on("keydown.brush",null).on("keyup.brush",null),z(),w({type:"brushend"})}var M,x,b=this,_=ao.select(ao.event.target),w=l.of(b,arguments),k=ao.select(b),N=_.datum(),E=!/^(n|s)$/.test(N)&&c,A=!/^(e|w)$/.test(N)&&f,C=_.classed("extent"),z=W(b),L=ao.mouse(b),q=ao.select(t(b)).on("keydown.brush",u).on("keyup.brush",v);if(ao.event.changedTouches?q.on("touchmove.brush",d).on("touchend.brush",m):q.on("mousemove.brush",d).on("mouseup.brush",m),k.interrupt().selectAll("*").interrupt(),C)L[0]=s[0]-L[0],L[1]=h[0]-L[1];else if(N){var T=+/w$/.test(N),R=+/^n/.test(N);x=[s[1-T]-L[0],h[1-R]-L[1]],L[0]=s[T],L[1]=h[R]}else ao.event.altKey&&(M=L.slice());k.style("pointer-events","none").selectAll(".resize").style("display",null),ao.select("body").style("cursor",_.style("cursor")),w({type:"brushstart"}),d()}var o,a,l=N(n,"brushstart","brush","brushend"),c=null,f=null,s=[0,0],h=[0,0],p=!0,g=!0,v=Bl[0];return n.event=function(n){n.each(function(){var n=l.of(this,arguments),t={x:s,y:h,i:o,j:a},e=this.__chart__||t;this.__chart__=t,Hl?ao.select(this).transition().each("start.brush",function(){o=e.i,a=e.j,s=e.x,h=e.y,n({type:"brushstart"})}).tween("brush:brush",function(){var e=xr(s,t.x),r=xr(h,t.y);return o=a=null,function(i){s=t.x=e(i),h=t.y=r(i),n({type:"brush",mode:"resize"})}}).each("end.brush",function(){o=t.i,a=t.j,n({type:"brush",mode:"resize"}),n({type:"brushend"})}):(n({type:"brushstart"}),n({type:"brush",mode:"resize"}),n({type:"brushend"}))})},n.x=function(t){return arguments.length?(c=t,v=Bl[!c<<1|!f],n):c},n.y=function(t){return arguments.length?(f=t,v=Bl[!c<<1|!f],n):f},n.clamp=function(t){return arguments.length?(c&&f?(p=!!t[0],g=!!t[1]):c?p=!!t:f&&(g=!!t),n):c&&f?[p,g]:c?p:f?g:null},n.extent=function(t){var e,r,i,u,l;return arguments.length?(c&&(e=t[0],r=t[1],f&&(e=e[0],r=r[0]),o=[e,r],c.invert&&(e=c(e),r=c(r)),e>r&&(l=e,e=r,r=l),e==s[0]&&r==s[1]||(s=[e,r])),f&&(i=t[0],u=t[1],c&&(i=i[1],u=u[1]),a=[i,u],f.invert&&(i=f(i),u=f(u)),i>u&&(l=i,i=u,u=l),i==h[0]&&u==h[1]||(h=[i,u])),n):(c&&(o?(e=o[0],r=o[1]):(e=s[0],r=s[1],c.invert&&(e=c.invert(e),r=c.invert(r)),e>r&&(l=e,e=r,r=l))),f&&(a?(i=a[0],u=a[1]):(i=h[0],u=h[1],f.invert&&(i=f.invert(i),u=f.invert(u)),i>u&&(l=i,i=u,u=l))),c&&f?[[e,i],[r,u]]:c?[e,r]:f&&[i,u])},n.clear=function(){return n.empty()||(s=[0,0],h=[0,0],o=a=null),n},n.empty=function(){return!!c&&s[0]==s[1]||!!f&&h[0]==h[1]},ao.rebind(n,l,"on")};var $l={n:"ns-resize",e:"ew-resize",s:"ns-resize",w:"ew-resize",nw:"nwse-resize",ne:"nesw-resize",se:"nwse-resize",sw:"nesw-resize"},Bl=[["n","e","s","w","nw","ne","se","sw"],["e","w"],["n","s"],[]],Wl=ga.format=xa.timeFormat,Jl=Wl.utc,Gl=Jl("%Y-%m-%dT%H:%M:%S.%LZ");Wl.iso=Date.prototype.toISOString&&+new Date("2000-01-01T00:00:00.000Z")?eo:Gl,eo.parse=function(n){var t=new Date(n);return isNaN(t)?null:t},eo.toString=Gl.toString,ga.second=On(function(n){return new va(1e3*Math.floor(n/1e3))},function(n,t){n.setTime(n.getTime()+1e3*Math.floor(t))},function(n){return n.getSeconds()}),ga.seconds=ga.second.range,ga.seconds.utc=ga.second.utc.range,ga.minute=On(function(n){return new va(6e4*Math.floor(n/6e4))},function(n,t){n.setTime(n.getTime()+6e4*Math.floor(t))},function(n){return n.getMinutes()}),ga.minutes=ga.minute.range,ga.minutes.utc=ga.minute.utc.range,ga.hour=On(function(n){var t=n.getTimezoneOffset()/60;return new va(36e5*(Math.floor(n/36e5-t)+t))},function(n,t){n.setTime(n.getTime()+36e5*Math.floor(t))},function(n){return n.getHours()}),ga.hours=ga.hour.range,ga.hours.utc=ga.hour.utc.range,ga.month=On(function(n){return n=ga.day(n),n.setDate(1),n},function(n,t){n.setMonth(n.getMonth()+t)},function(n){return n.getMonth()}),ga.months=ga.month.range,ga.months.utc=ga.month.utc.range;var Kl=[1e3,5e3,15e3,3e4,6e4,3e5,9e5,18e5,36e5,108e5,216e5,432e5,864e5,1728e5,6048e5,2592e6,7776e6,31536e6],Ql=[[ga.second,1],[ga.second,5],[ga.second,15],[ga.second,30],[ga.minute,1],[ga.minute,5],[ga.minute,15],[ga.minute,30],[ga.hour,1],[ga.hour,3],[ga.hour,6],[ga.hour,12],[ga.day,1],[ga.day,2],[ga.week,1],[ga.month,1],[ga.month,3],[ga.year,1]],nc=Wl.multi([[".%L",function(n){return n.getMilliseconds()}],[":%S",function(n){return n.getSeconds()}],["%I:%M",function(n){return n.getMinutes()}],["%I %p",function(n){return n.getHours()}],["%a %d",function(n){return n.getDay()&&1!=n.getDate()}],["%b %d",function(n){return 1!=n.getDate()}],["%B",function(n){return n.getMonth()}],["%Y",zt]]),tc={range:function(n,t,e){return ao.range(Math.ceil(n/e)*e,+t,e).map(io)},floor:m,ceil:m};Ql.year=ga.year,ga.scale=function(){return ro(ao.scale.linear(),Ql,nc)};var ec=Ql.map(function(n){return[n[0].utc,n[1]]}),rc=Jl.multi([[".%L",function(n){return n.getUTCMilliseconds()}],[":%S",function(n){return n.getUTCSeconds()}],["%I:%M",function(n){return n.getUTCMinutes()}],["%I %p",function(n){return n.getUTCHours()}],["%a %d",function(n){return n.getUTCDay()&&1!=n.getUTCDate()}],["%b %d",function(n){return 1!=n.getUTCDate()}],["%B",function(n){return n.getUTCMonth()}],["%Y",zt]]);ec.year=ga.year.utc,ga.scale.utc=function(){return ro(ao.scale.linear(),ec,rc)},ao.text=An(function(n){return n.responseText}),ao.json=function(n,t){return Cn(n,"application/json",uo,t)},ao.html=function(n,t){return Cn(n,"text/html",oo,t)},ao.xml=An(function(n){return n.responseXML}),"function"==typeof define&&define.amd?(this.d3=ao,define(ao)):"object"==typeof module&&module.exports?module.exports=ao:this.d3=ao}();},{}],
-			2:[function(require,module,exports){
-			"use strict";
-
-			var d3 = require('d3');
-
-			//aigner: functions for drawing expand- and collapse-symbols
-			function drawExpandSymbol(aCircle, line1, line2)
-			{        
-				 aCircle = aCircle
-					.attr("r", 10)
-					.style("stroke", "black")
-					.style("stroke-width", 2)
-					.style("fill", "#99CC00")
-					.style("fill-opacity", .6)
-				line1 = line1
-					.attr("x1", parseFloat(aCircle.attr("cx"))-5)
-					.attr("y1", parseFloat(aCircle.attr("cy")))
-					.attr("x2", parseFloat(aCircle.attr("cx"))+5)
-					.attr("y2", parseFloat(aCircle.attr("cy")))
-					.style("stroke", "black")
-					.style("stroke-width", 2);
-				line2 = line2
-					.attr("x1", parseFloat(aCircle.attr("cx")))
-					.attr("y1", parseFloat(aCircle.attr("cy"))-5)
-					.attr("x2", parseFloat(aCircle.attr("cx")))
-					.attr("y2", parseFloat(aCircle.attr("cy"))+5)
-					.style("stroke", "black")
-					.style("stroke-width", 2);
-			}
-			function drawRemoveSymbol(anXdsm, aCircle, aMinus)
-			{        
-				 var xOffset=150;
-				 var yOffset=12;
-				 aCircle = aCircle
-					.attr("cx", anXdsm.svg.attr("width")-xOffset)
-					.attr("cy", yOffset)
-					.attr("r", 10)
-					.classed("remCircle",true)
-				aMinus = aMinus
-					.attr("x1", anXdsm.svg.attr("width")-xOffset+5)
-					.attr("y1", yOffset)
-					.attr("x2", anXdsm.svg.attr("width")-xOffset-5)
-					.attr("y2", yOffset)
-					.classed("remMinus",true)
-			}
-			//d3-context-menu for right-click-option
-			d3.contextMenu = function (menu, openCallback) {
-
-				// create the div element that will hold the context menu
-				d3.selectAll('.d3-context-menu').data([1])
-					.enter()
-					.append('div')
-					.attr('class', 'd3-context-menu');
-
-				// close menu
-				d3.select('body').on('click.d3-context-menu', function() {
-					d3.select('.d3-context-menu').style('display', 'none');
-				});
-
-				// this gets executed when a contextmenu event occurs
-				return function(data, index) {	
-					var elm = this;
-
-					d3.selectAll('.d3-context-menu').html('');
-					var list = d3.selectAll('.d3-context-menu').append('ul');
-						list.selectAll('li').data(menu).enter()
-						.append('li')
-						.html(function(d) {
-							return d.title;
-						})
-						.on('mousedown', function(d, i) {
-							d.onMouseDown(elm, data, index);
-						})
-						.on('mouseup', function(d, i) {
-							d.onMouseUp(elm, data, index);
-							d3.select('.d3-context-menu').style('display', 'none');
-						})
-						.on('mouseenter',function(d,i){
-							d.onMouseOver(elm,data,index);
-							if(d.childrenItems.length>0 )
-								 {
-                                  var li = this
-								  d3.select(this).selectAll("ul").remove(); 
-								  d3.select(this)
-									.append("ul")
-                                    .style("top",String(li.offsetTop-5)+"px")
-									.selectAll("li")
-									   .data(d.childrenItems)
-										.enter().append("li")
-										  .text(function(d) { return d.title; })
-									 .on("mouseenter", function(d,i){
-											d.onMouseOver(elm,data,index);
-										})
-									 .on('click',  function(d, i) {
-											d.onMouseClick(elm, d, index);
-										})
-									 .on('mouseleave',function(d,i){
-										
-										});
-								 }
-							 else
-								 return false;
-						})
-						.on('mouseleave',function(d,i){
-							d3.select(this).selectAll("ul").style('display', 'none')                  
-						});
-					
-					  
-
-					// the openCallback allows an action to fire before the menu is displayed
-					// an example usage would be closing a tooltip
-					if (openCallback) openCallback(data, index);
-
-					// display context menu
-					d3.select('.d3-context-menu')
-						.style('left', (d3.event.pageX - 2) + 'px')
-						.style('top', (d3.event.pageY - 2) + 'px')
-						.style('display', 'block');
-                    
-                    //Prevent the default event, which is the left-click. 
-                    //This means, the context-menu will only appear on right mouse clicks
-					d3.event.preventDefault();
-                    
-                    //Place context-menu always on top of everything esle
-                    d3.select(".d3-context-menu").style("z-index",Number.MAX_SAFE_INTEGER);
-				};
-			};
-				
-			function tabulate(aTable,data,columns) {
-				var thead = aTable.append('thead');
-				var	tbody = aTable.append('tbody');  
-
-				// create a row for each object in the data
-				var rows = tbody.selectAll('tr')
-				  .data(data)
-				  .enter()
-				  .append('tr');
-
-				// create a cell in each row for each column
-				var cells = rows.selectAll('td')
-				  .data(function (row) {
-					return columns.map(function (column) {
-					  return {column: column, value: row[column]};
-					});
-				  })
-				  .enter()
-				  .append('td')
-					.html(function (d) { return d.value; });
-
-				return aTable;
-			}
-
-			//aigner: Move to front function
-			d3.selection.prototype.moveToFront = function() {  
-			  return this.each(function(){
-				this.parentNode.appendChild(this);
-			  });
-			};
-			//aigner: Move to back function
-			d3.selection.prototype.moveToBack = function() {  
-				return this.each(function() { 
-					var firstChild = this.parentNode.firstChild; 
-					if (firstChild) { 
-						this.parentNode.insertBefore(this, firstChild); 
-					} 
-				});
-			};
-
-
-			var diameter = 1500,
-				radius = diameter / 2,
-				innerRadius = radius - 250;
-
-			var cluster = d3.layout.cluster()
-				.size([360, innerRadius])
-				.sort(null)
-				.value(function(d) { return d.size; });
-
-			var bundle = d3.layout.bundle();
-
-			var line = d3.svg.line.radial()
-				.interpolate("bundle")
-				.tension(0.5)
-				.radius(function(d) { return d.y; })
-				.angle(function(d) { return d.x / 180 * Math.PI; });
-
-			var svg = d3.select("body").append("div").attr("class","edgeBundlesDiv")
-				svg = svg.append("svg")
-					.attr("class","circleSvg")
-					.attr("width", 10000)
-					.attr("height", 10000)
-					.append("g")
-					.attr("transform", "translate(" + radius*1.2 + "," + radius*1.2+ ")");
-				
-			var width = diameter*1.5;
-			var imgWidth = width;
-
-			var link = svg.append("g").selectAll(".edgeBundlesLink"),
-				invisibleLink = svg.append("g").selectAll(".invisibleLink"),
-				node = svg.append("g").selectAll(".edgeBundlesNode");
-			
-			//aigner: Here the data is read and the edge bundles is created
-			//################################################################################################//			
-			function startEdgeBundles(data, graphID) 
-			{
-				var graphs, currentGraph, varCategories;
-				
-				graphs =  data.graphs;
-				for (var i=0;i<graphs.length;i++)
-				{
-					if (graphs[i].id==graphID)
-					{
-						currentGraph = graphs[i]
-					}
-				}
-				
-				varCategories =  data.categories;
-				var classes = currentGraph.edgeBundles;
-				
-				//Highlight function, that shows usage of a node in the XDSM
-                function highlight(data)
-                {
-                    var xPath = data.xPath
-                    var allLinks = d3.selectAll(".edgeBundlesLink");
-                    allLinks[0].forEach(function(aLink)
-                    {
-                        
-                        aLink.__data__.pipeData_in = aLink.__data__.source.pipeline_data[aLink.__data__.target.name];
-                        aLink.__data__.pipeData_out = aLink.__data__.target.pipeline_data[aLink.__data__.source.name];
-                        aLink.__data__.pipeDataName_in = "";
-                        aLink.__data__.pipeDataName_out = "";
-                        aLink.__data__.name = "";
-                        if (aLink.__data__.pipeData_in)
-                        {
-                            for (var i=0; i<aLink.__data__.pipeData_in.length; i++)
-                            {
-                                if (i==0){aLink.__data__.pipeDataName_in += aLink.__data__.pipeData_in[i];}
-                                else{aLink.__data__.pipeDataName_in += "," + aLink.__data__.pipeData_in[i];}
-                                
-                            }
-                            aLink.__data__.name += aLink.__data__.pipeDataName_in
-                        }
-                        if (aLink.__data__.pipeData_out)
-                        {
-                            for (var i=0; i<aLink.__data__.pipeData_out.length; i++)
-                            {
-                                if (i==0){aLink.__data__.pipeDataName_out += aLink.__data__.pipeData_out[i];}
-                                else{aLink.__data__.pipeDataName_out += "," + aLink.__data__.pipeData_out[i];}
-                            }
-                            aLink.__data__.name += aLink.__data__.pipeDataName_out
-                        }
-                    })
-                    
-                    allLinks[0].forEach(function(p) {
-                        var firstElement_tmp = p.__data__.name.split("/")[1]
-                        var xPath_fromFirst = "/"+firstElement_tmp+xPath.split(firstElement_tmp)[1]
-                        var p_name_list = p.__data__.name.split(",")
-                        var highlight_on = false
-                        p_name_list.forEach(function(p_name) 
-                        {
-                            if (include(p_name+"__",xPath_fromFirst+"__") || include(p_name,xPath_fromFirst+"/"))
-                            {                                
-                                highlight_on = true
-                            }
-                        })
-                        if (highlight_on)
-                        {
-                            d3.select(p).style("stroke-opacity", 1.5)
-                        }
-                        else
-                        {
-                            d3.select(p).style("stroke-opacity", 0);			
-                        }
-                    });
-                }
-                    
-                //Function writeTreeToXML goes through tree nodes and puts the into an xml document
-                function writeTreeToXML(aNode,anXMLDoc,anXPath)
-                {
-                    //Variable "children" 
-                    //--> One children variable, no matter whether a node has "_children" (collapsed) or "children" (expanded)
-                    var children;
-                    if (aNode._children){children = aNode._children;}
-                    else if (aNode.children){children = aNode.children;}
-                    
-                    //Get current xml element with its xPath
-                    var element = anXMLDoc.evaluate(anXPath,anXMLDoc, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null ).singleNodeValue;
-                    if (element != null) {element.value = '...';}
-                    
-                    //If a node has children (collapsed or expanded), loop through them
-                    if (children)
-                    {
-                        for (var i=0; i < children.length;i++)
-                        {
-                            //Name of the new XML element --> childName
-                            var child = children[i];
-                            var childName = child.name.split(/[\[\]]+/);//Split childName at "[]" which is the uID 
-                            var cleanChildName = childName[0].split(/[\+\*\^\-\ \#]+/);//Split childName all special characters
-                            var newNode = anXMLDoc.createElement(String(cleanChildName[0]));
-                            
-                            //The children are appended to the xPath --> newXPath
-                            var newXPath = anXPath+"/"+cleanChildName[0];
-                            
-                            //If childName contains a uID, make the uID an attribute
-                            if (childName[1])
-                            {
-                                if (parseInt(childName[1]))
-                                {
-                                    var dummyID = childName[1];
-                                    newNode.setAttribute("dummyID", dummyID)
-                                    newXPath = newXPath+"[@dummyID='"+dummyID+"']";
-                                }
-                                else
-                                {
-                                    var uID = childName[1];
-                                    newNode.setAttribute("uID", uID)
-                                    newXPath = newXPath+"[@uID='"+uID+"']";
-                                }
-                            }
-                            if (cleanChildName.length>1) {newNode.setAttribute("elementName", childName[0])};
-                            
-                            //Append the newNode to the xml structure
-                            element.appendChild(newNode);
-                            
-                            
-                            
-                            ////aigner: Sorting of XML elements according to "uID"
-                            // var items = element.children;
-                            // var itemsArr = [];
-                            // for (var j in items) {
-                                // if (items[j].nodeType == 1) { // get rid of the whitespace text nodes
-                                    // itemsArr.push(items[j]);
-                                // }
-                            // }
-                            // itemsArr.sort(function(a,b){
-                                // if (a.getAttribute("uID") < b.getAttribute("uID"))
-                                    // return -1;
-                                // if (a.getAttribute("uID") > b.getAttribute("uID"))
-                                    // return 1;
-                                // return 0;
-                                // });
-
-                            // for (j = 0; j < itemsArr.length; ++j) {
-                              // element.appendChild(itemsArr[j]);
-                            // }
-                            
-                            //call function writeTreeToXML recursively for all children
-                            writeTreeToXML(child,anXMLDoc,newXPath)
-                        }
-                    }
-                    else
-                    {
-                        if (aNode.value){element.innerHTML = String(aNode.value);}
-                        else{element.innerHTML = " ";}
-                    }
-                    //return the xml document
-                    return anXMLDoc;
-                }
-                
-                function removeAttributeInAllElements(aDocument,attribute)
-                {
-                  var matchingElements = [];
-                  var allElements = aDocument.getElementsByTagName('*');
-                  for (var i = 0, n = allElements.length; i < n; i++)
-                  {
-                    if (allElements[i].getAttribute(attribute) !== null)
-                    {
-                        allElements[i].removeAttribute(attribute);
-                    }
-                  }
-                  return matchingElements;
-                }
-                
-                function putAncestorsInXMLString(strWrapper, aNode)
-                {
-                    //Name of the new XML element
-                    var nodeName = aNode.name.split(/[\[\]]+/);//Split name at "[]" which is the uID 
-                    var cleanNodeName = nodeName[0].split(/[\+\*\^\-\ \#]+/);//Split nodeName all special characters
-                    //If nodeName contains a uID, make the uID an attribute
-                    if (nodeName[1])
-                    {
-                        var uID = nodeName[1];
-                        strWrapper.val = "<"+cleanNodeName[0]+" uID='"+ uID +"'>"+strWrapper.val+"</"+cleanNodeName[0]+">";;
-                    }
-                    else
-                    {
-                        strWrapper.val = "<"+cleanNodeName[0]+">"+strWrapper.val+"</"+cleanNodeName[0]+">";;
-                    }
-                    var aParent = aNode.parent;
-                    if (aParent)
-                    {
-                        return putAncestorsInXMLString(strWrapper, aParent);
-                    }
-                    else 
-                    {
-                        return strWrapper;
-                    }
-                }
-                
-                function putAncestorsInXPath(strWrapper, aNode)
-                {
-                    //Name of the new XML element
-                    var nodeName = aNode.name.split(/[\[\]]+/);//Split name at "[]" which is the uID 
-                    var cleanNodeName = nodeName[0].split(/[\+\*\^\-\ \#]+/);//Split nodeName all special characters
-                    //If nodeName contains a uID, make the uID an attribute
-                    if (nodeName[1])
-                    {
-                        var uID = nodeName[1];
-                        strWrapper.val = "/"+cleanNodeName[0]+"[@uID='"+uID+"']"+strWrapper.val;
-                    }
-                    else
-                    {
-                        strWrapper.val = "/"+cleanNodeName[0]+strWrapper.val;
-                    }
-                    var aParent = aNode.parent;
-                    if (aParent)
-                    {
-                        return putAncestorsInXPath(strWrapper, aParent);
-                    }
-                    else 
-                    {
-                        return strWrapper;
-                    }
-                }
-                
-                // Function to download data to a file
-                function download(filename, text) {
-                    var element = document.createElement('a');
-                    element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(text));
-                    element.setAttribute('download', filename);
-
-                    element.style.display = 'none';
-                    document.body.appendChild(element);
-
-                    element.click();
-
-                    document.body.removeChild(element);
-                }
-                
-                function showVariableTable(aVariable)
-                {						
-                                        
-                    var headLine = "Node Information (" + aVariable.name + ")";
-                    var data = [];
-                    // render the table(s)
-                    data.push({ "name" : "Name", "value" : "\""+aVariable.name+"\"" })
-                    data.push({ "name" : "xPath", "value" : aVariable.xPath })
-                    if (aVariable.type){data.push({ "name" : "Type", "value" : aVariable.type })}
-                    if (aVariable.level){data.push({ "name" : "Level", "value" : aVariable.level })}
-                    if (aVariable.children || aVariable._children)
-                    {
-                        var childrenNum=0;
-                        if (aVariable.children){childrenNum=childrenNum+aVariable.children.length}
-                        if (aVariable._children){childrenNum=childrenNum+aVariable._children.length}
-                        data.push({ "name" : "Number of children", "value" : childrenNum })
-                    }
-                    if (aVariable.dimension){data.push({ "name" : "Dimension", "value" : aVariable.dimension })}
-                    else if(aVariable.dimension===null){data.push({ "name" : "Dimension", "value" : "undefined" })}
-                    if (aVariable.value){data.push({ "name" : "Value(s)", "value" : aVariable.value })}
-                    
-                    var d3_body = d3.select("body");
-                    
-                    var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                    panel_div.append("div").attr("class","panel-heading")
-                        .append("div").attr("class","panel_title").append("h4").text(headLine)
-                    var listGroup = panel_div.append("div").attr("class","panel-body")
-                        .append("table").attr("id","myTable")
-                        .append("tbody")
-                        
-                    data.forEach(function(listElement)
-                    {
-                        var row = listGroup.append("tr")
-                        row.append("td").text(listElement.name)
-                        row.append("td").text(listElement.value)
-                        
-                    })
-                    $('.myPanel').lobiPanel({
-                        reload: false,
-                        editTitle: false,
-                        expand: false,
-                        unpin: false,
-                        resize: "none",
-                        minWidth: 200,
-                        minHeight: 200,
-                        maxWidth: 1100,
-                        maxHeight: 1200,
-                    });
-                    $('.myPanel').lobiPanel('unpin');
-                }
-                
-                //menu --> functions for right click options
-                var nodeMenu = [
-                {
-                    title: 'Show node information',
-                    onMouseDown: function(elm, d, i) {
-                        showVariableTable(d);
-                    },
-                    onMouseUp: function(elm, d, i) {},
-                    onMouseOver: function(elm, d, i) {},
-                    childrenItems: []
-                },
-                {
-                    title: 'Show usage of node in diagram',
-                    onMouseDown: function(elm, d, i) {
-                        d3.selectAll(".treeFrame").attr("fill-opacity", .5);
-                        d3.selectAll(".nodeText").style("fill-opacity", 0.5);					
-                        highlight(d);
-                    },
-                    onMouseUp: function(elm, d, i) {				
-                        d3.selectAll(".edgeBundlesLink")
-                            .style("stroke-opacity",.4)
-                        d3.selectAll(".treeFrame").attr("fill-opacity", .8);
-                        d3.selectAll(".nodeText").style("fill-opacity", 1);					
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: []
-                },
-                {
-                    title: 'Copy x-path to clipboard',
-                    onMouseDown: function(elm, d, i) {
-                        window.prompt("Copy to clipboard: Ctrl+C, Enter", d.xPath);
-                        d3.select('.d3-context-menu').style('display', 'none');
-                    },
-                    onMouseUp: function(elm, d, i) {
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: []
-                }
-                ]
-                
-				//################################################################################################//	
-				var headerDiv =  d3.select(".edgeBundlesDiv").append("div").attr("class","panel panel-primary")
-				headerDiv.append("div").attr("class","panel-heading text-center")
-					.append("h3")
-					.attr("class","panel-title")
-					.style("font-family","Arial")
-					.style("font-size","20pt")
-					.text("Edge Bundles View")
-				var name_tmp="";
-				if (currentGraph.name){name_tmp=currentGraph.name}
-				else{name_tmp="Graph " + currentGraph.id}
-				headerDiv.append("div").attr("class","panel-body")
-					.style("font-family","Arial")
-					.style("font-size","16pt")
-					.text("Graph name: " + name_tmp)
-				headerDiv.append("div").attr("class","panel-body")
-					.style("font-family","Arial")
-					.style("font-size","16pt")
-					.text("Graph description: " + currentGraph.description)
-				//################################################################################################//	
-				
-				//aigner: Tree option menu to select which kind of tree view the user wants to see
-				//#####################################################################//
-				function showFullTree(categoryID, categoryDescr)
-				{
-					var name_tmp = "Full data model tree view; Categorization: " + categoryDescr;
-					var emptyArray="";
-					var allLinks = d3.selectAll(".edgeBundlesLink");
-					var theSchema = currentGraph.variableSchemes[categoryID];
-					createTreeLayout(name_tmp,theSchema,emptyArray,allLinks,nodeMenu);
-				}
-				
-				var childrenItems = [];
-				for (var j=0; j< varCategories.length; j++)
-				{
-					childrenItems.push({title: 'according to ' + varCategories[j].description,
-								   varCategory: varCategories[j].name,
-								   description: varCategories[j].description,
-								   onMouseClick: function(elm, d, i) {showFullTree(d.varCategory,d.description)},
-								   onMouseOver: function(elm,d,i){}})
-				}
-				var treeOptionMenu = [
-				{
-					title: 'Show variable tree...',
-					onMouseDown: function(elm, d, i) {
-					},
-					onMouseUp: function(elm, d, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: childrenItems
-				}
-				]
-				
-                
-                function showList(aTitle,aList,aMenu)
-                {
-                    if (aList.length != 0)
-                    {
-                        var d3_body = d3.select("body");
-                        
-                        var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                        panel_div.append("div").attr("class","panel-heading")
-                            .append("div").attr("class","panel_title").append("h4").text(aTitle)
-                        panel_div.append("input")
-                            .attr("id","myInput")
-                            .attr("placeholder","Filter search...")
-                            .attr("title","Type in a name")
-                            .attr("onkeyup","filterSearch()")
-                        var listGroup = panel_div.append("div").attr("class","panel-body")
-                            .append("table").attr("id","myTable")
-                            .append("tbody")
-                            
-                        var tr = listGroup
-                            .selectAll('tr')
-                            .data(aList).enter()
-                                .append('tr')
-                        var td = tr.append("td").html(function(d) { 
-                            if (d.xPath){return d.xPath;} 
-                            else {return d.name;} 
-                        })
-                        tr.on('contextmenu', d3.contextMenu(aMenu));
-                        $('.myPanel').lobiPanel({
-                            reload: false,
-                            editTitle: false,
-                            expand: false,
-                            unpin: false,
-                            resize: "none",
-                            minWidth: 200,
-                            minHeight: 200,
-                            maxWidth: 1100,
-                            maxHeight: 1200,
-                        });
-                        $('.myPanel').lobiPanel('unpin');
-                        $('.myPanel').lobiPanel('height','5000');
-                    }
-                }
-                
-                //aigner: Data Model Tree View Button
-				//####################################################################################################################
-				var dataModelDiv = d3.select(".edgeBundlesDiv").append("div").attr("class","dataModelDiv").attr("transform","translate(10,0)")
-				var ul = dataModelDiv.append("ul")
-				var dropdown1 = ul.append("li").on("mouseover", function(){d3.select(this).style("cursor", "default")})
-				dropdown1.append("img").attr("src",fileReference.AGILE_Icon)
-					.attr("align","left")
-					.style("margin-left","6px")
-					.style("margin-right","-10px")
-					.style("margin-top","10px")
-					.style("margin-bottom","0px")
-					.attr("height","20")
-					.attr("width","20")
-				dropdown1.append("a").text("Data Model Tree")
-				var links = dropdown1.append("ul");
-                var xOffset_ul = dropdown1[0][0].offsetLeft+dropdown1[0][0].offsetWidth-40;
-                links.style("left", String(xOffset_ul)+"px")
-				for (var j=0; j< varCategories.length; j++)
-				{
-					//console.log(varCategories[j])
-					var linkLi = links.append("li");
-					var linkA = linkLi.append("a")
-						.attr("id",j)
-						.text(varCategories[j].description)
-						.on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-						.on("click", function()
-						{		
-							showFullTree(varCategories[this.id].name,varCategories[this.id].description)
-						})
-				}
-				//aigner: Set width of the div, so the VISTOMS dropdown (in the top of the page) still works
-				//dataModelDiv.style("width", String(dropdown1.node().getBoundingClientRect().width+20)+"px")
-				//####################################################################################################################
-                
-                //aigner: Data Model List View Button
-				//####################################################################################################################
-				var ul_list = dataModelDiv.append("ul")
-				var dropdownList = ul_list.append("li").on("mouseover", function(){d3.select(this).style("cursor", "default")})
-				dropdownList.append("img").attr("src",fileReference.AGILE_Icon)
-					.attr("align","left")
-					.style("margin-left","6px")
-					.style("margin-right","-10px")
-					.style("margin-top","10px")
-					.style("margin-bottom","0px")
-					.attr("height","20")
-					.attr("width","20")
-				dropdownList.append("a").text("Data Model List")
-				var linksList = dropdownList.append("ul");
-                var xOffset_ul = dropdownList[0][0].offsetLeft+dropdownList[0][0].offsetWidth-40;
-                linksList.style("left", String(xOffset_ul)+"px")
-				for (var j=0; j< varCategories.length; j++)
-				{
-					//console.log(varCategories[j])
-					var linkLi = linksList.append("li");
-					var linkA = linkLi.append("a")
-						.attr("id",j)
-						.text(varCategories[j].description)
-						.on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-						.on("click", function()
-						{	
-                            var variables = JSON.parse(JSON.stringify(currentGraph.variableSchemes[varCategories[this.id].name]));
-                            variables.forEach(function(variable)
-                            {
-                                variable.name = variable.xPath
-                                //work around because nodeMenu expexts the data, to have a "data" object inside
-                                variable.data = variable
-                                variable.data.name = variable.xPath.split("/")[variable.xPath.split("/").length-1]
-                            })
-                            var title = "List view: full variable set categorized according to " + varCategories[this.id].description
-                            showList(title,variables,nodeMenu)
-						})
-				}
-				//aigner: Set width of the div, so the VISTOMS dropdown (in the top of the page) still works
-				//####################################################################################################################
-				
-				
-				//aigner: legend
-				//################################################################################################//
-				// var legendDiv = d3.select("body").append("div").attr("class","legendDiv");
-				// var legendSVG = legendDiv.append("svg").attr("width",1000).attr("height",200);
-				// var legend = legendSVG.append("g")
-					// .attr("class", "legend")
-					// .attr("transform", "translate(38,12)");
-				// var legendFrame = legend.append("rect")
-					// .attr("x",-28)
-					// .attr("height", 150)
-					// .attr("width", 400)
-					// .attr("fill", "none")
-					// .attr("stroke", "#8888")
-					// .attr("stroke-width", 3)
-				// legend.append("text")
-					// .attr("transform", "translate(-20,24)")
-					// .attr("font-family","Arial")
-					// .attr("font-size","16pt")
-					// .attr("font-weight",700)
-					// .attr("fill","black")
-					// .text("Legend")
-				// legend.append("line")
-					// .attr("x1", -20)
-					// .attr("y1", 50)
-					// .attr("x2", 20)
-					// .attr("y2", 50)
-					// .style("stroke", "#CC0000")
-					// .style("stroke-width", 5);
-				// legend.append("line")
-					// .attr("x1", -20)
-					// .attr("y1", 90)
-					// .attr("x2", 20)
-					// .attr("y2", 90)
-					// .style("stroke", "#99CC00")
-					// .style("stroke-width", 5);
-				// legend.append("text")
-					// .attr("transform", "translate(30,56)")
-					// .attr("font-family","Arial")
-					// .attr("font-size","12pt")
-					// .attr("fill","black")
-					// .text("Input")
-				// legend.append("text")
-					// .attr("transform", "translate(30,96)")
-					// .attr("font-family","Arial")
-					// .attr("font-size","12pt")
-					// .attr("fill","black")
-					// .text("Output")
-				
-				//################################################################################################//
-				
-				
-				//d3.select(".legendDiv").moveToBack()
-				d3.select(".dataModelDiv").moveToBack()
-				headerDiv.moveToBack()
-                d3.select(".addButtonDiv").moveToBack()
-				d3.select(".navigationBarDiv").moveToBack()
-				d3.select(".visPackDiv").moveToBack()
-				
-				
-				var nodes = cluster.nodes(packageHierarchy(classes));
-				var links = packageImports(nodes);
-				
-				links.forEach(function(d)
-				{
-					d.pipeData_in = d.source.pipeline_data[d.target.name];
-					d.pipeData_out = d.target.pipeline_data[d.source.name];
-					d.pipeDataName_in = "";
-					d.pipeDataName_out = "";
-					if (d.pipeData_in)
-					{
-						for (var i=0; i<d.pipeData_in.length; i++)
-						{
-							d.pipeDataName_in += "," + d.pipeData_in[i];
-						}
-					}
-					if (d.pipeData_out)
-					{
-						for (var i=0; i<d.pipeData_out.length; i++)
-						{
-							d.pipeDataName_out += "," + d.pipeData_out[i];
-						}
-
-					}
-				})
-					
-				link = link
-				  .data(bundle(links))
-				.enter().append("path")
-				  .each(function(d) { 
-					d.source = d[0];
-					d.target = d[d.length - 1];})
-				  .attr("class", "edgeBundlesLink")
-				  .attr("d", line)
-
-				
-				
-				invisibleLink = invisibleLink
-				  .data(bundle(links))
-					.enter().append("path")
-				  .each(function(d) { 
-					d.source = d[0];
-					d.target = d[d.length - 1];
-					d.createNew = true;})
-				  .attr("class", "invisibleLink")
-				  .attr("d", line)
-				  
-					
-				function showLinkTree(aLink,aVarCategory, aCategoryDescr)
-				{
-					var theSchema = currentGraph.variableSchemes[aVarCategory];
-					var name_tmp = "Variable flow: " + aLink.__data__.source.name +  "  →  " + aLink.__data__.target.name + "; Categorization: " + aCategoryDescr;
-					createTreeLayout(name_tmp,theSchema,aLink.__data__,link,nodeMenu);
-				}
-				
-				function showEdgeTable(aLink)
-				{						
-					aLink.pipeData_in = aLink.source.pipeline_data[aLink.target.name];
-					aLink.pipeData_out = aLink.target.pipeline_data[aLink.source.name];
-					aLink.pipeDataName_in = "";
-					aLink.pipeDataName_out = "";
-					aLink.name = "";
-					if (aLink.pipeData_in)
-					{
-						for (var i=0; i<aLink.pipeData_in.length; i++)
-						{
-							if (i==0){aLink.pipeDataName_in += aLink.pipeData_in[i];}
-							else{aLink.pipeDataName_in += "," + aLink.pipeData_in[i];}
-							
-						}
-						aLink.name += aLink.pipeDataName_in
-					}
-					if (aLink.pipeData_out)
-					{
-						for (var i=0; i<aLink.pipeData_out.length; i++)
-						{
-							if (i==0){aLink.pipeDataName_out += aLink.pipeData_out[i];}
-							else{aLink.pipeDataName_out += "," + aLink.pipeData_out[i];}
-						}
-						aLink.name += aLink.pipeDataName_out
-					}
-                    
-                   
-					var headLine = "Edge Information (" + aLink.source.key + " - " + aLink.target.key + ")";					
-					var pipeData_in = aLink.pipeDataName_in;
-					var pipeData_out = aLink.pipeDataName_in;
-                    var theLeafNodes_in = JSON.parse(JSON.stringify(currentGraph.variableSchemes[varCategories[0].name]));
-                    var theLeafNodes_out = JSON.parse(JSON.stringify(currentGraph.variableSchemes[varCategories[0].name]));
-					prune_tree(pipeData_in,theLeafNodes_in)
-					prune_tree(pipeData_out,theLeafNodes_out)
-                    
-                    var nullDim_in=false;
-                    var dimension_in=0;
-                    var undefLeafsNumber_in=0;
-					var defLeafsNumber_in=0;
-                    var nullDim_out=false;
-                    var dimension_out=0;
-                    var undefLeafsNumber_out=0;
-					var defLeafsNumber_out=0;
-                    function getUndefinedLeafNodes(theLeafNodes,defLeafsNumber,undefLeafsNumber,dimenson,nullDim)
-                    {
-                        for (var k=0;k<theLeafNodes.length;k++)
-                        {
-                            if (theLeafNodes[k].dimension!=null){dimension = dimension+theLeafNodes[k].dimension}
-                            else{nullDim=true}
-                            if (theLeafNodes[k].value.includes("could not be found")||theLeafNodes[k].value.includes("unknown"))
-                            {
-                                undefLeafsNumber ++;
-                            }
-                            else
-                            {
-                                defLeafsNumber++;
-                            }
-                        }		
-                    }
-                    getUndefinedLeafNodes(theLeafNodes_in,defLeafsNumber_in,undefLeafsNumber_in,dimension_in,nullDim_in)
-                    getUndefinedLeafNodes(theLeafNodes_out,defLeafsNumber_out,undefLeafsNumber_out,dimension_out,nullDim_out)
-					//Render data for table
-					var data = [];
-					data.push({ "name" : "Total number of connections", "value" : aLink.pipeDataName_in.split(",").length+aLink.pipeDataName_out.split(",").length })
-					
-                    data.push({ "name" : "Total number of incoming connections", "value" : aLink.pipeDataName_in.split(",").length })
-                    data.push({ "name" : "Number of referenced incoming connections", "value" : defLeafsNumber_in })
-                    data.push({ "name" : "Dimension of referenced outgoing connections", "value" : String(dimension_in) })
-					if (undefLeafsNumber_in>0)
-					{
-						data.push({ "name" : "Number of unreferenced incoming connections", "value" :  undefLeafsNumber_in})					
-					}
-					
-                    data.push({ "name" : "Total number of outgoing connections", "value" : aLink.pipeDataName_out.split(",").length })
-					data.push({ "name" : "Number of referenced outgoing connections", "value" : defLeafsNumber_out })
-                    data.push({ "name" : "Dimension of referenced outgoing connections", "value" : String(dimension_out) })
-                    if (undefLeafsNumber_out>0)
-					{
-						data.push({ "name" : "Number of unreferenced incoming connections", "value" :  undefLeafsNumber_out})					
-					}
-					
-					
-                    var d3_body = d3.select("body");
-                    var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                    panel_div.append("div").attr("class","panel-heading")
-                        .append("div").attr("class","panel_title").append("h4").text(headLine)
-                    var listGroup = panel_div.append("div").attr("class","panel-body")
-                        .append("table").attr("id","myTable")
-                        .append("tbody")
-                        
-                    data.forEach(function(listElement)
-                    {
-                        var row = listGroup.append("tr")
-                        row.append("td").text(listElement.name)
-                        row.append("td").text(listElement.value)
-                        
-                    })
-                    $('.myPanel').lobiPanel({
-                        reload: false,
-                        editTitle: false,
-                        expand: false,
-                        unpin: false,
-                        resize: "none",
-                        minWidth: 200,
-                        minHeight: 200,
-                        maxWidth: 1100,
-                        maxHeight: 1200,
-                    });
-                    $('.myPanel').lobiPanel('unpin');
-				}
-				
-				//linkMenu --> functions for right click options
-				var linkChildrenItemsTree = [];
-				for (var j=0; j< varCategories.length; j++)
-				{
-					linkChildrenItemsTree.push({title: 'according to ' + varCategories[j].description,
-											varCategory: varCategories[j].name,
-											description: varCategories[j].description,
-											onMouseClick: function(elm, data, i) {showLinkTree(elm,data.varCategory,data.description)},
-											onMouseOver: function(elm,data,i){}});
-				}
-                var linkChildrenItemsList = [];
-                for (var j=0; j< varCategories.length; j++)
-                {
-                    linkChildrenItemsList.push({title: 'according to ' + varCategories[j].description,
-                        varCategory: varCategories[j].name,
-                        description: varCategories[j].description,
-                        onMouseClick: function(elm, data, i) {                           
-                            var title = "List view of variable flow: " + elm.__data__.source.id +  "  →  " + elm.__data__.target.id + "; Categorization: " + data.description;
-                            var variables = prepareTreeData(currentGraph.variableSchemes[data.varCategory],elm.__data__)
-                            variables.forEach(function(variable)
-                            {
-                                variable.name = variable.xPath
-                                //work around because nodeMenu expexts the data, to have a "data" object inside
-                                variable.data = variable
-                                variable.data.name = variable.xPath.split("/")[variable.xPath.split("/").length-1]
-                            })
-                            
-                            showList(title,variables,nodeMenu);
-                        },
-                        onMouseOver: function(elm,data,i){}});
-                }
-                
-				var linkMenu = [
-				{
-					title: 'Show edge info',
-					onMouseDown: function(elm, k, i) {
-						showEdgeTable(k)
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: []
-				},
-				{
-					title: 'Show variable tree...',
-					onMouseDown: function(elm, k, i) {
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: linkChildrenItemsTree
-				},
-				{
-					title: 'Show variable list...',
-					onMouseDown: function(elm, k, i) {
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: linkChildrenItemsList
-				}
-				]  
-				invisibleLink.append("svg:title").text("Click right to inspect")
-				invisibleLink
-				.on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-				.on('contextmenu', d3.contextMenu(linkMenu));
-				
-				//aigner: CAUTION, HACK --> delete the obsolete object that contains duplicate information
-				nodes.forEach(function(aNode,i)
-				{
-					if (aNode.children)
-					{
-						var index = nodes.indexOf(aNode);
-						if (index > -1) 
-						{
-							nodes.splice(index, 1);
-						}
-					}
-				});
-				
-				//aigner: Create the nodes in a circular view
-				node = node
-				  .data(nodes)
-				.enter().append("text")
-				  .attr("class", "edgeBundlesNode")
-				  .attr("dy", ".31em")
-				  .attr("transform", function(d) { return "rotate(" + (d.x - 90) + ")translate(" + (d.y + 8) + ",0)" + (d.x < 180 ? "" : "rotate(180)"); })
-				  .style("text-anchor", function(d) { return d.x < 180 ? "start" : "end"; })
-				  .style("font-family","Arial")
-				  .style("font-size","16pt")
-				  .text(function(d) { return d.name; })
-				  .on("mouseover", nodeMouseovered)
-				  .on("mouseout", nodeMouseouted);
-				
-				//aigner: Right click options for tools
-				//##############################################################################################################################
-				//aigner: assign additional node information to nodes coming from xdsm information	
-				var theXDSM = currentGraph.xdsm;
-				nodes.forEach(function(aNode,i)
-				{
-					var xdsmNodes = theXDSM.nodes;
-					for (var i=0; i< xdsmNodes.length; i++)
-					{
-						var xdsmNode = xdsmNodes[i];
-						if (xdsmNode.name == aNode.name)
-						{
-							aNode.id = xdsmNode.id;
-							aNode.metadata = xdsmNode.metadata;
-							aNode.type = xdsmNode.type;
-						}
-					}
-				});		
-				
-				//aigner: Table for competence/tool information
-				//############################################################
-                function showToolTable(aTool)
-                {
-                    var aToolNameSplit = aTool.name.split(': ')			
-                    var headLine;
-                    if (aToolNameSplit.length>1){headLine = "Competence Information: (" + aToolNameSplit[1] + ")";}
-                    else {headLine = "Competence Information: (" + aToolNameSplit[0] + ")";}
-                    
-                    
-                    var data = [];
-                    // render the table(s)
-                    if (aTool.metadata.length==0)
-                    {
-                        data.push({ "name" : "NO TOOL METADATA AVAILABLE", "value" : "..." })
-                    }
-                    function findSubMetaData(aMetaData)
-                    {
-                        for(var key in aMetaData)
-                        {
-                            if (typeof aMetaData[key] === 'object')
-                            {
-                                data.push({ "name" : key, "value" : ''}) ;
-                                findSubMetaData(aMetaData[key]);
-                            }
-                            else
-                            {
-                                data.push({ "name" : key, "value" : aMetaData[key] })
-                            }
-                        }
-                    }
-                    for (var j=0; j < aTool.metadata.length;j++)
-                    {
-                        var metaData = aTool.metadata[j];
-                        findSubMetaData(metaData);						
-                    }
-                
-                    
-                    var d3_body = d3.select("body");
-                    
-                    var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                    panel_div.append("div").attr("class","panel-heading")
-                        .append("div").attr("class","panel_title").append("h4").text(headLine)
-                    var listGroup = panel_div.append("div").attr("class","panel-body")
-                        .append("table").attr("id","myTable")
-                        .append("tbody")
-                        
-                    data.forEach(function(listElement)
-                    {
-                        var row = listGroup.append("tr")
-                        row.append("td").text(listElement.name)
-                        row.append("td").text(listElement.value)
-                        
-                    })
-                    $('.myPanel').lobiPanel({
-                        reload: false,
-                        editTitle: false,
-                        expand: false,
-                        unpin: false,
-                        resize: "none",
-                        minWidth: 200,
-                        minHeight: 200,
-                        maxWidth: 1100,
-                        maxHeight: 1200,
-                    });
-                    $('.myPanel').lobiPanel('unpin');
-                }
-				//############################################################
-				
-				//aigner: Creation of input/output tree
-				//############################################################
-				function showIOTree(categoryName, categoryDescr, theNode, io)
-				{	
-					var links = d3.selectAll(".edgeBundlesLink")[0];
-					var array={name_in:"",name_out:"",name:""};
-					var name_tmp = "";
-								
-					links.forEach(function(d)
-					{	
-						var theLink = d.__data__;
-						
-						
-						var pipeData_in = theLink.source.pipeline_data[theLink.target.name];
-						var pipeData_out = theLink.target.pipeline_data[theLink.source.name];
-						if (!pipeData_in){pipeData_in = [];}
-						if (!pipeData_out){pipeData_out = [];}
-						theLink.pipeData_in = theLink.source.pipeline_data[theLink.target.name];
-						theLink.pipeData_out = theLink.target.pipeline_data[theLink.source.name];
-						theLink.name_in = "";
-						theLink.name_out = "";
-						theLink.name = "";
-						if (theLink.pipeData_in)
-						{
-							for (var i=0; i<theLink.pipeData_in.length; i++)
-							{
-								if (i==0){theLink.name_in += theLink.pipeData_in[i];}
-								else{theLink.name_in += "," + theLink.pipeData_in[i];}
-								
-							}
-							theLink.name += theLink.name_in
-						}
-						if (theLink.pipeData_out)
-						{
-							for (var i=0; i<theLink.pipeData_out.length; i++)
-							{
-								if (i==0){theLink.name_out += theLink.pipeData_out[i];}
-								else{theLink.name_out += "," + theLink.pipeData_out[i];}
-							}
-							theLink.name += theLink.name_out
-						}
-					
-						if (io=="in")
-						{
-							if (theLink.target == theNode)
-							{
-								if (array.name_in == ""){array.name_in +=theLink.name_out;}
-								else{array.name_in += "," + theLink.name_out;}
-								array.name_out = "";
-								array.name = array.name_in;
-							}
-							if (theLink.source == theNode)
-							{
-								if (array.name_in == ""){array.name_in +=theLink.name_in;}
-								else{array.name_in += "," + theLink.name_in;}
-								array.name_out = "";
-								array.name = array.name_in;
-							}
-							name_tmp = "Input tree view: " + theNode.id + "; Categorization: " + categoryDescr;
-						}
-						else if (io=="out")
-						{
-							if (theLink.source == theNode)
-							{
-								if (array.name_out == ""){array.name_out +=theLink.name_out;}
-								else{array.name_out += "," + theLink.name_out;}
-								array.name_in = "";
-								array.name = array.name_out;
-							}
-							if (theLink.target == theNode)
-							{
-								if (array.name_out == ""){array.name_out +=theLink.name_in;}
-								else{array.name_out += "," + theLink.name_in;}
-								array.name_in = "";
-								array.name = array.name_out;
-							}
-							name_tmp = "Output tree view: " + theNode.id + "; Categorization: " + categoryDescr;
-						}
-					})		
-					var theSchema = currentGraph.variableSchemes[categoryName]		
-					createTreeLayout(name_tmp,theSchema,array,link,nodeMenu)
-				}
-				//############################################################
-                
-                //aigner: Creation of input/output list
-				//############################################################
-				function prepareIOList(theNode, io)
-				{	
-					var links = d3.selectAll(".edgeBundlesLink")[0];
-					var array={name_in:"",name_out:"",name:""};
-								
-					links.forEach(function(d)
-					{	
-						var theLink = d.__data__;
-						
-						
-						var pipeData_in = theLink.source.pipeline_data[theLink.target.name];
-						var pipeData_out = theLink.target.pipeline_data[theLink.source.name];
-						if (!pipeData_in){pipeData_in = [];}
-						if (!pipeData_out){pipeData_out = [];}
-						theLink.pipeData_in = theLink.source.pipeline_data[theLink.target.name];
-						theLink.pipeData_out = theLink.target.pipeline_data[theLink.source.name];
-						theLink.name_in = "";
-						theLink.name_out = "";
-						theLink.name = "";
-						if (theLink.pipeData_in)
-						{
-							for (var i=0; i<theLink.pipeData_in.length; i++)
-							{
-								if (i==0){theLink.name_in += theLink.pipeData_in[i];}
-								else{theLink.name_in += "," + theLink.pipeData_in[i];}
-								
-							}
-							theLink.name += theLink.name_in
-						}
-						if (theLink.pipeData_out)
-						{
-							for (var i=0; i<theLink.pipeData_out.length; i++)
-							{
-								if (i==0){theLink.name_out += theLink.pipeData_out[i];}
-								else{theLink.name_out += "," + theLink.pipeData_out[i];}
-							}
-							theLink.name += theLink.name_out
-						}
-					
-						if (io=="in")
-						{
-							if (theLink.target == theNode)
-							{
-								if (array.name_in == ""){array.name_in +=theLink.name_out;}
-								else{array.name_in += "," + theLink.name_out;}
-								array.name_out = "";
-								array.name = array.name_in;
-							}
-							if (theLink.source == theNode)
-							{
-								if (array.name_in == ""){array.name_in +=theLink.name_in;}
-								else{array.name_in += "," + theLink.name_in;}
-								array.name_out = "";
-								array.name = array.name_in;
-							}
-						}
-						else if (io=="out")
-						{
-							if (theLink.source == theNode)
-							{
-								if (array.name_out == ""){array.name_out +=theLink.name_out;}
-								else{array.name_out += "," + theLink.name_out;}
-								array.name_in = "";
-								array.name = array.name_out;
-							}
-							if (theLink.target == theNode)
-							{
-								if (array.name_out == ""){array.name_out +=theLink.name_in;}
-								else{array.name_out += "," + theLink.name_in;}
-								array.name_in = "";
-								array.name = array.name_out;
-							}
-						}
-					})		
-					return array;
-				}
-				//############################################################
-				
-				var inputChildrenitemsTree = [];
-				var outputChildrenitemsTree = [];
-				for (var j=0; j< varCategories.length; j++)
-				{
-					inputChildrenitemsTree.push({title: 'according to ' + varCategories[j].description,
-											 varCategory: varCategories[j].name,
-											 description: varCategories[j].description,
-											 onMouseClick: function(elm, data, i) {showIOTree(data.varCategory,data.description,elm.__data__,"in")},
-											 onMouseOver: function(elm,data,i){}});
-					outputChildrenitemsTree.push({title: 'according to ' + varCategories[j].description,
-											 varCategory: varCategories[j].name,
-											 description: varCategories[j].description,
-											 onMouseClick: function(elm, data, i) {showIOTree(data.varCategory,data.description,elm.__data__,"out")},
-											 onMouseOver: function(elm,data,i){}});
-				}
-                var inputChildrenitemsList = [];
-				var outputChildrenitemsList = [];
-				for (var j=0; j< varCategories.length; j++)
-				{
-					inputChildrenitemsList.push({title: 'according to ' + varCategories[j].description,
-											 varCategory: varCategories[j].name,
-											 description: varCategories[j].description,
-											 onMouseClick: function(elm, data, i) {
-                                                 var array = prepareIOList(elm.__data__,"in")
-                                                 var variables = prepareTreeData(currentGraph.variableSchemes[data.varCategory],array)
-                                                 var title = "List view of all inputs for " + elm.__data__.id + "; Categorization: " + data.description;
-                                                 showList(title,variables,nodeMenu)
-                                             },
-											 onMouseOver: function(elm,data,i){}});
-					outputChildrenitemsList.push({title: 'according to ' + varCategories[j].description,
-											 varCategory: varCategories[j].name,
-											 description: varCategories[j].description,
-											 onMouseClick: function(elm, data, i) {
-                                                var array = prepareIOList(elm.__data__,"out")
-                                                var variables = prepareTreeData(currentGraph.variableSchemes[data.varCategory],array)
-                                                var title = "List view of all outputs from " + elm.__data__.id + "; Categorization: " + data.description;
-                                                showList(title,variables,nodeMenu)
-                                             },
-											 onMouseOver: function(elm,data,i){}});
-				}
-				//menu --> functions for right click options
-				var toolMenu = [
-				{
-					title: 'Show competence info',
-					onMouseDown: function(elm, k, i) {
-						showToolTable(k);
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: []
-				},
-				{
-					title: 'Show input variable tree...',
-					onMouseDown: function(elm, k, i) {
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: inputChildrenitemsTree
-				},
-				{
-					title: 'Show output variable tree...',
-					onMouseDown: function(elm, k, i) {
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: outputChildrenitemsTree
-				},
-				{
-					title: 'Show input variable list...',
-					onMouseDown: function(elm, k, i) {
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: inputChildrenitemsList
-				},
-				{
-					title: 'Show output variable list...',
-					onMouseDown: function(elm, k, i) {
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: outputChildrenitemsList
-				}
-				]
-				
-				node.on('contextmenu', d3.contextMenu(toolMenu));
-				//##############################################################################################################################
-			};
-			startEdgeBundles(data,graphID);
-
-			function nodeMouseovered(d) {
-				d3.select(this).append("svg:title").text("Click right to inspect");
-				d3.select(this).style("cursor", "pointer")
-			  node
-				  .each(function(n) { 
-				  n.target = n.source = false; });
-
-			  link
-				  .classed("edgeBundlesLink--target", function(l) { if (l.target === d) return l.source.source = true; })
-				  .classed("edgeBundlesLink--source", function(l) { if (l.source === d) return l.target.target = true; })
-				  .filter(function(l) { return l.target === d || l.source === d; })
-				  .each(function() { this.parentNode.appendChild(this); });
-				  
-			  node
-				  .classed("edgeBundlesNode--target", function(n) { return n.target; })
-				  .classed("edgeBundlesNode--source", function(n) { return n.source; })
-			}
-
-			function nodeMouseouted(d) {
-			  link
-				  .classed("edgeBundlesLink--target", false)
-				  .classed("edgeBundlesLink--source", false);
-
-			  node
-				  .classed("edgeBundlesNode--target", false)
-				  .classed("edgeBundlesNode--source", false);
-			}
-
-			d3.select(self.frameElement).style("height", diameter + "px");
-
-			// Lazily construct the package hierarchy from class names.
-			function packageHierarchy(classes) {
-			  var map = {};
-
-			  function find(name, data) {
-				var node = map[name], i;
-				if (!node) {
-				  node = map[name] = data || {name: name, children: []};
-				  if (name.length) {
-					node.parent = find(name.substring(0, i = name.lastIndexOf("/")));
-					node.parent.children.push(node);
-					node.key = name.substring(i + 1);
-				  }
-				}
-				return node;
-			  }
-
-			  classes.forEach(function(d) {
-				find(d.name, d);
-			  });
-
-			  return map[""];
-			}
-
-			// Return a list of imports for the given array of nodes.
-			function packageImports(nodes) {
-			  var map = {},
-			  map2 = {},
-			  input = [];
-
-			  // Compute a map from name to node.
-			  nodes.forEach(function(d) {
-				map[d.name] = d;
-				map2[d.pipeline_data] = d;
-			  });
-
-			  // For each import, construct a link from the source to target node.
-			  nodes.forEach(function(d) 
-			  {
-				if(d.input)
-				{
-					d.input.forEach(function(i) 
-					{
-						if (map[i])
-						{
-							input.push({source: map[d.name], 
-									target: map[i],
-									pipeline_data: map2[d.pipeline_data]});	
-						}
-					})
-				}
-
-			   });
-			  return input;
-			}
-            
-            
-            function prepareTreeData(aSchema,aLink)
-            {
-                var theLink = aLink;
-				if (aLink.source && aLink.target)
-				{
-					var pipeData_in = theLink.source.pipeline_data[theLink.target.name];
-					var pipeData_out = theLink.target.pipeline_data[theLink.source.name];
-					if (!pipeData_in){pipeData_in = [];}
-					if (!pipeData_out){pipeData_out = [];}
-					theLink.pipeData_in = theLink.source.pipeline_data[theLink.target.name];
-					theLink.pipeData_out = theLink.target.pipeline_data[theLink.source.name];
-					theLink.name_in = "";
-					theLink.name_out = "";
-					theLink.name = "";
-					if (theLink.pipeData_in)
-					{
-						for (var i=0; i<theLink.pipeData_in.length; i++)
-						{
-							if (i==0){theLink.name_in += theLink.pipeData_in[i];}
-							else{theLink.name_in += "," + theLink.pipeData_in[i];}
-							
-						}
-						theLink.name += theLink.name_in
-					}
-					if (theLink.pipeData_out)
-					{
-						for (var i=0; i<theLink.pipeData_out.length; i++)
-						{
-							if (i==0){theLink.name_out += theLink.pipeData_out[i];}
-							else{theLink.name_out += "," + theLink.pipeData_out[i];}
-						}
-						theLink.name += theLink.name_out
-					}
-				}
-                
-                var treeData_in = (JSON.parse(JSON.stringify(aSchema)));				
-                var treeData_out = (JSON.parse(JSON.stringify(aSchema)));				
-                //aigner: Here, the minimalized tree is created!                    
-                //The tree will only be pruned if there is pipeData, such as in an edge or for the input of a tool
-                if (theLink)
-                {
-                    if (theLink.name_in)
-                    {
-                        prune_tree(theLink.name_in, treeData_in, "in");
-                    }
-                    else{treeData_in=[]}
-                    if (theLink.name_out)
-                    {
-                        prune_tree(theLink.name_out, treeData_out, "out");
-                    }
-                    else{treeData_out=[]}
-                }
-                    
-                //build tree layout for vistoms
-                var treeData = treeData_in.concat(treeData_out)
-                
-                return treeData;
-            }
-            
-			function createTreeLayout(theName, schema,aLink,theAllLinks,nodeMenu)
-			{
-                //aigner: Build the tree layout
-                //######################################################################
-				var treeData = prepareTreeData(schema, aLink)
-                var newTree = {};
-                buildTree(newTree, treeData)                    
-                treeData = newTree
-                //######################################################################
-                
-				var width= 1000;
-				var height= 500;
-				var xOffset = 10;
-				var xOffset2 = 100;
-				var canvas = d3.select(".circleSvg");
-				// Calculate total nodes, max label length
-				var totalNodes = 0;
-				var maxLabelLength = 0;
-				// variables for drag/drop
-				var selectedNode = null;
-				var draggingNode = null;
-				// Misc. variables
-				var i = 0;
-				var duration = 500;
-				var root;
-				
-
-				// size of the diagram
-				var viewerWidth = width/3;
-				var viewerHeight = height-50;
-
-				var tree = d3.layout.tree()
-					.size([viewerHeight, viewerWidth])
-
-				// define a d3 diagonal projection for use by the node paths later on.
-				var diagonal = d3.svg.diagonal()
-					.projection(function(d) {
-						return [d.y+xOffset, d.x];
-					});
-
-				// A recursive helper function for performing some setup by walking through all nodes
-
-				function visit(parent, visitFn, childrenFn) {
-					if (!parent) return;
-
-					visitFn(parent);
-
-					var children = childrenFn(parent);
-					if (children) {
-						var count = children.length;
-						for (var i = 0; i < count; i++) {
-							visit(children[i], visitFn, childrenFn);
-						}
-					}
-				}
-
-				// Call visit function to establish maxLabelLength
-				visit(treeData, function(d) {
-					totalNodes++;
-					maxLabelLength = Math.max(d.name.length, maxLabelLength);
-				}, function(d) {
-					return d.children && d.children.length > 0 ? d.children : null;
-				});
-				
-				function getMaxLength(data)
-				{
-					var maxLen=0;;
-					for (var i = 0; i < data.length; i++)
-					{
-						maxLen = Math.max(data[i].name.length, maxLen);
-					}
-					for (var i = 0; i < data.length; i++)
-					{
-						data[i].labelLength = maxLen;
-						if (data[i].children)
-						{getMaxLength(data[i].children);}
-						if (data[i]._children)
-						{getMaxLength(data[i]._children);}
-					}
-					
-				}
-				if(treeData._children)
-				{getMaxLength(treeData._children);}
-				if(treeData.children)
-				{getMaxLength(treeData.children);}
-				treeData.labelLength = treeData.name.length;
-
-				// sort the tree according to the node names
-				function sortTree() {
-					tree.sort(function(a, b) {
-						return b.name.toLowerCase() < a.name.toLowerCase() ? 1 : -1;
-					});
-				}
-				// Sort the tree initially incase the JSON isn't in a sorted order.
-				//sortTree()
-
-
-				// Collapse the node and all it's children
-				function collapse(d) {
-				  if(d.children) {
-					d._children = d.children
-					d._children.forEach(collapse)
-					d.children = null
-				  }
-				}
-				// Collapse the node and all it's children
-				function expand(d) {
-				  if(d._children) {
-					d.children = d._children
-					d.children.forEach(expand)
-					d._children = null
-				  }
-				}
-				// Toggle children on click.
-				function click(d) 
-				{
-					if (d.children) {
-						d._children = d.children;
-						d.children = null;
-					} else 
-					{
-						d.children = d._children;
-						d._children = null;
-					}
-					update(d,theAllLinks);
-				}
-				// Collapse/expand entire tree on double-click
-				function dblclick(d) 
-				{
-					if(d.children) 
-					{
-						collapse(d);
-					}
-					else if(d._children)
-					{
-						expand(d);
-					}
-					update(d,theAllLinks);
-				}	
-
-				
-				
-				//aigner: Here the tree layout is created
-                var d3_body = d3.select("body")
-                var lobiID = String(getRandomInt(0,1000))
-                var divClassName = "treeDiv"+lobiID
-                var treeLayoutdiv = d3_body.append("div").attr("class",divClassName+" panel-default")
-                                                .style("left","200px")
-                                                .style("top","200px")
-                                                .style("position", "absolute")
-                treeLayoutdiv.append("div").attr("class","panel-heading")
-                    .append("div").attr("class","panel_title").append("h4").text(theName)
-                $('.'+divClassName).lobiPanel({
-                    reload: false,
-                    editTitle: false,
-                    unpin: false,
-                    minWidth: 200,
-                    maxWidth: 100000,
-                    minHeight: 200,
-                    maxHeight: 100000,
-                });
-                $('.'+divClassName).lobiPanel('unpin');										
-				var treeLayoutSVG = treeLayoutdiv.append("svg").attr("class","treeLayoutSVG")
-				var treeGroup = treeLayoutSVG.append("g").attr("class","treeGroup").style("position","absolute")
-								.attr("transform", "translate(50,0)");
-				var margin = {top: 20, right: 90, bottom: 20, left: 90},
-							  width = 960 - margin.left - margin.right,
-							  height = 500 - margin.top - margin.bottom;
-
-				// append the svg object to the body of the page
-				// appends a 'group' element to 'svg'
-				// moves the 'group' element to the top left margin
-				var offset_tmp = 60;
-				treeLayoutSVG = treeLayoutSVG.attr("width", width + 1.2*margin.right + margin.left+offset_tmp)
-						 .attr("height", height + margin.top + margin.bottom+offset_tmp);
-				treeLayoutdiv.attr("width", width + 1.2*margin.right + margin.left+offset_tmp)
-						 .attr("height", height + margin.top + margin.bottom+offset_tmp)
-						 .on("mouseover",function(){d3.select(this).style("cursor", "grab")})
-				treeGroup = treeGroup
-					.attr("width", width + margin.right + margin.left)
-					.attr("height", height + margin.top + margin.bottom);
-					
-				
-				
-				var frame = treeGroup.append("rect")
-					.attr("class","treeFrame")
-					.attr("stroke-width", 1)
-					.attr("stroke", "white")
-					.attr("fill-opacity", .8);				
-				
-				
-				// Define the root
-				root = treeData;
-				root.x0 = 0;
-				root.y0 = 0;
-				
-				// Append a group which holds all nodes and which the zoom Listener can act upon.
-				var svgGroup_xOff = root.name.length*10+50
-				var svgGroup = treeGroup.append("g")
-					.attr("class","tree_"+theName)
-					.attr("transform", "translate("+ svgGroup_xOff + "," + String(margin.top+10) + ")");
-				
-				collapse(root);
-				update(root,theAllLinks);
-			
-				
-				function update(source,allLinks) {
-					// Compute the new height, function counts total children of root node and sets tree height accordingly.
-					// This prevents the layout looking squashed when new nodes are made visible or looking sparse when nodes are removed
-					// This makes the layout more consistent.
-					var levelWidth = [1];
-					var levelLength = [1];
-					var childCount = function(level, n) {
-
-						if (n.children && n.children.length > 0) {
-							if (levelWidth.length <= level + 1) levelWidth.push(0);
-							
-							levelWidth[level + 1] += n.children.length;
-							n.children.forEach(function(d) {
-								childCount(level + 1, d);
-							});
-						}
-					};
-					childCount(0, root);
-
-					var newHeight = d3.max(levelWidth) * 60; // 20 pixels per line
-					var newWidth = viewerWidth+300;
-					
-					//BENNI: fill in viewerHeight instead of newHeight for other expanding/collapsing beaviour
-					tree = tree.size([newHeight, newWidth]);
-					
-					frame = frame.attr("width",newWidth)
-						.attr("height",newHeight+60)
-						.attr("fill","white");
-						
-					
-					
-					// Compute the new tree layout.
-					var nodes = tree.nodes(root),
-						links = tree.links(nodes);
-						
-						
-					//aigner: count all descendants of a node
-					function countDescendants(node, counter) 
-					{
-						if (node._children)
-						{
-							node._children.forEach(function(n)
-							{
-								counter = countDescendants(n, counter);
-							});
-						}
-						else if (node.children)
-						{
-							node.children.forEach(function(n)
-							{
-								counter = countDescendants(n, counter);
-							});
-						}
-						else
-						{
-							counter ++;
-						}
-						return counter;
-					}
-					
-					
-					var depths = [];
-					var labelLength = [];
-					nodes.forEach(function(d) 
-					{				
-						//aigner: If node is collapsed show number of ancestors
-						if (d._children)
-						{
-							d._childrenNum = countDescendants(d, 0);
-							d.text = d.name + " (" + d._childrenNum + ")";
-						}
-						else 
-						{
-							d.text = d.name
-						}
-						
-						//aigner: Find maximum labelLength for each level
-						if (!depths.includes(d.depth))
-						{
-							depths.push(d.depth);
-							labelLength.push(d.text.length);
-						}
-						else
-						{
-							if (d.depth!=0){labelLength[depths.indexOf(d.depth)] = Math.max(d.text.length, labelLength[depths.indexOf(d.depth)]);}
-						}
-					});
-					// Set widths between levels based on labelLength of each level.
-					var newWidth=0;	
-					var depth_tmp = 0;			
-					nodes.forEach(function(d) 
-					{
-						if (d.parent)
-						{
-							d.y = d.parent.y+(labelLength[depths.indexOf(d.depth)])*10+50;
-						}
-						else{d.y=0}
-						
-						
-						if (newWidth<d.y)
-						{newWidth=d.y;}
-						
-						// console.log("##############")
-						// console.log(d.name)
-						// console.log("x = " + d.x)
-						// console.log("y = " + d.y)
-						// console.log("depth = " + depths.indexOf(d.depth))
-						// console.log("##############")
-					});	
-					
-					
-					newWidth=Math.max(newWidth,getTextWidth(theName,"Arial 12pt"));					
-					//aigner: Adjust height and width of the frame
-					$('.'+divClassName).lobiPanel('setWidth', newWidth + margin.top + margin.bottom +400+maxLabelLength*25+offset_tmp);
-                    $('.'+divClassName).lobiPanel('setHeight', newHeight + margin.top + 2*margin.bottom+offset_tmp);
-					treeLayoutSVG = treeLayoutSVG.attr("height", newHeight + margin.top + margin.bottom+offset_tmp)
-					treeLayoutSVG = treeLayoutSVG.attr("width", newWidth + margin.top + margin.bottom +300+maxLabelLength*25+offset_tmp)
-					frame = frame.attr("height", newHeight + margin.top + margin.bottom)
-					frame = frame.attr("width", newWidth + margin.top + margin.bottom+300+maxLabelLength*15)
-
-
-					// Update the nodes…
-					var treeNode = svgGroup.selectAll("g.treeNode")
-						.data(nodes, function(d) {
-							return d.id || (d.id = ++i);
-						});
-
-					var dblclick_timer = false;
-					// Enter any new nodes at the parent's previous position.
-					var nodeEnter = treeNode.enter().append('g')
-					  .attr('class', 'treeNode')
-					  .attr("transform", function(d) {
-						return "translate(" + source.y0 + "," + source.x0 + ")";
-					})
-					.on("mousedown", function(d) {
-						if (d3.event.which != 3)
-						{
-							// if double click timer is active, this click is the double click
-							if ( dblclick_timer )
-							{
-								clearTimeout(dblclick_timer)
-								dblclick_timer = false
-								// double click code code comes here
-								//console.log("DOUBLE CLICK")
-								dblclick(d);
-							}
-							// otherwise, what to do after single click (double click has timed out)
-							else dblclick_timer = setTimeout( function(){
-								dblclick_timer = false
-								// single click code code comes here
-								//console.log("SINGLE CLICK")
-								click(d);
-							}, 250)
-						}
-					})
-						
-					
-					nodeEnter.append("circle")
-						.attr('class', 'nodeCircle')
-						.attr("r", 0)
-						.style("fill", function(d) {
-							if (d._children)
-							{
-								if(d.pipeLineIn && !d.pipeLineOut){return '#ea9999'}
-								else if(!d.pipeLineIn && d.pipeLineOut){return '#d6ea99'}
-								else {return "lightsteelblue"}
-							}
-							else{return "#fff";}
-						})		
-						.style("stroke", function(d) {
-							if(d.pipeLineIn && !d.pipeLineOut){
-								//console.log(d);
-								return '#CC0000'}
-							else if(!d.pipeLineIn && d.pipeLineOut){
-								//console.log(d);
-								return '#99CC00'}
-						})
-						.attr("cx", function(d) {return xOffset});
-
-					nodeEnter.append("text")
-						.attr("x", function(d) 
-						{
-								return d.children || d._children ? -10+xOffset : 10+xOffset;
-						})
-						.attr("dy", ".35em")
-						.attr('class', 'nodeText')
-						.attr("text-anchor", function(d) {
-							return d.children || d._children ? "end" : "start";
-						})
-						.text(function(d) {
-							return d.text;
-						})
-						.style("fill-opacity", 0)
-						
-
-					// Update the text to reflect whether node has children or not.
-					treeNode.select('text')
-						.attr("x", function(d) {
-							return d.children || d._children ? -10+xOffset : 10+xOffset;
-						})
-						.attr("text-anchor", function(d) {
-							return d.children || d._children ? "end" : "start";
-						})
-						.text(function(d) {
-							return d.text;
-						});
-
-					// Change the circle fill depending on whether it has children and is collapsed
-					treeNode.select("circle.nodeCircle")
-						.attr("r", 4.5)
-						.style("fill", function(d) {
-							if (d._children)
-							{
-								if(d.pipeLineIn && !d.pipeLineOut){return '#ea9999'}
-								else if(!d.pipeLineIn && d.pipeLineOut){return '#d6ea99'}
-								else {return "lightsteelblue"}
-							}
-							else{return "#fff";}
-						})			
-					
-                    var nodeTreeMenu = nodeMenu;
-                    var treeMenu = [
-                    {
-						title: 'Download full tree as XML-file',
-						onMouseDown: function(elm, d, i) {
-							//Begin xml structure with the first element
-							var xmlString = "<"+nodes[0].name+">"+"</"+nodes[0].name+">";
-							//Create a new xml document
-							var parser = new DOMParser();
-							var xmlDocument = parser.parseFromString(xmlString, "text/xml"); //important to use "text/xml"
-							//Get initial xPath of the tree and pass it to the function "writeTreeToXML"
-							var initialXPath = "/"+nodes[0].name;								
-							writeTreeToXML(nodes[0],xmlDocument,initialXPath);
-							//remove all attributes dummyID
-							removeAttributeInAllElements(xmlDocument,'dummyID');
-							//Make the xml document a string
-							var serializer = new XMLSerializer();
-							var xmlString = serializer.serializeToString(xmlDocument);
-							xmlString = vkbeautify.xml(xmlString);														
-							//Download a document with the xml-schema
-							download(theName+'_full.xml',xmlString);						
-						},
-						onMouseUp: function(elm, d, i) {
-						},
-						onMouseOver: function(elm, d, i) {
-						},
-						childrenItems: []
-					},
-					{
-						title: 'Download tree as XML-file from current node',
-						onMouseDown: function(elm, d, i) {
-							var xmlString = putAncestorsInXMLString({ val : '' }, d).val;
-							var initialXPath = putAncestorsInXPath({ val : '' }, d).val;												
-							//Create a new xml document
-							var parser = new DOMParser();
-							var xmlDocument = parser.parseFromString(xmlString, "text/xml"); //important to use "text/xml"
-							//Get initial xPath of the tree and pass it to the function "writeCurrentTreeToXML"
-							writeTreeToXML(d,xmlDocument,initialXPath);
-							//remove all attributes dummyID
-							removeAttributeInAllElements(xmlDocument,'dummyID');
-							//Make the xml document a string
-							var serializer = new XMLSerializer();
-							xmlString = serializer.serializeToString(xmlDocument);
-							xmlString = vkbeautify.xml(xmlString);														
-							//Download a document with the xml-schema
-							download(theName+"_"+d.name+'.xml',xmlString);						
-						},
-						onMouseUp: function(elm, d, i) {
-						},
-						onMouseOver: function(elm, d, i) {
-						},
-						childrenItems: []
-					}
-					]
-                    var nodeTreeMenu = nodeMenu.concat(treeMenu)
-					
-					nodeEnter.append("svg:title").text("Click left to expand, click right to inspect")
-					
-					nodeEnter = nodeEnter.on('contextmenu', d3.contextMenu(nodeTreeMenu));
-								
-					// UPDATE		
-					// Transition nodes to their new position.
-					var nodeUpdate = treeNode.transition()
-						.duration(duration)
-						.attr("transform", function(d) {
-							return "translate(" + d.y + "," + d.x + ")";
-						});
-
-					// Fade the text in
-					nodeUpdate.select("text")
-						.style("fill-opacity", 1);
-					
-					//New object for invisible nodes
-					var exitNodes = [];
-					
-					// Remove any exiting nodes
-					var nodeExit = treeNode.exit().transition()
-					  .duration(duration)
-					  .attr("transform", function(d) {
-						  return "translate(" + source.y + "," + source.x + ")";
-					  })
-					  .remove();
-					
-					function translation(d) 
-					{
-						
-						var closestAncestor;
-						closestAncestor = findClosestAncestor(nodes,d);
-						exitNodes.push(d);
-						exitNodes[exitNodes.length-1].x = closestAncestor.x;
-						exitNodes[exitNodes.length-1].y = closestAncestor.y;
-						return "translate(" + closestAncestor.y + "," + closestAncestor.x + ")";
-					}
-					
-					function findClosestAncestor(allNodes, element) 
-					{
-						var level = 0;
-						var closestAncestor;
-						for (var i=0;i<allNodes.length;i++)
-						{
-							if (!allNodes[i].level){allNodes[i].level=0};
-							if (isDescendant(allNodes[i],element) && allNodes[i].level >= level)
-							{
-								level = allNodes[i].level;
-								closestAncestor = allNodes[i];
-							}
-						}
-						return closestAncestor;
-					}
-					
-					function isDescendant(parent, child) 
-					{
-						 var node = child.parent;
-						 while (node != null) 
-						 {
-							if (node == parent) 
-							{
-								return true;
-							}
-							node = node.parent;
-						 }
-						 return false;
-					}
-				
-
-					// Update the links…
-					var link = svgGroup.selectAll("path.treeLink")
-						.data(links, function(d) {
-							return d.target.id;
-						});
-
-					// Enter any new links at the parent's previous position.
-					link.enter().insert("path", "g")
-						.attr("class", "treeLink")
-						.attr("d", function(d) {
-							var o = {
-								x: source.x0,
-								y: source.y0
-							};
-							return diagonal({
-								source: o,
-								target: o
-							});
-						});
-
-					// Transition links to their new position.
-					link.transition()
-						.duration(duration)
-						.attr("d", diagonal);
-
-					// Transition exiting nodes to the parent's new position.
-					link.exit().transition()
-						.duration(duration)
-						.attr("d", function(d) {
-							var o = {
-								x: source.x,
-								y: source.y
-							};
-							return diagonal({
-								source: o,
-								target: o
-							});
-						})
-						.remove();
-					
-					// Stash the old positions for transition.
-					nodes.forEach(function(d) {						
-						d.x0 = d.x;
-						d.y0 = d.y;
-					});
-				}
-			}
-
-			},{"d3":1}]},{},[2]);
-		}
-		
-		function sankeyDiagram_script(data, graphID)
-		{
-			(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
-			!function(){function n(n){return n&&(n.ownerDocument||n.document||n).documentElement}function t(n){return n&&(n.ownerDocument&&n.ownerDocument.defaultView||n.document&&n||n.defaultView)}function e(n,t){return t>n?-1:n>t?1:n>=t?0:NaN}function r(n){return null===n?NaN:+n}function i(n){return!isNaN(n)}function u(n){return{left:function(t,e,r,i){for(arguments.length<3&&(r=0),arguments.length<4&&(i=t.length);i>r;){var u=r+i>>>1;n(t[u],e)<0?r=u+1:i=u}return r},right:function(t,e,r,i){for(arguments.length<3&&(r=0),arguments.length<4&&(i=t.length);i>r;){var u=r+i>>>1;n(t[u],e)>0?i=u:r=u+1}return r}}}function o(n){return n.length}function a(n){for(var t=1;n*t%1;)t*=10;return t}function l(n,t){for(var e in t)Object.defineProperty(n.prototype,e,{value:t[e],enumerable:!1})}function c(){this._=Object.create(null)}function f(n){return(n+="")===bo||n[0]===_o?_o+n:n}function s(n){return(n+="")[0]===_o?n.slice(1):n}function h(n){return f(n)in this._}function p(n){return(n=f(n))in this._&&delete this._[n]}function g(){var n=[];for(var t in this._)n.push(s(t));return n}function v(){var n=0;for(var t in this._)++n;return n}function d(){for(var n in this._)return!1;return!0}function y(){this._=Object.create(null)}function m(n){return n}function M(n,t,e){return function(){var r=e.apply(t,arguments);return r===t?n:r}}function x(n,t){if(t in n)return t;t=t.charAt(0).toUpperCase()+t.slice(1);for(var e=0,r=wo.length;r>e;++e){var i=wo[e]+t;if(i in n)return i}}function b(){}function _(){}function w(n){function t(){for(var t,r=e,i=-1,u=r.length;++i<u;)(t=r[i].on)&&t.apply(this,arguments);return n}var e=[],r=new c;return t.on=function(t,i){var u,o=r.get(t);return arguments.length<2?o&&o.on:(o&&(o.on=null,e=e.slice(0,u=e.indexOf(o)).concat(e.slice(u+1)),r.remove(t)),i&&e.push(r.set(t,{on:i})),n)},t}function S(){ao.event.preventDefault()}function k(){for(var n,t=ao.event;n=t.sourceEvent;)t=n;return t}function N(n){for(var t=new _,e=0,r=arguments.length;++e<r;)t[arguments[e]]=w(t);return t.of=function(e,r){return function(i){try{var u=i.sourceEvent=ao.event;i.target=n,ao.event=i,t[i.type].apply(e,r)}finally{ao.event=u}}},t}function E(n){return ko(n,Co),n}function A(n){return"function"==typeof n?n:function(){return No(n,this)}}function C(n){return"function"==typeof n?n:function(){return Eo(n,this)}}function z(n,t){function e(){this.removeAttribute(n)}function r(){this.removeAttributeNS(n.space,n.local)}function i(){this.setAttribute(n,t)}function u(){this.setAttributeNS(n.space,n.local,t)}function o(){var e=t.apply(this,arguments);null==e?this.removeAttribute(n):this.setAttribute(n,e)}function a(){var e=t.apply(this,arguments);null==e?this.removeAttributeNS(n.space,n.local):this.setAttributeNS(n.space,n.local,e)}return n=ao.ns.qualify(n),null==t?n.local?r:e:"function"==typeof t?n.local?a:o:n.local?u:i}function L(n){return n.trim().replace(/\s+/g," ")}function q(n){return new RegExp("(?:^|\\s+)"+ao.requote(n)+"(?:\\s+|$)","g")}function T(n){return(n+"").trim().split(/^|\s+/)}function R(n,t){function e(){for(var e=-1;++e<i;)n[e](this,t)}function r(){for(var e=-1,r=t.apply(this,arguments);++e<i;)n[e](this,r)}n=T(n).map(D);var i=n.length;return"function"==typeof t?r:e}function D(n){var t=q(n);return function(e,r){if(i=e.classList)return r?i.add(n):i.remove(n);var i=e.getAttribute("class")||"";r?(t.lastIndex=0,t.test(i)||e.setAttribute("class",L(i+" "+n))):e.setAttribute("class",L(i.replace(t," ")))}}function P(n,t,e){function r(){this.style.removeProperty(n)}function i(){this.style.setProperty(n,t,e)}function u(){var r=t.apply(this,arguments);null==r?this.style.removeProperty(n):this.style.setProperty(n,r,e)}return null==t?r:"function"==typeof t?u:i}function U(n,t){function e(){delete this[n]}function r(){this[n]=t}function i(){var e=t.apply(this,arguments);null==e?delete this[n]:this[n]=e}return null==t?e:"function"==typeof t?i:r}function j(n){function t(){var t=this.ownerDocument,e=this.namespaceURI;return e===zo&&t.documentElement.namespaceURI===zo?t.createElement(n):t.createElementNS(e,n)}function e(){return this.ownerDocument.createElementNS(n.space,n.local)}return"function"==typeof n?n:(n=ao.ns.qualify(n)).local?e:t}function F(){var n=this.parentNode;n&&n.removeChild(this)}function H(n){return{__data__:n}}function O(n){return function(){return Ao(this,n)}}function I(n){return arguments.length||(n=e),function(t,e){return t&&e?n(t.__data__,e.__data__):!t-!e}}function Y(n,t){for(var e=0,r=n.length;r>e;e++)for(var i,u=n[e],o=0,a=u.length;a>o;o++)(i=u[o])&&t(i,o,e);return n}function Z(n){return ko(n,qo),n}function V(n){var t,e;return function(r,i,u){var o,a=n[u].update,l=a.length;for(u!=e&&(e=u,t=0),i>=t&&(t=i+1);!(o=a[t])&&++t<l;);return o}}function X(n,t,e){function r(){var t=this[o];t&&(this.removeEventListener(n,t,t.$),delete this[o])}function i(){var i=l(t,co(arguments));r.call(this),this.addEventListener(n,this[o]=i,i.$=e),i._=t}function u(){var t,e=new RegExp("^__on([^.]+)"+ao.requote(n)+"$");for(var r in this)if(t=r.match(e)){var i=this[r];this.removeEventListener(t[1],i,i.$),delete this[r]}}var o="__on"+n,a=n.indexOf("."),l=$;a>0&&(n=n.slice(0,a));var c=To.get(n);return c&&(n=c,l=B),a?t?i:r:t?b:u}function $(n,t){return function(e){var r=ao.event;ao.event=e,t[0]=this.__data__;try{n.apply(this,t)}finally{ao.event=r}}}function B(n,t){var e=$(n,t);return function(n){var t=this,r=n.relatedTarget;r&&(r===t||8&r.compareDocumentPosition(t))||e.call(t,n)}}function W(e){var r=".dragsuppress-"+ ++Do,i="click"+r,u=ao.select(t(e)).on("touchmove"+r,S).on("dragstart"+r,S).on("selectstart"+r,S);if(null==Ro&&(Ro="onselectstart"in e?!1:x(e.style,"userSelect")),Ro){var o=n(e).style,a=o[Ro];o[Ro]="none"}return function(n){if(u.on(r,null),Ro&&(o[Ro]=a),n){var t=function(){u.on(i,null)};u.on(i,function(){S(),t()},!0),setTimeout(t,0)}}}function J(n,e){e.changedTouches&&(e=e.changedTouches[0]);var r=n.ownerSVGElement||n;if(r.createSVGPoint){var i=r.createSVGPoint();if(0>Po){var u=t(n);if(u.scrollX||u.scrollY){r=ao.select("body").append("svg").style({position:"absolute",top:0,left:0,margin:0,padding:0,border:"none"},"important");var o=r[0][0].getScreenCTM();Po=!(o.f||o.e),r.remove()}}return Po?(i.x=e.pageX,i.y=e.pageY):(i.x=e.clientX,i.y=e.clientY),i=i.matrixTransform(n.getScreenCTM().inverse()),[i.x,i.y]}var a=n.getBoundingClientRect();return[e.clientX-a.left-n.clientLeft,e.clientY-a.top-n.clientTop]}function G(){return ao.event.changedTouches[0].identifier}function K(n){return n>0?1:0>n?-1:0}function Q(n,t,e){return(t[0]-n[0])*(e[1]-n[1])-(t[1]-n[1])*(e[0]-n[0])}function nn(n){return n>1?0:-1>n?Fo:Math.acos(n)}function tn(n){return n>1?Io:-1>n?-Io:Math.asin(n)}function en(n){return((n=Math.exp(n))-1/n)/2}function rn(n){return((n=Math.exp(n))+1/n)/2}function un(n){return((n=Math.exp(2*n))-1)/(n+1)}function on(n){return(n=Math.sin(n/2))*n}function an(){}function ln(n,t,e){return this instanceof ln?(this.h=+n,this.s=+t,void(this.l=+e)):arguments.length<2?n instanceof ln?new ln(n.h,n.s,n.l):_n(""+n,wn,ln):new ln(n,t,e)}function cn(n,t,e){function r(n){return n>360?n-=360:0>n&&(n+=360),60>n?u+(o-u)*n/60:180>n?o:240>n?u+(o-u)*(240-n)/60:u}function i(n){return Math.round(255*r(n))}var u,o;return n=isNaN(n)?0:(n%=360)<0?n+360:n,t=isNaN(t)?0:0>t?0:t>1?1:t,e=0>e?0:e>1?1:e,o=.5>=e?e*(1+t):e+t-e*t,u=2*e-o,new mn(i(n+120),i(n),i(n-120))}function fn(n,t,e){return this instanceof fn?(this.h=+n,this.c=+t,void(this.l=+e)):arguments.length<2?n instanceof fn?new fn(n.h,n.c,n.l):n instanceof hn?gn(n.l,n.a,n.b):gn((n=Sn((n=ao.rgb(n)).r,n.g,n.b)).l,n.a,n.b):new fn(n,t,e)}function sn(n,t,e){return isNaN(n)&&(n=0),isNaN(t)&&(t=0),new hn(e,Math.cos(n*=Yo)*t,Math.sin(n)*t)}function hn(n,t,e){return this instanceof hn?(this.l=+n,this.a=+t,void(this.b=+e)):arguments.length<2?n instanceof hn?new hn(n.l,n.a,n.b):n instanceof fn?sn(n.h,n.c,n.l):Sn((n=mn(n)).r,n.g,n.b):new hn(n,t,e)}function pn(n,t,e){var r=(n+16)/116,i=r+t/500,u=r-e/200;return i=vn(i)*na,r=vn(r)*ta,u=vn(u)*ea,new mn(yn(3.2404542*i-1.5371385*r-.4985314*u),yn(-.969266*i+1.8760108*r+.041556*u),yn(.0556434*i-.2040259*r+1.0572252*u))}function gn(n,t,e){return n>0?new fn(Math.atan2(e,t)*Zo,Math.sqrt(t*t+e*e),n):new fn(NaN,NaN,n)}function vn(n){return n>.206893034?n*n*n:(n-4/29)/7.787037}function dn(n){return n>.008856?Math.pow(n,1/3):7.787037*n+4/29}function yn(n){return Math.round(255*(.00304>=n?12.92*n:1.055*Math.pow(n,1/2.4)-.055))}function mn(n,t,e){return this instanceof mn?(this.r=~~n,this.g=~~t,void(this.b=~~e)):arguments.length<2?n instanceof mn?new mn(n.r,n.g,n.b):_n(""+n,mn,cn):new mn(n,t,e)}function Mn(n){return new mn(n>>16,n>>8&255,255&n)}function xn(n){return Mn(n)+""}function bn(n){return 16>n?"0"+Math.max(0,n).toString(16):Math.min(255,n).toString(16)}function _n(n,t,e){var r,i,u,o=0,a=0,l=0;if(r=/([a-z]+)\((.*)\)/.exec(n=n.toLowerCase()))switch(i=r[2].split(","),r[1]){case"hsl":return e(parseFloat(i[0]),parseFloat(i[1])/100,parseFloat(i[2])/100);case"rgb":return t(Nn(i[0]),Nn(i[1]),Nn(i[2]))}return(u=ua.get(n))?t(u.r,u.g,u.b):(null==n||"#"!==n.charAt(0)||isNaN(u=parseInt(n.slice(1),16))||(4===n.length?(o=(3840&u)>>4,o=o>>4|o,a=240&u,a=a>>4|a,l=15&u,l=l<<4|l):7===n.length&&(o=(16711680&u)>>16,a=(65280&u)>>8,l=255&u)),t(o,a,l))}function wn(n,t,e){var r,i,u=Math.min(n/=255,t/=255,e/=255),o=Math.max(n,t,e),a=o-u,l=(o+u)/2;return a?(i=.5>l?a/(o+u):a/(2-o-u),r=n==o?(t-e)/a+(e>t?6:0):t==o?(e-n)/a+2:(n-t)/a+4,r*=60):(r=NaN,i=l>0&&1>l?0:r),new ln(r,i,l)}function Sn(n,t,e){n=kn(n),t=kn(t),e=kn(e);var r=dn((.4124564*n+.3575761*t+.1804375*e)/na),i=dn((.2126729*n+.7151522*t+.072175*e)/ta),u=dn((.0193339*n+.119192*t+.9503041*e)/ea);return hn(116*i-16,500*(r-i),200*(i-u))}function kn(n){return(n/=255)<=.04045?n/12.92:Math.pow((n+.055)/1.055,2.4)}function Nn(n){var t=parseFloat(n);return"%"===n.charAt(n.length-1)?Math.round(2.55*t):t}function En(n){return"function"==typeof n?n:function(){return n}}function An(n){return function(t,e,r){return 2===arguments.length&&"function"==typeof e&&(r=e,e=null),Cn(t,e,n,r)}}function Cn(n,t,e,r){function i(){var n,t=l.status;if(!t&&Ln(l)||t>=200&&300>t||304===t){try{n=e.call(u,l)}catch(r){return void o.error.call(u,r)}o.load.call(u,n)}else o.error.call(u,l)}var u={},o=ao.dispatch("beforesend","progress","load","error"),a={},l=new XMLHttpRequest,c=null;return!this.XDomainRequest||"withCredentials"in l||!/^(http(s)?:)?\/\//.test(n)||(l=new XDomainRequest),"onload"in l?l.onload=l.onerror=i:l.onreadystatechange=function(){l.readyState>3&&i()},l.onprogress=function(n){var t=ao.event;ao.event=n;try{o.progress.call(u,l)}finally{ao.event=t}},u.header=function(n,t){return n=(n+"").toLowerCase(),arguments.length<2?a[n]:(null==t?delete a[n]:a[n]=t+"",u)},u.mimeType=function(n){return arguments.length?(t=null==n?null:n+"",u):t},u.responseType=function(n){return arguments.length?(c=n,u):c},u.response=function(n){return e=n,u},["get","post"].forEach(function(n){u[n]=function(){return u.send.apply(u,[n].concat(co(arguments)))}}),u.send=function(e,r,i){if(2===arguments.length&&"function"==typeof r&&(i=r,r=null),l.open(e,n,!0),null==t||"accept"in a||(a.accept=t+",*/*"),l.setRequestHeader)for(var f in a)l.setRequestHeader(f,a[f]);return null!=t&&l.overrideMimeType&&l.overrideMimeType(t),null!=c&&(l.responseType=c),null!=i&&u.on("error",i).on("load",function(n){i(null,n)}),o.beforesend.call(u,l),l.send(null==r?null:r),u},u.abort=function(){return l.abort(),u},ao.rebind(u,o,"on"),null==r?u:u.get(zn(r))}function zn(n){return 1===n.length?function(t,e){n(null==t?e:null)}:n}function Ln(n){var t=n.responseType;return t&&"text"!==t?n.response:n.responseText}function qn(n,t,e){var r=arguments.length;2>r&&(t=0),3>r&&(e=Date.now());var i=e+t,u={c:n,t:i,n:null};return aa?aa.n=u:oa=u,aa=u,la||(ca=clearTimeout(ca),la=1,fa(Tn)),u}function Tn(){var n=Rn(),t=Dn()-n;t>24?(isFinite(t)&&(clearTimeout(ca),ca=setTimeout(Tn,t)),la=0):(la=1,fa(Tn))}function Rn(){for(var n=Date.now(),t=oa;t;)n>=t.t&&t.c(n-t.t)&&(t.c=null),t=t.n;return n}function Dn(){for(var n,t=oa,e=1/0;t;)t.c?(t.t<e&&(e=t.t),t=(n=t).n):t=n?n.n=t.n:oa=t.n;return aa=n,e}function Pn(n,t){return t-(n?Math.ceil(Math.log(n)/Math.LN10):1)}function Un(n,t){var e=Math.pow(10,3*xo(8-t));return{scale:t>8?function(n){return n/e}:function(n){return n*e},symbol:n}}function jn(n){var t=n.decimal,e=n.thousands,r=n.grouping,i=n.currency,u=r&&e?function(n,t){for(var i=n.length,u=[],o=0,a=r[0],l=0;i>0&&a>0&&(l+a+1>t&&(a=Math.max(1,t-l)),u.push(n.substring(i-=a,i+a)),!((l+=a+1)>t));)a=r[o=(o+1)%r.length];return u.reverse().join(e)}:m;return function(n){var e=ha.exec(n),r=e[1]||" ",o=e[2]||">",a=e[3]||"-",l=e[4]||"",c=e[5],f=+e[6],s=e[7],h=e[8],p=e[9],g=1,v="",d="",y=!1,m=!0;switch(h&&(h=+h.substring(1)),(c||"0"===r&&"="===o)&&(c=r="0",o="="),p){case"n":s=!0,p="g";break;case"%":g=100,d="%",p="f";break;case"p":g=100,d="%",p="r";break;case"b":case"o":case"x":case"X":"#"===l&&(v="0"+p.toLowerCase());case"c":m=!1;case"d":y=!0,h=0;break;case"s":g=-1,p="r"}"$"===l&&(v=i[0],d=i[1]),"r"!=p||h||(p="g"),null!=h&&("g"==p?h=Math.max(1,Math.min(21,h)):"e"!=p&&"f"!=p||(h=Math.max(0,Math.min(20,h)))),p=pa.get(p)||Fn;var M=c&&s;return function(n){var e=d;if(y&&n%1)return"";var i=0>n||0===n&&0>1/n?(n=-n,"-"):"-"===a?"":a;if(0>g){var l=ao.formatPrefix(n,h);n=l.scale(n),e=l.symbol+d}else n*=g;n=p(n,h);var x,b,_=n.lastIndexOf(".");if(0>_){var w=m?n.lastIndexOf("e"):-1;0>w?(x=n,b=""):(x=n.substring(0,w),b=n.substring(w))}else x=n.substring(0,_),b=t+n.substring(_+1);!c&&s&&(x=u(x,1/0));var S=v.length+x.length+b.length+(M?0:i.length),k=f>S?new Array(S=f-S+1).join(r):"";return M&&(x=u(k+x,k.length?f-b.length:1/0)),i+=v,n=x+b,("<"===o?i+n+k:">"===o?k+i+n:"^"===o?k.substring(0,S>>=1)+i+n+k.substring(S):i+(M?n:k+n))+e}}}function Fn(n){return n+""}function Hn(){this._=new Date(arguments.length>1?Date.UTC.apply(this,arguments):arguments[0])}function On(n,t,e){function r(t){var e=n(t),r=u(e,1);return r-t>t-e?e:r}function i(e){return t(e=n(new va(e-1)),1),e}function u(n,e){return t(n=new va(+n),e),n}function o(n,r,u){var o=i(n),a=[];if(u>1)for(;r>o;)e(o)%u||a.push(new Date(+o)),t(o,1);else for(;r>o;)a.push(new Date(+o)),t(o,1);return a}function a(n,t,e){try{va=Hn;var r=new Hn;return r._=n,o(r,t,e)}finally{va=Date}}n.floor=n,n.round=r,n.ceil=i,n.offset=u,n.range=o;var l=n.utc=In(n);return l.floor=l,l.round=In(r),l.ceil=In(i),l.offset=In(u),l.range=a,n}function In(n){return function(t,e){try{va=Hn;var r=new Hn;return r._=t,n(r,e)._}finally{va=Date}}}function Yn(n){function t(n){function t(t){for(var e,i,u,o=[],a=-1,l=0;++a<r;)37===n.charCodeAt(a)&&(o.push(n.slice(l,a)),null!=(i=ya[e=n.charAt(++a)])&&(e=n.charAt(++a)),(u=A[e])&&(e=u(t,null==i?"e"===e?" ":"0":i)),o.push(e),l=a+1);return o.push(n.slice(l,a)),o.join("")}var r=n.length;return t.parse=function(t){var r={y:1900,m:0,d:1,H:0,M:0,S:0,L:0,Z:null},i=e(r,n,t,0);if(i!=t.length)return null;"p"in r&&(r.H=r.H%12+12*r.p);var u=null!=r.Z&&va!==Hn,o=new(u?Hn:va);return"j"in r?o.setFullYear(r.y,0,r.j):"W"in r||"U"in r?("w"in r||(r.w="W"in r?1:0),o.setFullYear(r.y,0,1),o.setFullYear(r.y,0,"W"in r?(r.w+6)%7+7*r.W-(o.getDay()+5)%7:r.w+7*r.U-(o.getDay()+6)%7)):o.setFullYear(r.y,r.m,r.d),o.setHours(r.H+(r.Z/100|0),r.M+r.Z%100,r.S,r.L),u?o._:o},t.toString=function(){return n},t}function e(n,t,e,r){for(var i,u,o,a=0,l=t.length,c=e.length;l>a;){if(r>=c)return-1;if(i=t.charCodeAt(a++),37===i){if(o=t.charAt(a++),u=C[o in ya?t.charAt(a++):o],!u||(r=u(n,e,r))<0)return-1}else if(i!=e.charCodeAt(r++))return-1}return r}function r(n,t,e){_.lastIndex=0;var r=_.exec(t.slice(e));return r?(n.w=w.get(r[0].toLowerCase()),e+r[0].length):-1}function i(n,t,e){x.lastIndex=0;var r=x.exec(t.slice(e));return r?(n.w=b.get(r[0].toLowerCase()),e+r[0].length):-1}function u(n,t,e){N.lastIndex=0;var r=N.exec(t.slice(e));return r?(n.m=E.get(r[0].toLowerCase()),e+r[0].length):-1}function o(n,t,e){S.lastIndex=0;var r=S.exec(t.slice(e));return r?(n.m=k.get(r[0].toLowerCase()),e+r[0].length):-1}function a(n,t,r){return e(n,A.c.toString(),t,r)}function l(n,t,r){return e(n,A.x.toString(),t,r)}function c(n,t,r){return e(n,A.X.toString(),t,r)}function f(n,t,e){var r=M.get(t.slice(e,e+=2).toLowerCase());return null==r?-1:(n.p=r,e)}var s=n.dateTime,h=n.date,p=n.time,g=n.periods,v=n.days,d=n.shortDays,y=n.months,m=n.shortMonths;t.utc=function(n){function e(n){try{va=Hn;var t=new va;return t._=n,r(t)}finally{va=Date}}var r=t(n);return e.parse=function(n){try{va=Hn;var t=r.parse(n);return t&&t._}finally{va=Date}},e.toString=r.toString,e},t.multi=t.utc.multi=ct;var M=ao.map(),x=Vn(v),b=Xn(v),_=Vn(d),w=Xn(d),S=Vn(y),k=Xn(y),N=Vn(m),E=Xn(m);g.forEach(function(n,t){M.set(n.toLowerCase(),t)});var A={a:function(n){return d[n.getDay()]},A:function(n){return v[n.getDay()]},b:function(n){return m[n.getMonth()]},B:function(n){return y[n.getMonth()]},c:t(s),d:function(n,t){return Zn(n.getDate(),t,2)},e:function(n,t){return Zn(n.getDate(),t,2)},H:function(n,t){return Zn(n.getHours(),t,2)},I:function(n,t){return Zn(n.getHours()%12||12,t,2)},j:function(n,t){return Zn(1+ga.dayOfYear(n),t,3)},L:function(n,t){return Zn(n.getMilliseconds(),t,3)},m:function(n,t){return Zn(n.getMonth()+1,t,2)},M:function(n,t){return Zn(n.getMinutes(),t,2)},p:function(n){return g[+(n.getHours()>=12)]},S:function(n,t){return Zn(n.getSeconds(),t,2)},U:function(n,t){return Zn(ga.sundayOfYear(n),t,2)},w:function(n){return n.getDay()},W:function(n,t){return Zn(ga.mondayOfYear(n),t,2)},x:t(h),X:t(p),y:function(n,t){return Zn(n.getFullYear()%100,t,2)},Y:function(n,t){return Zn(n.getFullYear()%1e4,t,4)},Z:at,"%":function(){return"%"}},C={a:r,A:i,b:u,B:o,c:a,d:tt,e:tt,H:rt,I:rt,j:et,L:ot,m:nt,M:it,p:f,S:ut,U:Bn,w:$n,W:Wn,x:l,X:c,y:Gn,Y:Jn,Z:Kn,"%":lt};return t}function Zn(n,t,e){var r=0>n?"-":"",i=(r?-n:n)+"",u=i.length;return r+(e>u?new Array(e-u+1).join(t)+i:i)}function Vn(n){return new RegExp("^(?:"+n.map(ao.requote).join("|")+")","i")}function Xn(n){for(var t=new c,e=-1,r=n.length;++e<r;)t.set(n[e].toLowerCase(),e);return t}function $n(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+1));return r?(n.w=+r[0],e+r[0].length):-1}function Bn(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e));return r?(n.U=+r[0],e+r[0].length):-1}function Wn(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e));return r?(n.W=+r[0],e+r[0].length):-1}function Jn(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+4));return r?(n.y=+r[0],e+r[0].length):-1}function Gn(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.y=Qn(+r[0]),e+r[0].length):-1}function Kn(n,t,e){return/^[+-]\d{4}$/.test(t=t.slice(e,e+5))?(n.Z=-t,e+5):-1}function Qn(n){return n+(n>68?1900:2e3)}function nt(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.m=r[0]-1,e+r[0].length):-1}function tt(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.d=+r[0],e+r[0].length):-1}function et(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+3));return r?(n.j=+r[0],e+r[0].length):-1}function rt(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.H=+r[0],e+r[0].length):-1}function it(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.M=+r[0],e+r[0].length):-1}function ut(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+2));return r?(n.S=+r[0],e+r[0].length):-1}function ot(n,t,e){ma.lastIndex=0;var r=ma.exec(t.slice(e,e+3));return r?(n.L=+r[0],e+r[0].length):-1}function at(n){var t=n.getTimezoneOffset(),e=t>0?"-":"+",r=xo(t)/60|0,i=xo(t)%60;return e+Zn(r,"0",2)+Zn(i,"0",2)}function lt(n,t,e){Ma.lastIndex=0;var r=Ma.exec(t.slice(e,e+1));return r?e+r[0].length:-1}function ct(n){for(var t=n.length,e=-1;++e<t;)n[e][0]=this(n[e][0]);return function(t){for(var e=0,r=n[e];!r[1](t);)r=n[++e];return r[0](t)}}function ft(){}function st(n,t,e){var r=e.s=n+t,i=r-n,u=r-i;e.t=n-u+(t-i)}function ht(n,t){n&&wa.hasOwnProperty(n.type)&&wa[n.type](n,t)}function pt(n,t,e){var r,i=-1,u=n.length-e;for(t.lineStart();++i<u;)r=n[i],t.point(r[0],r[1],r[2]);t.lineEnd()}function gt(n,t){var e=-1,r=n.length;for(t.polygonStart();++e<r;)pt(n[e],t,1);t.polygonEnd()}function vt(){function n(n,t){n*=Yo,t=t*Yo/2+Fo/4;var e=n-r,o=e>=0?1:-1,a=o*e,l=Math.cos(t),c=Math.sin(t),f=u*c,s=i*l+f*Math.cos(a),h=f*o*Math.sin(a);ka.add(Math.atan2(h,s)),r=n,i=l,u=c}var t,e,r,i,u;Na.point=function(o,a){Na.point=n,r=(t=o)*Yo,i=Math.cos(a=(e=a)*Yo/2+Fo/4),u=Math.sin(a)},Na.lineEnd=function(){n(t,e)}}function dt(n){var t=n[0],e=n[1],r=Math.cos(e);return[r*Math.cos(t),r*Math.sin(t),Math.sin(e)]}function yt(n,t){return n[0]*t[0]+n[1]*t[1]+n[2]*t[2]}function mt(n,t){return[n[1]*t[2]-n[2]*t[1],n[2]*t[0]-n[0]*t[2],n[0]*t[1]-n[1]*t[0]]}function Mt(n,t){n[0]+=t[0],n[1]+=t[1],n[2]+=t[2]}function xt(n,t){return[n[0]*t,n[1]*t,n[2]*t]}function bt(n){var t=Math.sqrt(n[0]*n[0]+n[1]*n[1]+n[2]*n[2]);n[0]/=t,n[1]/=t,n[2]/=t}function _t(n){return[Math.atan2(n[1],n[0]),tn(n[2])]}function wt(n,t){return xo(n[0]-t[0])<Uo&&xo(n[1]-t[1])<Uo}function St(n,t){n*=Yo;var e=Math.cos(t*=Yo);kt(e*Math.cos(n),e*Math.sin(n),Math.sin(t))}function kt(n,t,e){++Ea,Ca+=(n-Ca)/Ea,za+=(t-za)/Ea,La+=(e-La)/Ea}function Nt(){function n(n,i){n*=Yo;var u=Math.cos(i*=Yo),o=u*Math.cos(n),a=u*Math.sin(n),l=Math.sin(i),c=Math.atan2(Math.sqrt((c=e*l-r*a)*c+(c=r*o-t*l)*c+(c=t*a-e*o)*c),t*o+e*a+r*l);Aa+=c,qa+=c*(t+(t=o)),Ta+=c*(e+(e=a)),Ra+=c*(r+(r=l)),kt(t,e,r)}var t,e,r;ja.point=function(i,u){i*=Yo;var o=Math.cos(u*=Yo);t=o*Math.cos(i),e=o*Math.sin(i),r=Math.sin(u),ja.point=n,kt(t,e,r)}}function Et(){ja.point=St}function At(){function n(n,t){n*=Yo;var e=Math.cos(t*=Yo),o=e*Math.cos(n),a=e*Math.sin(n),l=Math.sin(t),c=i*l-u*a,f=u*o-r*l,s=r*a-i*o,h=Math.sqrt(c*c+f*f+s*s),p=r*o+i*a+u*l,g=h&&-nn(p)/h,v=Math.atan2(h,p);Da+=g*c,Pa+=g*f,Ua+=g*s,Aa+=v,qa+=v*(r+(r=o)),Ta+=v*(i+(i=a)),Ra+=v*(u+(u=l)),kt(r,i,u)}var t,e,r,i,u;ja.point=function(o,a){t=o,e=a,ja.point=n,o*=Yo;var l=Math.cos(a*=Yo);r=l*Math.cos(o),i=l*Math.sin(o),u=Math.sin(a),kt(r,i,u)},ja.lineEnd=function(){n(t,e),ja.lineEnd=Et,ja.point=St}}function Ct(n,t){function e(e,r){return e=n(e,r),t(e[0],e[1])}return n.invert&&t.invert&&(e.invert=function(e,r){return e=t.invert(e,r),e&&n.invert(e[0],e[1])}),e}function zt(){return!0}function Lt(n,t,e,r,i){var u=[],o=[];if(n.forEach(function(n){if(!((t=n.length-1)<=0)){var t,e=n[0],r=n[t];if(wt(e,r)){i.lineStart();for(var a=0;t>a;++a)i.point((e=n[a])[0],e[1]);return void i.lineEnd()}var l=new Tt(e,n,null,!0),c=new Tt(e,null,l,!1);l.o=c,u.push(l),o.push(c),l=new Tt(r,n,null,!1),c=new Tt(r,null,l,!0),l.o=c,u.push(l),o.push(c)}}),o.sort(t),qt(u),qt(o),u.length){for(var a=0,l=e,c=o.length;c>a;++a)o[a].e=l=!l;for(var f,s,h=u[0];;){for(var p=h,g=!0;p.v;)if((p=p.n)===h)return;f=p.z,i.lineStart();do{if(p.v=p.o.v=!0,p.e){if(g)for(var a=0,c=f.length;c>a;++a)i.point((s=f[a])[0],s[1]);else r(p.x,p.n.x,1,i);p=p.n}else{if(g){f=p.p.z;for(var a=f.length-1;a>=0;--a)i.point((s=f[a])[0],s[1])}else r(p.x,p.p.x,-1,i);p=p.p}p=p.o,f=p.z,g=!g}while(!p.v);i.lineEnd()}}}function qt(n){if(t=n.length){for(var t,e,r=0,i=n[0];++r<t;)i.n=e=n[r],e.p=i,i=e;i.n=e=n[0],e.p=i}}function Tt(n,t,e,r){this.x=n,this.z=t,this.o=e,this.e=r,this.v=!1,this.n=this.p=null}function Rt(n,t,e,r){return function(i,u){function o(t,e){var r=i(t,e);n(t=r[0],e=r[1])&&u.point(t,e)}function a(n,t){var e=i(n,t);d.point(e[0],e[1])}function l(){m.point=a,d.lineStart()}function c(){m.point=o,d.lineEnd()}function f(n,t){v.push([n,t]);var e=i(n,t);x.point(e[0],e[1])}function s(){x.lineStart(),v=[]}function h(){f(v[0][0],v[0][1]),x.lineEnd();var n,t=x.clean(),e=M.buffer(),r=e.length;if(v.pop(),g.push(v),v=null,r)if(1&t){n=e[0];var i,r=n.length-1,o=-1;if(r>0){for(b||(u.polygonStart(),b=!0),u.lineStart();++o<r;)u.point((i=n[o])[0],i[1]);u.lineEnd()}}else r>1&&2&t&&e.push(e.pop().concat(e.shift())),p.push(e.filter(Dt))}var p,g,v,d=t(u),y=i.invert(r[0],r[1]),m={point:o,lineStart:l,lineEnd:c,polygonStart:function(){m.point=f,m.lineStart=s,m.lineEnd=h,p=[],g=[]},polygonEnd:function(){m.point=o,m.lineStart=l,m.lineEnd=c,p=ao.merge(p);var n=Ot(y,g);p.length?(b||(u.polygonStart(),b=!0),Lt(p,Ut,n,e,u)):n&&(b||(u.polygonStart(),b=!0),u.lineStart(),e(null,null,1,u),u.lineEnd()),b&&(u.polygonEnd(),b=!1),p=g=null},sphere:function(){u.polygonStart(),u.lineStart(),e(null,null,1,u),u.lineEnd(),u.polygonEnd()}},M=Pt(),x=t(M),b=!1;return m}}function Dt(n){return n.length>1}function Pt(){var n,t=[];return{lineStart:function(){t.push(n=[])},point:function(t,e){n.push([t,e])},lineEnd:b,buffer:function(){var e=t;return t=[],n=null,e},rejoin:function(){t.length>1&&t.push(t.pop().concat(t.shift()))}}}function Ut(n,t){return((n=n.x)[0]<0?n[1]-Io-Uo:Io-n[1])-((t=t.x)[0]<0?t[1]-Io-Uo:Io-t[1])}function jt(n){var t,e=NaN,r=NaN,i=NaN;return{lineStart:function(){n.lineStart(),t=1},point:function(u,o){var a=u>0?Fo:-Fo,l=xo(u-e);xo(l-Fo)<Uo?(n.point(e,r=(r+o)/2>0?Io:-Io),n.point(i,r),n.lineEnd(),n.lineStart(),n.point(a,r),n.point(u,r),t=0):i!==a&&l>=Fo&&(xo(e-i)<Uo&&(e-=i*Uo),xo(u-a)<Uo&&(u-=a*Uo),r=Ft(e,r,u,o),n.point(i,r),n.lineEnd(),n.lineStart(),n.point(a,r),t=0),n.point(e=u,r=o),i=a},lineEnd:function(){n.lineEnd(),e=r=NaN},clean:function(){return 2-t}}}function Ft(n,t,e,r){var i,u,o=Math.sin(n-e);return xo(o)>Uo?Math.atan((Math.sin(t)*(u=Math.cos(r))*Math.sin(e)-Math.sin(r)*(i=Math.cos(t))*Math.sin(n))/(i*u*o)):(t+r)/2}function Ht(n,t,e,r){var i;if(null==n)i=e*Io,r.point(-Fo,i),r.point(0,i),r.point(Fo,i),r.point(Fo,0),r.point(Fo,-i),r.point(0,-i),r.point(-Fo,-i),r.point(-Fo,0),r.point(-Fo,i);else if(xo(n[0]-t[0])>Uo){var u=n[0]<t[0]?Fo:-Fo;i=e*u/2,r.point(-u,i),r.point(0,i),r.point(u,i)}else r.point(t[0],t[1])}function Ot(n,t){var e=n[0],r=n[1],i=[Math.sin(e),-Math.cos(e),0],u=0,o=0;ka.reset();for(var a=0,l=t.length;l>a;++a){var c=t[a],f=c.length;if(f)for(var s=c[0],h=s[0],p=s[1]/2+Fo/4,g=Math.sin(p),v=Math.cos(p),d=1;;){d===f&&(d=0),n=c[d];var y=n[0],m=n[1]/2+Fo/4,M=Math.sin(m),x=Math.cos(m),b=y-h,_=b>=0?1:-1,w=_*b,S=w>Fo,k=g*M;if(ka.add(Math.atan2(k*_*Math.sin(w),v*x+k*Math.cos(w))),u+=S?b+_*Ho:b,S^h>=e^y>=e){var N=mt(dt(s),dt(n));bt(N);var E=mt(i,N);bt(E);var A=(S^b>=0?-1:1)*tn(E[2]);(r>A||r===A&&(N[0]||N[1]))&&(o+=S^b>=0?1:-1)}if(!d++)break;h=y,g=M,v=x,s=n}}return(-Uo>u||Uo>u&&-Uo>ka)^1&o}function It(n){function t(n,t){return Math.cos(n)*Math.cos(t)>u}function e(n){var e,u,l,c,f;return{lineStart:function(){c=l=!1,f=1},point:function(s,h){var p,g=[s,h],v=t(s,h),d=o?v?0:i(s,h):v?i(s+(0>s?Fo:-Fo),h):0;if(!e&&(c=l=v)&&n.lineStart(),v!==l&&(p=r(e,g),(wt(e,p)||wt(g,p))&&(g[0]+=Uo,g[1]+=Uo,v=t(g[0],g[1]))),v!==l)f=0,v?(n.lineStart(),p=r(g,e),n.point(p[0],p[1])):(p=r(e,g),n.point(p[0],p[1]),n.lineEnd()),e=p;else if(a&&e&&o^v){var y;d&u||!(y=r(g,e,!0))||(f=0,o?(n.lineStart(),n.point(y[0][0],y[0][1]),n.point(y[1][0],y[1][1]),n.lineEnd()):(n.point(y[1][0],y[1][1]),n.lineEnd(),n.lineStart(),n.point(y[0][0],y[0][1])))}!v||e&&wt(e,g)||n.point(g[0],g[1]),e=g,l=v,u=d},lineEnd:function(){l&&n.lineEnd(),e=null},clean:function(){return f|(c&&l)<<1}}}function r(n,t,e){var r=dt(n),i=dt(t),o=[1,0,0],a=mt(r,i),l=yt(a,a),c=a[0],f=l-c*c;if(!f)return!e&&n;var s=u*l/f,h=-u*c/f,p=mt(o,a),g=xt(o,s),v=xt(a,h);Mt(g,v);var d=p,y=yt(g,d),m=yt(d,d),M=y*y-m*(yt(g,g)-1);if(!(0>M)){var x=Math.sqrt(M),b=xt(d,(-y-x)/m);if(Mt(b,g),b=_t(b),!e)return b;var _,w=n[0],S=t[0],k=n[1],N=t[1];w>S&&(_=w,w=S,S=_);var E=S-w,A=xo(E-Fo)<Uo,C=A||Uo>E;if(!A&&k>N&&(_=k,k=N,N=_),C?A?k+N>0^b[1]<(xo(b[0]-w)<Uo?k:N):k<=b[1]&&b[1]<=N:E>Fo^(w<=b[0]&&b[0]<=S)){var z=xt(d,(-y+x)/m);return Mt(z,g),[b,_t(z)]}}}function i(t,e){var r=o?n:Fo-n,i=0;return-r>t?i|=1:t>r&&(i|=2),-r>e?i|=4:e>r&&(i|=8),i}var u=Math.cos(n),o=u>0,a=xo(u)>Uo,l=ve(n,6*Yo);return Rt(t,e,l,o?[0,-n]:[-Fo,n-Fo])}function Yt(n,t,e,r){return function(i){var u,o=i.a,a=i.b,l=o.x,c=o.y,f=a.x,s=a.y,h=0,p=1,g=f-l,v=s-c;if(u=n-l,g||!(u>0)){if(u/=g,0>g){if(h>u)return;p>u&&(p=u)}else if(g>0){if(u>p)return;u>h&&(h=u)}if(u=e-l,g||!(0>u)){if(u/=g,0>g){if(u>p)return;u>h&&(h=u)}else if(g>0){if(h>u)return;p>u&&(p=u)}if(u=t-c,v||!(u>0)){if(u/=v,0>v){if(h>u)return;p>u&&(p=u)}else if(v>0){if(u>p)return;u>h&&(h=u)}if(u=r-c,v||!(0>u)){if(u/=v,0>v){if(u>p)return;u>h&&(h=u)}else if(v>0){if(h>u)return;p>u&&(p=u)}return h>0&&(i.a={x:l+h*g,y:c+h*v}),1>p&&(i.b={x:l+p*g,y:c+p*v}),i}}}}}}function Zt(n,t,e,r){function i(r,i){return xo(r[0]-n)<Uo?i>0?0:3:xo(r[0]-e)<Uo?i>0?2:1:xo(r[1]-t)<Uo?i>0?1:0:i>0?3:2}function u(n,t){return o(n.x,t.x)}function o(n,t){var e=i(n,1),r=i(t,1);return e!==r?e-r:0===e?t[1]-n[1]:1===e?n[0]-t[0]:2===e?n[1]-t[1]:t[0]-n[0]}return function(a){function l(n){for(var t=0,e=d.length,r=n[1],i=0;e>i;++i)for(var u,o=1,a=d[i],l=a.length,c=a[0];l>o;++o)u=a[o],c[1]<=r?u[1]>r&&Q(c,u,n)>0&&++t:u[1]<=r&&Q(c,u,n)<0&&--t,c=u;return 0!==t}function c(u,a,l,c){var f=0,s=0;if(null==u||(f=i(u,l))!==(s=i(a,l))||o(u,a)<0^l>0){do c.point(0===f||3===f?n:e,f>1?r:t);while((f=(f+l+4)%4)!==s)}else c.point(a[0],a[1])}function f(i,u){return i>=n&&e>=i&&u>=t&&r>=u}function s(n,t){f(n,t)&&a.point(n,t)}function h(){C.point=g,d&&d.push(y=[]),S=!0,w=!1,b=_=NaN}function p(){v&&(g(m,M),x&&w&&E.rejoin(),v.push(E.buffer())),C.point=s,w&&a.lineEnd()}function g(n,t){n=Math.max(-Ha,Math.min(Ha,n)),t=Math.max(-Ha,Math.min(Ha,t));var e=f(n,t);if(d&&y.push([n,t]),S)m=n,M=t,x=e,S=!1,e&&(a.lineStart(),a.point(n,t));else if(e&&w)a.point(n,t);else{var r={a:{x:b,y:_},b:{x:n,y:t}};A(r)?(w||(a.lineStart(),a.point(r.a.x,r.a.y)),a.point(r.b.x,r.b.y),e||a.lineEnd(),k=!1):e&&(a.lineStart(),a.point(n,t),k=!1)}b=n,_=t,w=e}var v,d,y,m,M,x,b,_,w,S,k,N=a,E=Pt(),A=Yt(n,t,e,r),C={point:s,lineStart:h,lineEnd:p,polygonStart:function(){a=E,v=[],d=[],k=!0},polygonEnd:function(){a=N,v=ao.merge(v);var t=l([n,r]),e=k&&t,i=v.length;(e||i)&&(a.polygonStart(),e&&(a.lineStart(),c(null,null,1,a),a.lineEnd()),i&&Lt(v,u,t,c,a),a.polygonEnd()),v=d=y=null}};return C}}function Vt(n){var t=0,e=Fo/3,r=ae(n),i=r(t,e);return i.parallels=function(n){return arguments.length?r(t=n[0]*Fo/180,e=n[1]*Fo/180):[t/Fo*180,e/Fo*180]},i}function Xt(n,t){function e(n,t){var e=Math.sqrt(u-2*i*Math.sin(t))/i;return[e*Math.sin(n*=i),o-e*Math.cos(n)]}var r=Math.sin(n),i=(r+Math.sin(t))/2,u=1+r*(2*i-r),o=Math.sqrt(u)/i;return e.invert=function(n,t){var e=o-t;return[Math.atan2(n,e)/i,tn((u-(n*n+e*e)*i*i)/(2*i))]},e}function $t(){function n(n,t){Ia+=i*n-r*t,r=n,i=t}var t,e,r,i;$a.point=function(u,o){$a.point=n,t=r=u,e=i=o},$a.lineEnd=function(){n(t,e)}}function Bt(n,t){Ya>n&&(Ya=n),n>Va&&(Va=n),Za>t&&(Za=t),t>Xa&&(Xa=t)}function Wt(){function n(n,t){o.push("M",n,",",t,u)}function t(n,t){o.push("M",n,",",t),a.point=e}function e(n,t){o.push("L",n,",",t)}function r(){a.point=n}function i(){o.push("Z")}var u=Jt(4.5),o=[],a={point:n,lineStart:function(){a.point=t},lineEnd:r,polygonStart:function(){a.lineEnd=i},polygonEnd:function(){a.lineEnd=r,a.point=n},pointRadius:function(n){return u=Jt(n),a},result:function(){if(o.length){var n=o.join("");return o=[],n}}};return a}function Jt(n){return"m0,"+n+"a"+n+","+n+" 0 1,1 0,"+-2*n+"a"+n+","+n+" 0 1,1 0,"+2*n+"z"}function Gt(n,t){Ca+=n,za+=t,++La}function Kt(){function n(n,r){var i=n-t,u=r-e,o=Math.sqrt(i*i+u*u);qa+=o*(t+n)/2,Ta+=o*(e+r)/2,Ra+=o,Gt(t=n,e=r)}var t,e;Wa.point=function(r,i){Wa.point=n,Gt(t=r,e=i)}}function Qt(){Wa.point=Gt}function ne(){function n(n,t){var e=n-r,u=t-i,o=Math.sqrt(e*e+u*u);qa+=o*(r+n)/2,Ta+=o*(i+t)/2,Ra+=o,o=i*n-r*t,Da+=o*(r+n),Pa+=o*(i+t),Ua+=3*o,Gt(r=n,i=t)}var t,e,r,i;Wa.point=function(u,o){Wa.point=n,Gt(t=r=u,e=i=o)},Wa.lineEnd=function(){n(t,e)}}function te(n){function t(t,e){n.moveTo(t+o,e),n.arc(t,e,o,0,Ho)}function e(t,e){n.moveTo(t,e),a.point=r}function r(t,e){n.lineTo(t,e)}function i(){a.point=t}function u(){n.closePath()}var o=4.5,a={point:t,lineStart:function(){a.point=e},lineEnd:i,polygonStart:function(){a.lineEnd=u},polygonEnd:function(){a.lineEnd=i,a.point=t},pointRadius:function(n){return o=n,a},result:b};return a}function ee(n){function t(n){return(a?r:e)(n)}function e(t){return ue(t,function(e,r){e=n(e,r),t.point(e[0],e[1])})}function r(t){function e(e,r){e=n(e,r),t.point(e[0],e[1])}function r(){M=NaN,S.point=u,t.lineStart()}function u(e,r){var u=dt([e,r]),o=n(e,r);i(M,x,m,b,_,w,M=o[0],x=o[1],m=e,b=u[0],_=u[1],w=u[2],a,t),t.point(M,x)}function o(){S.point=e,t.lineEnd()}function l(){
-			r(),S.point=c,S.lineEnd=f}function c(n,t){u(s=n,h=t),p=M,g=x,v=b,d=_,y=w,S.point=u}function f(){i(M,x,m,b,_,w,p,g,s,v,d,y,a,t),S.lineEnd=o,o()}var s,h,p,g,v,d,y,m,M,x,b,_,w,S={point:e,lineStart:r,lineEnd:o,polygonStart:function(){t.polygonStart(),S.lineStart=l},polygonEnd:function(){t.polygonEnd(),S.lineStart=r}};return S}function i(t,e,r,a,l,c,f,s,h,p,g,v,d,y){var m=f-t,M=s-e,x=m*m+M*M;if(x>4*u&&d--){var b=a+p,_=l+g,w=c+v,S=Math.sqrt(b*b+_*_+w*w),k=Math.asin(w/=S),N=xo(xo(w)-1)<Uo||xo(r-h)<Uo?(r+h)/2:Math.atan2(_,b),E=n(N,k),A=E[0],C=E[1],z=A-t,L=C-e,q=M*z-m*L;(q*q/x>u||xo((m*z+M*L)/x-.5)>.3||o>a*p+l*g+c*v)&&(i(t,e,r,a,l,c,A,C,N,b/=S,_/=S,w,d,y),y.point(A,C),i(A,C,N,b,_,w,f,s,h,p,g,v,d,y))}}var u=.5,o=Math.cos(30*Yo),a=16;return t.precision=function(n){return arguments.length?(a=(u=n*n)>0&&16,t):Math.sqrt(u)},t}function re(n){var t=ee(function(t,e){return n([t*Zo,e*Zo])});return function(n){return le(t(n))}}function ie(n){this.stream=n}function ue(n,t){return{point:t,sphere:function(){n.sphere()},lineStart:function(){n.lineStart()},lineEnd:function(){n.lineEnd()},polygonStart:function(){n.polygonStart()},polygonEnd:function(){n.polygonEnd()}}}function oe(n){return ae(function(){return n})()}function ae(n){function t(n){return n=a(n[0]*Yo,n[1]*Yo),[n[0]*h+l,c-n[1]*h]}function e(n){return n=a.invert((n[0]-l)/h,(c-n[1])/h),n&&[n[0]*Zo,n[1]*Zo]}function r(){a=Ct(o=se(y,M,x),u);var n=u(v,d);return l=p-n[0]*h,c=g+n[1]*h,i()}function i(){return f&&(f.valid=!1,f=null),t}var u,o,a,l,c,f,s=ee(function(n,t){return n=u(n,t),[n[0]*h+l,c-n[1]*h]}),h=150,p=480,g=250,v=0,d=0,y=0,M=0,x=0,b=Fa,_=m,w=null,S=null;return t.stream=function(n){return f&&(f.valid=!1),f=le(b(o,s(_(n)))),f.valid=!0,f},t.clipAngle=function(n){return arguments.length?(b=null==n?(w=n,Fa):It((w=+n)*Yo),i()):w},t.clipExtent=function(n){return arguments.length?(S=n,_=n?Zt(n[0][0],n[0][1],n[1][0],n[1][1]):m,i()):S},t.scale=function(n){return arguments.length?(h=+n,r()):h},t.translate=function(n){return arguments.length?(p=+n[0],g=+n[1],r()):[p,g]},t.center=function(n){return arguments.length?(v=n[0]%360*Yo,d=n[1]%360*Yo,r()):[v*Zo,d*Zo]},t.rotate=function(n){return arguments.length?(y=n[0]%360*Yo,M=n[1]%360*Yo,x=n.length>2?n[2]%360*Yo:0,r()):[y*Zo,M*Zo,x*Zo]},ao.rebind(t,s,"precision"),function(){return u=n.apply(this,arguments),t.invert=u.invert&&e,r()}}function le(n){return ue(n,function(t,e){n.point(t*Yo,e*Yo)})}function ce(n,t){return[n,t]}function fe(n,t){return[n>Fo?n-Ho:-Fo>n?n+Ho:n,t]}function se(n,t,e){return n?t||e?Ct(pe(n),ge(t,e)):pe(n):t||e?ge(t,e):fe}function he(n){return function(t,e){return t+=n,[t>Fo?t-Ho:-Fo>t?t+Ho:t,e]}}function pe(n){var t=he(n);return t.invert=he(-n),t}function ge(n,t){function e(n,t){var e=Math.cos(t),a=Math.cos(n)*e,l=Math.sin(n)*e,c=Math.sin(t),f=c*r+a*i;return[Math.atan2(l*u-f*o,a*r-c*i),tn(f*u+l*o)]}var r=Math.cos(n),i=Math.sin(n),u=Math.cos(t),o=Math.sin(t);return e.invert=function(n,t){var e=Math.cos(t),a=Math.cos(n)*e,l=Math.sin(n)*e,c=Math.sin(t),f=c*u-l*o;return[Math.atan2(l*u+c*o,a*r+f*i),tn(f*r-a*i)]},e}function ve(n,t){var e=Math.cos(n),r=Math.sin(n);return function(i,u,o,a){var l=o*t;null!=i?(i=de(e,i),u=de(e,u),(o>0?u>i:i>u)&&(i+=o*Ho)):(i=n+o*Ho,u=n-.5*l);for(var c,f=i;o>0?f>u:u>f;f-=l)a.point((c=_t([e,-r*Math.cos(f),-r*Math.sin(f)]))[0],c[1])}}function de(n,t){var e=dt(t);e[0]-=n,bt(e);var r=nn(-e[1]);return((-e[2]<0?-r:r)+2*Math.PI-Uo)%(2*Math.PI)}function ye(n,t,e){var r=ao.range(n,t-Uo,e).concat(t);return function(n){return r.map(function(t){return[n,t]})}}function me(n,t,e){var r=ao.range(n,t-Uo,e).concat(t);return function(n){return r.map(function(t){return[t,n]})}}function Me(n){return n.source}function xe(n){return n.target}function be(n,t,e,r){var i=Math.cos(t),u=Math.sin(t),o=Math.cos(r),a=Math.sin(r),l=i*Math.cos(n),c=i*Math.sin(n),f=o*Math.cos(e),s=o*Math.sin(e),h=2*Math.asin(Math.sqrt(on(r-t)+i*o*on(e-n))),p=1/Math.sin(h),g=h?function(n){var t=Math.sin(n*=h)*p,e=Math.sin(h-n)*p,r=e*l+t*f,i=e*c+t*s,o=e*u+t*a;return[Math.atan2(i,r)*Zo,Math.atan2(o,Math.sqrt(r*r+i*i))*Zo]}:function(){return[n*Zo,t*Zo]};return g.distance=h,g}function _e(){function n(n,i){var u=Math.sin(i*=Yo),o=Math.cos(i),a=xo((n*=Yo)-t),l=Math.cos(a);Ja+=Math.atan2(Math.sqrt((a=o*Math.sin(a))*a+(a=r*u-e*o*l)*a),e*u+r*o*l),t=n,e=u,r=o}var t,e,r;Ga.point=function(i,u){t=i*Yo,e=Math.sin(u*=Yo),r=Math.cos(u),Ga.point=n},Ga.lineEnd=function(){Ga.point=Ga.lineEnd=b}}function we(n,t){function e(t,e){var r=Math.cos(t),i=Math.cos(e),u=n(r*i);return[u*i*Math.sin(t),u*Math.sin(e)]}return e.invert=function(n,e){var r=Math.sqrt(n*n+e*e),i=t(r),u=Math.sin(i),o=Math.cos(i);return[Math.atan2(n*u,r*o),Math.asin(r&&e*u/r)]},e}function Se(n,t){function e(n,t){o>0?-Io+Uo>t&&(t=-Io+Uo):t>Io-Uo&&(t=Io-Uo);var e=o/Math.pow(i(t),u);return[e*Math.sin(u*n),o-e*Math.cos(u*n)]}var r=Math.cos(n),i=function(n){return Math.tan(Fo/4+n/2)},u=n===t?Math.sin(n):Math.log(r/Math.cos(t))/Math.log(i(t)/i(n)),o=r*Math.pow(i(n),u)/u;return u?(e.invert=function(n,t){var e=o-t,r=K(u)*Math.sqrt(n*n+e*e);return[Math.atan2(n,e)/u,2*Math.atan(Math.pow(o/r,1/u))-Io]},e):Ne}function ke(n,t){function e(n,t){var e=u-t;return[e*Math.sin(i*n),u-e*Math.cos(i*n)]}var r=Math.cos(n),i=n===t?Math.sin(n):(r-Math.cos(t))/(t-n),u=r/i+n;return xo(i)<Uo?ce:(e.invert=function(n,t){var e=u-t;return[Math.atan2(n,e)/i,u-K(i)*Math.sqrt(n*n+e*e)]},e)}function Ne(n,t){return[n,Math.log(Math.tan(Fo/4+t/2))]}function Ee(n){var t,e=oe(n),r=e.scale,i=e.translate,u=e.clipExtent;return e.scale=function(){var n=r.apply(e,arguments);return n===e?t?e.clipExtent(null):e:n},e.translate=function(){var n=i.apply(e,arguments);return n===e?t?e.clipExtent(null):e:n},e.clipExtent=function(n){var o=u.apply(e,arguments);if(o===e){if(t=null==n){var a=Fo*r(),l=i();u([[l[0]-a,l[1]-a],[l[0]+a,l[1]+a]])}}else t&&(o=null);return o},e.clipExtent(null)}function Ae(n,t){return[Math.log(Math.tan(Fo/4+t/2)),-n]}function Ce(n){return n[0]}function ze(n){return n[1]}function Le(n){for(var t=n.length,e=[0,1],r=2,i=2;t>i;i++){for(;r>1&&Q(n[e[r-2]],n[e[r-1]],n[i])<=0;)--r;e[r++]=i}return e.slice(0,r)}function qe(n,t){return n[0]-t[0]||n[1]-t[1]}function Te(n,t,e){return(e[0]-t[0])*(n[1]-t[1])<(e[1]-t[1])*(n[0]-t[0])}function Re(n,t,e,r){var i=n[0],u=e[0],o=t[0]-i,a=r[0]-u,l=n[1],c=e[1],f=t[1]-l,s=r[1]-c,h=(a*(l-c)-s*(i-u))/(s*o-a*f);return[i+h*o,l+h*f]}function De(n){var t=n[0],e=n[n.length-1];return!(t[0]-e[0]||t[1]-e[1])}function Pe(){rr(this),this.edge=this.site=this.circle=null}function Ue(n){var t=cl.pop()||new Pe;return t.site=n,t}function je(n){Be(n),ol.remove(n),cl.push(n),rr(n)}function Fe(n){var t=n.circle,e=t.x,r=t.cy,i={x:e,y:r},u=n.P,o=n.N,a=[n];je(n);for(var l=u;l.circle&&xo(e-l.circle.x)<Uo&&xo(r-l.circle.cy)<Uo;)u=l.P,a.unshift(l),je(l),l=u;a.unshift(l),Be(l);for(var c=o;c.circle&&xo(e-c.circle.x)<Uo&&xo(r-c.circle.cy)<Uo;)o=c.N,a.push(c),je(c),c=o;a.push(c),Be(c);var f,s=a.length;for(f=1;s>f;++f)c=a[f],l=a[f-1],nr(c.edge,l.site,c.site,i);l=a[0],c=a[s-1],c.edge=Ke(l.site,c.site,null,i),$e(l),$e(c)}function He(n){for(var t,e,r,i,u=n.x,o=n.y,a=ol._;a;)if(r=Oe(a,o)-u,r>Uo)a=a.L;else{if(i=u-Ie(a,o),!(i>Uo)){r>-Uo?(t=a.P,e=a):i>-Uo?(t=a,e=a.N):t=e=a;break}if(!a.R){t=a;break}a=a.R}var l=Ue(n);if(ol.insert(t,l),t||e){if(t===e)return Be(t),e=Ue(t.site),ol.insert(l,e),l.edge=e.edge=Ke(t.site,l.site),$e(t),void $e(e);if(!e)return void(l.edge=Ke(t.site,l.site));Be(t),Be(e);var c=t.site,f=c.x,s=c.y,h=n.x-f,p=n.y-s,g=e.site,v=g.x-f,d=g.y-s,y=2*(h*d-p*v),m=h*h+p*p,M=v*v+d*d,x={x:(d*m-p*M)/y+f,y:(h*M-v*m)/y+s};nr(e.edge,c,g,x),l.edge=Ke(c,n,null,x),e.edge=Ke(n,g,null,x),$e(t),$e(e)}}function Oe(n,t){var e=n.site,r=e.x,i=e.y,u=i-t;if(!u)return r;var o=n.P;if(!o)return-(1/0);e=o.site;var a=e.x,l=e.y,c=l-t;if(!c)return a;var f=a-r,s=1/u-1/c,h=f/c;return s?(-h+Math.sqrt(h*h-2*s*(f*f/(-2*c)-l+c/2+i-u/2)))/s+r:(r+a)/2}function Ie(n,t){var e=n.N;if(e)return Oe(e,t);var r=n.site;return r.y===t?r.x:1/0}function Ye(n){this.site=n,this.edges=[]}function Ze(n){for(var t,e,r,i,u,o,a,l,c,f,s=n[0][0],h=n[1][0],p=n[0][1],g=n[1][1],v=ul,d=v.length;d--;)if(u=v[d],u&&u.prepare())for(a=u.edges,l=a.length,o=0;l>o;)f=a[o].end(),r=f.x,i=f.y,c=a[++o%l].start(),t=c.x,e=c.y,(xo(r-t)>Uo||xo(i-e)>Uo)&&(a.splice(o,0,new tr(Qe(u.site,f,xo(r-s)<Uo&&g-i>Uo?{x:s,y:xo(t-s)<Uo?e:g}:xo(i-g)<Uo&&h-r>Uo?{x:xo(e-g)<Uo?t:h,y:g}:xo(r-h)<Uo&&i-p>Uo?{x:h,y:xo(t-h)<Uo?e:p}:xo(i-p)<Uo&&r-s>Uo?{x:xo(e-p)<Uo?t:s,y:p}:null),u.site,null)),++l)}function Ve(n,t){return t.angle-n.angle}function Xe(){rr(this),this.x=this.y=this.arc=this.site=this.cy=null}function $e(n){var t=n.P,e=n.N;if(t&&e){var r=t.site,i=n.site,u=e.site;if(r!==u){var o=i.x,a=i.y,l=r.x-o,c=r.y-a,f=u.x-o,s=u.y-a,h=2*(l*s-c*f);if(!(h>=-jo)){var p=l*l+c*c,g=f*f+s*s,v=(s*p-c*g)/h,d=(l*g-f*p)/h,s=d+a,y=fl.pop()||new Xe;y.arc=n,y.site=i,y.x=v+o,y.y=s+Math.sqrt(v*v+d*d),y.cy=s,n.circle=y;for(var m=null,M=ll._;M;)if(y.y<M.y||y.y===M.y&&y.x<=M.x){if(!M.L){m=M.P;break}M=M.L}else{if(!M.R){m=M;break}M=M.R}ll.insert(m,y),m||(al=y)}}}}function Be(n){var t=n.circle;t&&(t.P||(al=t.N),ll.remove(t),fl.push(t),rr(t),n.circle=null)}function We(n){for(var t,e=il,r=Yt(n[0][0],n[0][1],n[1][0],n[1][1]),i=e.length;i--;)t=e[i],(!Je(t,n)||!r(t)||xo(t.a.x-t.b.x)<Uo&&xo(t.a.y-t.b.y)<Uo)&&(t.a=t.b=null,e.splice(i,1))}function Je(n,t){var e=n.b;if(e)return!0;var r,i,u=n.a,o=t[0][0],a=t[1][0],l=t[0][1],c=t[1][1],f=n.l,s=n.r,h=f.x,p=f.y,g=s.x,v=s.y,d=(h+g)/2,y=(p+v)/2;if(v===p){if(o>d||d>=a)return;if(h>g){if(u){if(u.y>=c)return}else u={x:d,y:l};e={x:d,y:c}}else{if(u){if(u.y<l)return}else u={x:d,y:c};e={x:d,y:l}}}else if(r=(h-g)/(v-p),i=y-r*d,-1>r||r>1)if(h>g){if(u){if(u.y>=c)return}else u={x:(l-i)/r,y:l};e={x:(c-i)/r,y:c}}else{if(u){if(u.y<l)return}else u={x:(c-i)/r,y:c};e={x:(l-i)/r,y:l}}else if(v>p){if(u){if(u.x>=a)return}else u={x:o,y:r*o+i};e={x:a,y:r*a+i}}else{if(u){if(u.x<o)return}else u={x:a,y:r*a+i};e={x:o,y:r*o+i}}return n.a=u,n.b=e,!0}function Ge(n,t){this.l=n,this.r=t,this.a=this.b=null}function Ke(n,t,e,r){var i=new Ge(n,t);return il.push(i),e&&nr(i,n,t,e),r&&nr(i,t,n,r),ul[n.i].edges.push(new tr(i,n,t)),ul[t.i].edges.push(new tr(i,t,n)),i}function Qe(n,t,e){var r=new Ge(n,null);return r.a=t,r.b=e,il.push(r),r}function nr(n,t,e,r){n.a||n.b?n.l===e?n.b=r:n.a=r:(n.a=r,n.l=t,n.r=e)}function tr(n,t,e){var r=n.a,i=n.b;this.edge=n,this.site=t,this.angle=e?Math.atan2(e.y-t.y,e.x-t.x):n.l===t?Math.atan2(i.x-r.x,r.y-i.y):Math.atan2(r.x-i.x,i.y-r.y)}function er(){this._=null}function rr(n){n.U=n.C=n.L=n.R=n.P=n.N=null}function ir(n,t){var e=t,r=t.R,i=e.U;i?i.L===e?i.L=r:i.R=r:n._=r,r.U=i,e.U=r,e.R=r.L,e.R&&(e.R.U=e),r.L=e}function ur(n,t){var e=t,r=t.L,i=e.U;i?i.L===e?i.L=r:i.R=r:n._=r,r.U=i,e.U=r,e.L=r.R,e.L&&(e.L.U=e),r.R=e}function or(n){for(;n.L;)n=n.L;return n}function ar(n,t){var e,r,i,u=n.sort(lr).pop();for(il=[],ul=new Array(n.length),ol=new er,ll=new er;;)if(i=al,u&&(!i||u.y<i.y||u.y===i.y&&u.x<i.x))u.x===e&&u.y===r||(ul[u.i]=new Ye(u),He(u),e=u.x,r=u.y),u=n.pop();else{if(!i)break;Fe(i.arc)}t&&(We(t),Ze(t));var o={cells:ul,edges:il};return ol=ll=il=ul=null,o}function lr(n,t){return t.y-n.y||t.x-n.x}function cr(n,t,e){return(n.x-e.x)*(t.y-n.y)-(n.x-t.x)*(e.y-n.y)}function fr(n){return n.x}function sr(n){return n.y}function hr(){return{leaf:!0,nodes:[],point:null,x:null,y:null}}function pr(n,t,e,r,i,u){if(!n(t,e,r,i,u)){var o=.5*(e+i),a=.5*(r+u),l=t.nodes;l[0]&&pr(n,l[0],e,r,o,a),l[1]&&pr(n,l[1],o,r,i,a),l[2]&&pr(n,l[2],e,a,o,u),l[3]&&pr(n,l[3],o,a,i,u)}}function gr(n,t,e,r,i,u,o){var a,l=1/0;return function c(n,f,s,h,p){if(!(f>u||s>o||r>h||i>p)){if(g=n.point){var g,v=t-n.x,d=e-n.y,y=v*v+d*d;if(l>y){var m=Math.sqrt(l=y);r=t-m,i=e-m,u=t+m,o=e+m,a=g}}for(var M=n.nodes,x=.5*(f+h),b=.5*(s+p),_=t>=x,w=e>=b,S=w<<1|_,k=S+4;k>S;++S)if(n=M[3&S])switch(3&S){case 0:c(n,f,s,x,b);break;case 1:c(n,x,s,h,b);break;case 2:c(n,f,b,x,p);break;case 3:c(n,x,b,h,p)}}}(n,r,i,u,o),a}function vr(n,t){n=ao.rgb(n),t=ao.rgb(t);var e=n.r,r=n.g,i=n.b,u=t.r-e,o=t.g-r,a=t.b-i;return function(n){return"#"+bn(Math.round(e+u*n))+bn(Math.round(r+o*n))+bn(Math.round(i+a*n))}}function dr(n,t){var e,r={},i={};for(e in n)e in t?r[e]=Mr(n[e],t[e]):i[e]=n[e];for(e in t)e in n||(i[e]=t[e]);return function(n){for(e in r)i[e]=r[e](n);return i}}function yr(n,t){return n=+n,t=+t,function(e){return n*(1-e)+t*e}}function mr(n,t){var e,r,i,u=hl.lastIndex=pl.lastIndex=0,o=-1,a=[],l=[];for(n+="",t+="";(e=hl.exec(n))&&(r=pl.exec(t));)(i=r.index)>u&&(i=t.slice(u,i),a[o]?a[o]+=i:a[++o]=i),(e=e[0])===(r=r[0])?a[o]?a[o]+=r:a[++o]=r:(a[++o]=null,l.push({i:o,x:yr(e,r)})),u=pl.lastIndex;return u<t.length&&(i=t.slice(u),a[o]?a[o]+=i:a[++o]=i),a.length<2?l[0]?(t=l[0].x,function(n){return t(n)+""}):function(){return t}:(t=l.length,function(n){for(var e,r=0;t>r;++r)a[(e=l[r]).i]=e.x(n);return a.join("")})}function Mr(n,t){for(var e,r=ao.interpolators.length;--r>=0&&!(e=ao.interpolators[r](n,t)););return e}function xr(n,t){var e,r=[],i=[],u=n.length,o=t.length,a=Math.min(n.length,t.length);for(e=0;a>e;++e)r.push(Mr(n[e],t[e]));for(;u>e;++e)i[e]=n[e];for(;o>e;++e)i[e]=t[e];return function(n){for(e=0;a>e;++e)i[e]=r[e](n);return i}}function br(n){return function(t){return 0>=t?0:t>=1?1:n(t)}}function _r(n){return function(t){return 1-n(1-t)}}function wr(n){return function(t){return.5*(.5>t?n(2*t):2-n(2-2*t))}}function Sr(n){return n*n}function kr(n){return n*n*n}function Nr(n){if(0>=n)return 0;if(n>=1)return 1;var t=n*n,e=t*n;return 4*(.5>n?e:3*(n-t)+e-.75)}function Er(n){return function(t){return Math.pow(t,n)}}function Ar(n){return 1-Math.cos(n*Io)}function Cr(n){return Math.pow(2,10*(n-1))}function zr(n){return 1-Math.sqrt(1-n*n)}function Lr(n,t){var e;return arguments.length<2&&(t=.45),arguments.length?e=t/Ho*Math.asin(1/n):(n=1,e=t/4),function(r){return 1+n*Math.pow(2,-10*r)*Math.sin((r-e)*Ho/t)}}function qr(n){return n||(n=1.70158),function(t){return t*t*((n+1)*t-n)}}function Tr(n){return 1/2.75>n?7.5625*n*n:2/2.75>n?7.5625*(n-=1.5/2.75)*n+.75:2.5/2.75>n?7.5625*(n-=2.25/2.75)*n+.9375:7.5625*(n-=2.625/2.75)*n+.984375}function Rr(n,t){n=ao.hcl(n),t=ao.hcl(t);var e=n.h,r=n.c,i=n.l,u=t.h-e,o=t.c-r,a=t.l-i;return isNaN(o)&&(o=0,r=isNaN(r)?t.c:r),isNaN(u)?(u=0,e=isNaN(e)?t.h:e):u>180?u-=360:-180>u&&(u+=360),function(n){return sn(e+u*n,r+o*n,i+a*n)+""}}function Dr(n,t){n=ao.hsl(n),t=ao.hsl(t);var e=n.h,r=n.s,i=n.l,u=t.h-e,o=t.s-r,a=t.l-i;return isNaN(o)&&(o=0,r=isNaN(r)?t.s:r),isNaN(u)?(u=0,e=isNaN(e)?t.h:e):u>180?u-=360:-180>u&&(u+=360),function(n){return cn(e+u*n,r+o*n,i+a*n)+""}}function Pr(n,t){n=ao.lab(n),t=ao.lab(t);var e=n.l,r=n.a,i=n.b,u=t.l-e,o=t.a-r,a=t.b-i;return function(n){return pn(e+u*n,r+o*n,i+a*n)+""}}function Ur(n,t){return t-=n,function(e){return Math.round(n+t*e)}}function jr(n){var t=[n.a,n.b],e=[n.c,n.d],r=Hr(t),i=Fr(t,e),u=Hr(Or(e,t,-i))||0;t[0]*e[1]<e[0]*t[1]&&(t[0]*=-1,t[1]*=-1,r*=-1,i*=-1),this.rotate=(r?Math.atan2(t[1],t[0]):Math.atan2(-e[0],e[1]))*Zo,this.translate=[n.e,n.f],this.scale=[r,u],this.skew=u?Math.atan2(i,u)*Zo:0}function Fr(n,t){return n[0]*t[0]+n[1]*t[1]}function Hr(n){var t=Math.sqrt(Fr(n,n));return t&&(n[0]/=t,n[1]/=t),t}function Or(n,t,e){return n[0]+=e*t[0],n[1]+=e*t[1],n}function Ir(n){return n.length?n.pop()+",":""}function Yr(n,t,e,r){if(n[0]!==t[0]||n[1]!==t[1]){var i=e.push("translate(",null,",",null,")");r.push({i:i-4,x:yr(n[0],t[0])},{i:i-2,x:yr(n[1],t[1])})}else(t[0]||t[1])&&e.push("translate("+t+")")}function Zr(n,t,e,r){n!==t?(n-t>180?t+=360:t-n>180&&(n+=360),r.push({i:e.push(Ir(e)+"rotate(",null,")")-2,x:yr(n,t)})):t&&e.push(Ir(e)+"rotate("+t+")")}function Vr(n,t,e,r){n!==t?r.push({i:e.push(Ir(e)+"skewX(",null,")")-2,x:yr(n,t)}):t&&e.push(Ir(e)+"skewX("+t+")")}function Xr(n,t,e,r){if(n[0]!==t[0]||n[1]!==t[1]){var i=e.push(Ir(e)+"scale(",null,",",null,")");r.push({i:i-4,x:yr(n[0],t[0])},{i:i-2,x:yr(n[1],t[1])})}else 1===t[0]&&1===t[1]||e.push(Ir(e)+"scale("+t+")")}function $r(n,t){var e=[],r=[];return n=ao.transform(n),t=ao.transform(t),Yr(n.translate,t.translate,e,r),Zr(n.rotate,t.rotate,e,r),Vr(n.skew,t.skew,e,r),Xr(n.scale,t.scale,e,r),n=t=null,function(n){for(var t,i=-1,u=r.length;++i<u;)e[(t=r[i]).i]=t.x(n);return e.join("")}}function Br(n,t){return t=(t-=n=+n)||1/t,function(e){return(e-n)/t}}function Wr(n,t){return t=(t-=n=+n)||1/t,function(e){return Math.max(0,Math.min(1,(e-n)/t))}}function Jr(n){for(var t=n.source,e=n.target,r=Kr(t,e),i=[t];t!==r;)t=t.parent,i.push(t);for(var u=i.length;e!==r;)i.splice(u,0,e),e=e.parent;return i}function Gr(n){for(var t=[],e=n.parent;null!=e;)t.push(n),n=e,e=e.parent;return t.push(n),t}function Kr(n,t){if(n===t)return n;for(var e=Gr(n),r=Gr(t),i=e.pop(),u=r.pop(),o=null;i===u;)o=i,i=e.pop(),u=r.pop();return o}function Qr(n){n.fixed|=2}function ni(n){n.fixed&=-7}function ti(n){n.fixed|=4,n.px=n.x,n.py=n.y}function ei(n){n.fixed&=-5}function ri(n,t,e){var r=0,i=0;if(n.charge=0,!n.leaf)for(var u,o=n.nodes,a=o.length,l=-1;++l<a;)u=o[l],null!=u&&(ri(u,t,e),n.charge+=u.charge,r+=u.charge*u.cx,i+=u.charge*u.cy);if(n.point){n.leaf||(n.point.x+=Math.random()-.5,n.point.y+=Math.random()-.5);var c=t*e[n.point.index];n.charge+=n.pointCharge=c,r+=c*n.point.x,i+=c*n.point.y}n.cx=r/n.charge,n.cy=i/n.charge}function ii(n,t){return ao.rebind(n,t,"sort","children","value"),n.nodes=n,n.links=fi,n}function ui(n,t){for(var e=[n];null!=(n=e.pop());)if(t(n),(i=n.children)&&(r=i.length))for(var r,i;--r>=0;)e.push(i[r])}function oi(n,t){for(var e=[n],r=[];null!=(n=e.pop());)if(r.push(n),(u=n.children)&&(i=u.length))for(var i,u,o=-1;++o<i;)e.push(u[o]);for(;null!=(n=r.pop());)t(n)}function ai(n){return n.children}function li(n){return n.value}function ci(n,t){return t.value-n.value}function fi(n){return ao.merge(n.map(function(n){return(n.children||[]).map(function(t){return{source:n,target:t}})}))}function si(n){return n.x}function hi(n){return n.y}function pi(n,t,e){n.y0=t,n.y=e}function gi(n){return ao.range(n.length)}function vi(n){for(var t=-1,e=n[0].length,r=[];++t<e;)r[t]=0;return r}function di(n){for(var t,e=1,r=0,i=n[0][1],u=n.length;u>e;++e)(t=n[e][1])>i&&(r=e,i=t);return r}function yi(n){return n.reduce(mi,0)}function mi(n,t){return n+t[1]}function Mi(n,t){return xi(n,Math.ceil(Math.log(t.length)/Math.LN2+1))}function xi(n,t){for(var e=-1,r=+n[0],i=(n[1]-r)/t,u=[];++e<=t;)u[e]=i*e+r;return u}function bi(n){return[ao.min(n),ao.max(n)]}function _i(n,t){return n.value-t.value}function wi(n,t){var e=n._pack_next;n._pack_next=t,t._pack_prev=n,t._pack_next=e,e._pack_prev=t}function Si(n,t){n._pack_next=t,t._pack_prev=n}function ki(n,t){var e=t.x-n.x,r=t.y-n.y,i=n.r+t.r;return.999*i*i>e*e+r*r}function Ni(n){function t(n){f=Math.min(n.x-n.r,f),s=Math.max(n.x+n.r,s),h=Math.min(n.y-n.r,h),p=Math.max(n.y+n.r,p)}if((e=n.children)&&(c=e.length)){var e,r,i,u,o,a,l,c,f=1/0,s=-(1/0),h=1/0,p=-(1/0);if(e.forEach(Ei),r=e[0],r.x=-r.r,r.y=0,t(r),c>1&&(i=e[1],i.x=i.r,i.y=0,t(i),c>2))for(u=e[2],zi(r,i,u),t(u),wi(r,u),r._pack_prev=u,wi(u,i),i=r._pack_next,o=3;c>o;o++){zi(r,i,u=e[o]);var g=0,v=1,d=1;for(a=i._pack_next;a!==i;a=a._pack_next,v++)if(ki(a,u)){g=1;break}if(1==g)for(l=r._pack_prev;l!==a._pack_prev&&!ki(l,u);l=l._pack_prev,d++);g?(d>v||v==d&&i.r<r.r?Si(r,i=a):Si(r=l,i),o--):(wi(r,u),i=u,t(u))}var y=(f+s)/2,m=(h+p)/2,M=0;for(o=0;c>o;o++)u=e[o],u.x-=y,u.y-=m,M=Math.max(M,u.r+Math.sqrt(u.x*u.x+u.y*u.y));n.r=M,e.forEach(Ai)}}function Ei(n){n._pack_next=n._pack_prev=n}function Ai(n){delete n._pack_next,delete n._pack_prev}function Ci(n,t,e,r){var i=n.children;if(n.x=t+=r*n.x,n.y=e+=r*n.y,n.r*=r,i)for(var u=-1,o=i.length;++u<o;)Ci(i[u],t,e,r)}function zi(n,t,e){var r=n.r+e.r,i=t.x-n.x,u=t.y-n.y;if(r&&(i||u)){var o=t.r+e.r,a=i*i+u*u;o*=o,r*=r;var l=.5+(r-o)/(2*a),c=Math.sqrt(Math.max(0,2*o*(r+a)-(r-=a)*r-o*o))/(2*a);e.x=n.x+l*i+c*u,e.y=n.y+l*u-c*i}else e.x=n.x+r,e.y=n.y}function Li(n,t){return n.parent==t.parent?1:2}function qi(n){var t=n.children;return t.length?t[0]:n.t}function Ti(n){var t,e=n.children;return(t=e.length)?e[t-1]:n.t}function Ri(n,t,e){var r=e/(t.i-n.i);t.c-=r,t.s+=e,n.c+=r,t.z+=e,t.m+=e}function Di(n){for(var t,e=0,r=0,i=n.children,u=i.length;--u>=0;)t=i[u],t.z+=e,t.m+=e,e+=t.s+(r+=t.c)}function Pi(n,t,e){return n.a.parent===t.parent?n.a:e}function Ui(n){return 1+ao.max(n,function(n){return n.y})}function ji(n){return n.reduce(function(n,t){return n+t.x},0)/n.length}function Fi(n){var t=n.children;return t&&t.length?Fi(t[0]):n}function Hi(n){var t,e=n.children;return e&&(t=e.length)?Hi(e[t-1]):n}function Oi(n){return{x:n.x,y:n.y,dx:n.dx,dy:n.dy}}function Ii(n,t){var e=n.x+t[3],r=n.y+t[0],i=n.dx-t[1]-t[3],u=n.dy-t[0]-t[2];return 0>i&&(e+=i/2,i=0),0>u&&(r+=u/2,u=0),{x:e,y:r,dx:i,dy:u}}function Yi(n){var t=n[0],e=n[n.length-1];return e>t?[t,e]:[e,t]}function Zi(n){return n.rangeExtent?n.rangeExtent():Yi(n.range())}function Vi(n,t,e,r){var i=e(n[0],n[1]),u=r(t[0],t[1]);return function(n){return u(i(n))}}function Xi(n,t){var e,r=0,i=n.length-1,u=n[r],o=n[i];return u>o&&(e=r,r=i,i=e,e=u,u=o,o=e),n[r]=t.floor(u),n[i]=t.ceil(o),n}function $i(n){return n?{floor:function(t){return Math.floor(t/n)*n},ceil:function(t){return Math.ceil(t/n)*n}}:Sl}function Bi(n,t,e,r){var i=[],u=[],o=0,a=Math.min(n.length,t.length)-1;for(n[a]<n[0]&&(n=n.slice().reverse(),t=t.slice().reverse());++o<=a;)i.push(e(n[o-1],n[o])),u.push(r(t[o-1],t[o]));return function(t){var e=ao.bisect(n,t,1,a)-1;return u[e](i[e](t))}}function Wi(n,t,e,r){function i(){var i=Math.min(n.length,t.length)>2?Bi:Vi,l=r?Wr:Br;return o=i(n,t,l,e),a=i(t,n,l,Mr),u}function u(n){return o(n)}var o,a;return u.invert=function(n){return a(n)},u.domain=function(t){return arguments.length?(n=t.map(Number),i()):n},u.range=function(n){return arguments.length?(t=n,i()):t},u.rangeRound=function(n){return u.range(n).interpolate(Ur)},u.clamp=function(n){return arguments.length?(r=n,i()):r},u.interpolate=function(n){return arguments.length?(e=n,i()):e},u.ticks=function(t){return Qi(n,t)},u.tickFormat=function(t,e){return nu(n,t,e)},u.nice=function(t){return Gi(n,t),i()},u.copy=function(){return Wi(n,t,e,r)},i()}function Ji(n,t){return ao.rebind(n,t,"range","rangeRound","interpolate","clamp")}function Gi(n,t){return Xi(n,$i(Ki(n,t)[2])),Xi(n,$i(Ki(n,t)[2])),n}function Ki(n,t){null==t&&(t=10);var e=Yi(n),r=e[1]-e[0],i=Math.pow(10,Math.floor(Math.log(r/t)/Math.LN10)),u=t/r*i;return.15>=u?i*=10:.35>=u?i*=5:.75>=u&&(i*=2),e[0]=Math.ceil(e[0]/i)*i,e[1]=Math.floor(e[1]/i)*i+.5*i,e[2]=i,e}function Qi(n,t){return ao.range.apply(ao,Ki(n,t))}function nu(n,t,e){var r=Ki(n,t);if(e){var i=ha.exec(e);if(i.shift(),"s"===i[8]){var u=ao.formatPrefix(Math.max(xo(r[0]),xo(r[1])));return i[7]||(i[7]="."+tu(u.scale(r[2]))),i[8]="f",e=ao.format(i.join("")),function(n){return e(u.scale(n))+u.symbol}}i[7]||(i[7]="."+eu(i[8],r)),e=i.join("")}else e=",."+tu(r[2])+"f";return ao.format(e)}function tu(n){return-Math.floor(Math.log(n)/Math.LN10+.01)}function eu(n,t){var e=tu(t[2]);return n in kl?Math.abs(e-tu(Math.max(xo(t[0]),xo(t[1]))))+ +("e"!==n):e-2*("%"===n)}function ru(n,t,e,r){function i(n){return(e?Math.log(0>n?0:n):-Math.log(n>0?0:-n))/Math.log(t)}function u(n){return e?Math.pow(t,n):-Math.pow(t,-n)}function o(t){return n(i(t))}return o.invert=function(t){return u(n.invert(t))},o.domain=function(t){return arguments.length?(e=t[0]>=0,n.domain((r=t.map(Number)).map(i)),o):r},o.base=function(e){return arguments.length?(t=+e,n.domain(r.map(i)),o):t},o.nice=function(){var t=Xi(r.map(i),e?Math:El);return n.domain(t),r=t.map(u),o},o.ticks=function(){var n=Yi(r),o=[],a=n[0],l=n[1],c=Math.floor(i(a)),f=Math.ceil(i(l)),s=t%1?2:t;if(isFinite(f-c)){if(e){for(;f>c;c++)for(var h=1;s>h;h++)o.push(u(c)*h);o.push(u(c))}else for(o.push(u(c));c++<f;)for(var h=s-1;h>0;h--)o.push(u(c)*h);for(c=0;o[c]<a;c++);for(f=o.length;o[f-1]>l;f--);o=o.slice(c,f)}return o},o.tickFormat=function(n,e){if(!arguments.length)return Nl;arguments.length<2?e=Nl:"function"!=typeof e&&(e=ao.format(e));var r=Math.max(1,t*n/o.ticks().length);return function(n){var o=n/u(Math.round(i(n)));return t-.5>o*t&&(o*=t),r>=o?e(n):""}},o.copy=function(){return ru(n.copy(),t,e,r)},Ji(o,n)}function iu(n,t,e){function r(t){return n(i(t))}var i=uu(t),u=uu(1/t);return r.invert=function(t){return u(n.invert(t))},r.domain=function(t){return arguments.length?(n.domain((e=t.map(Number)).map(i)),r):e},r.ticks=function(n){return Qi(e,n)},r.tickFormat=function(n,t){return nu(e,n,t)},r.nice=function(n){return r.domain(Gi(e,n))},r.exponent=function(o){return arguments.length?(i=uu(t=o),u=uu(1/t),n.domain(e.map(i)),r):t},r.copy=function(){return iu(n.copy(),t,e)},Ji(r,n)}function uu(n){return function(t){return 0>t?-Math.pow(-t,n):Math.pow(t,n)}}function ou(n,t){function e(e){return u[((i.get(e)||("range"===t.t?i.set(e,n.push(e)):NaN))-1)%u.length]}function r(t,e){return ao.range(n.length).map(function(n){return t+e*n})}var i,u,o;return e.domain=function(r){if(!arguments.length)return n;n=[],i=new c;for(var u,o=-1,a=r.length;++o<a;)i.has(u=r[o])||i.set(u,n.push(u));return e[t.t].apply(e,t.a)},e.range=function(n){return arguments.length?(u=n,o=0,t={t:"range",a:arguments},e):u},e.rangePoints=function(i,a){arguments.length<2&&(a=0);var l=i[0],c=i[1],f=n.length<2?(l=(l+c)/2,0):(c-l)/(n.length-1+a);return u=r(l+f*a/2,f),o=0,t={t:"rangePoints",a:arguments},e},e.rangeRoundPoints=function(i,a){arguments.length<2&&(a=0);var l=i[0],c=i[1],f=n.length<2?(l=c=Math.round((l+c)/2),0):(c-l)/(n.length-1+a)|0;return u=r(l+Math.round(f*a/2+(c-l-(n.length-1+a)*f)/2),f),o=0,t={t:"rangeRoundPoints",a:arguments},e},e.rangeBands=function(i,a,l){arguments.length<2&&(a=0),arguments.length<3&&(l=a);var c=i[1]<i[0],f=i[c-0],s=i[1-c],h=(s-f)/(n.length-a+2*l);return u=r(f+h*l,h),c&&u.reverse(),o=h*(1-a),t={t:"rangeBands",a:arguments},e},e.rangeRoundBands=function(i,a,l){arguments.length<2&&(a=0),arguments.length<3&&(l=a);var c=i[1]<i[0],f=i[c-0],s=i[1-c],h=Math.floor((s-f)/(n.length-a+2*l));return u=r(f+Math.round((s-f-(n.length-a)*h)/2),h),c&&u.reverse(),o=Math.round(h*(1-a)),t={t:"rangeRoundBands",a:arguments},e},e.rangeBand=function(){return o},e.rangeExtent=function(){return Yi(t.a[0])},e.copy=function(){return ou(n,t)},e.domain(n)}function au(n,t){function u(){var e=0,r=t.length;for(a=[];++e<r;)a[e-1]=ao.quantile(n,e/r);return o}function o(n){return isNaN(n=+n)?void 0:t[ao.bisect(a,n)]}var a;return o.domain=function(t){return arguments.length?(n=t.map(r).filter(i).sort(e),u()):n},o.range=function(n){return arguments.length?(t=n,u()):t},o.quantiles=function(){return a},o.invertExtent=function(e){return e=t.indexOf(e),0>e?[NaN,NaN]:[e>0?a[e-1]:n[0],e<a.length?a[e]:n[n.length-1]]},o.copy=function(){return au(n,t)},u()}function lu(n,t,e){function r(t){return e[Math.max(0,Math.min(o,Math.floor(u*(t-n))))]}function i(){return u=e.length/(t-n),o=e.length-1,r}var u,o;return r.domain=function(e){return arguments.length?(n=+e[0],t=+e[e.length-1],i()):[n,t]},r.range=function(n){return arguments.length?(e=n,i()):e},r.invertExtent=function(t){return t=e.indexOf(t),t=0>t?NaN:t/u+n,[t,t+1/u]},r.copy=function(){return lu(n,t,e)},i()}function cu(n,t){function e(e){return e>=e?t[ao.bisect(n,e)]:void 0}return e.domain=function(t){return arguments.length?(n=t,e):n},e.range=function(n){return arguments.length?(t=n,e):t},e.invertExtent=function(e){return e=t.indexOf(e),[n[e-1],n[e]]},e.copy=function(){return cu(n,t)},e}function fu(n){function t(n){return+n}return t.invert=t,t.domain=t.range=function(e){return arguments.length?(n=e.map(t),t):n},t.ticks=function(t){return Qi(n,t)},t.tickFormat=function(t,e){return nu(n,t,e)},t.copy=function(){return fu(n)},t}function su(){return 0}function hu(n){return n.innerRadius}function pu(n){return n.outerRadius}function gu(n){return n.startAngle}function vu(n){return n.endAngle}function du(n){return n&&n.padAngle}function yu(n,t,e,r){return(n-e)*t-(t-r)*n>0?0:1}function mu(n,t,e,r,i){var u=n[0]-t[0],o=n[1]-t[1],a=(i?r:-r)/Math.sqrt(u*u+o*o),l=a*o,c=-a*u,f=n[0]+l,s=n[1]+c,h=t[0]+l,p=t[1]+c,g=(f+h)/2,v=(s+p)/2,d=h-f,y=p-s,m=d*d+y*y,M=e-r,x=f*p-h*s,b=(0>y?-1:1)*Math.sqrt(Math.max(0,M*M*m-x*x)),_=(x*y-d*b)/m,w=(-x*d-y*b)/m,S=(x*y+d*b)/m,k=(-x*d+y*b)/m,N=_-g,E=w-v,A=S-g,C=k-v;return N*N+E*E>A*A+C*C&&(_=S,w=k),[[_-l,w-c],[_*e/M,w*e/M]]}function Mu(n){function t(t){function o(){c.push("M",u(n(f),a))}for(var l,c=[],f=[],s=-1,h=t.length,p=En(e),g=En(r);++s<h;)i.call(this,l=t[s],s)?f.push([+p.call(this,l,s),+g.call(this,l,s)]):f.length&&(o(),f=[]);return f.length&&o(),c.length?c.join(""):null}var e=Ce,r=ze,i=zt,u=xu,o=u.key,a=.7;return t.x=function(n){return arguments.length?(e=n,t):e},t.y=function(n){return arguments.length?(r=n,t):r},t.defined=function(n){return arguments.length?(i=n,t):i},t.interpolate=function(n){return arguments.length?(o="function"==typeof n?u=n:(u=Tl.get(n)||xu).key,t):o},t.tension=function(n){return arguments.length?(a=n,t):a},t}function xu(n){return n.length>1?n.join("L"):n+"Z"}function bu(n){return n.join("L")+"Z"}function _u(n){for(var t=0,e=n.length,r=n[0],i=[r[0],",",r[1]];++t<e;)i.push("H",(r[0]+(r=n[t])[0])/2,"V",r[1]);return e>1&&i.push("H",r[0]),i.join("")}function wu(n){for(var t=0,e=n.length,r=n[0],i=[r[0],",",r[1]];++t<e;)i.push("V",(r=n[t])[1],"H",r[0]);return i.join("")}function Su(n){for(var t=0,e=n.length,r=n[0],i=[r[0],",",r[1]];++t<e;)i.push("H",(r=n[t])[0],"V",r[1]);return i.join("")}function ku(n,t){return n.length<4?xu(n):n[1]+Au(n.slice(1,-1),Cu(n,t))}function Nu(n,t){return n.length<3?bu(n):n[0]+Au((n.push(n[0]),n),Cu([n[n.length-2]].concat(n,[n[1]]),t))}function Eu(n,t){return n.length<3?xu(n):n[0]+Au(n,Cu(n,t))}function Au(n,t){if(t.length<1||n.length!=t.length&&n.length!=t.length+2)return xu(n);var e=n.length!=t.length,r="",i=n[0],u=n[1],o=t[0],a=o,l=1;if(e&&(r+="Q"+(u[0]-2*o[0]/3)+","+(u[1]-2*o[1]/3)+","+u[0]+","+u[1],i=n[1],l=2),t.length>1){a=t[1],u=n[l],l++,r+="C"+(i[0]+o[0])+","+(i[1]+o[1])+","+(u[0]-a[0])+","+(u[1]-a[1])+","+u[0]+","+u[1];for(var c=2;c<t.length;c++,l++)u=n[l],a=t[c],r+="S"+(u[0]-a[0])+","+(u[1]-a[1])+","+u[0]+","+u[1]}if(e){var f=n[l];r+="Q"+(u[0]+2*a[0]/3)+","+(u[1]+2*a[1]/3)+","+f[0]+","+f[1]}return r}function Cu(n,t){for(var e,r=[],i=(1-t)/2,u=n[0],o=n[1],a=1,l=n.length;++a<l;)e=u,u=o,o=n[a],r.push([i*(o[0]-e[0]),i*(o[1]-e[1])]);return r}function zu(n){if(n.length<3)return xu(n);var t=1,e=n.length,r=n[0],i=r[0],u=r[1],o=[i,i,i,(r=n[1])[0]],a=[u,u,u,r[1]],l=[i,",",u,"L",Ru(Pl,o),",",Ru(Pl,a)];for(n.push(n[e-1]);++t<=e;)r=n[t],o.shift(),o.push(r[0]),a.shift(),a.push(r[1]),Du(l,o,a);return n.pop(),l.push("L",r),l.join("")}function Lu(n){if(n.length<4)return xu(n);for(var t,e=[],r=-1,i=n.length,u=[0],o=[0];++r<3;)t=n[r],u.push(t[0]),o.push(t[1]);for(e.push(Ru(Pl,u)+","+Ru(Pl,o)),--r;++r<i;)t=n[r],u.shift(),u.push(t[0]),o.shift(),o.push(t[1]),Du(e,u,o);return e.join("")}function qu(n){for(var t,e,r=-1,i=n.length,u=i+4,o=[],a=[];++r<4;)e=n[r%i],o.push(e[0]),a.push(e[1]);for(t=[Ru(Pl,o),",",Ru(Pl,a)],--r;++r<u;)e=n[r%i],o.shift(),o.push(e[0]),a.shift(),a.push(e[1]),Du(t,o,a);return t.join("")}function Tu(n,t){var e=n.length-1;if(e)for(var r,i,u=n[0][0],o=n[0][1],a=n[e][0]-u,l=n[e][1]-o,c=-1;++c<=e;)r=n[c],i=c/e,r[0]=t*r[0]+(1-t)*(u+i*a),r[1]=t*r[1]+(1-t)*(o+i*l);return zu(n)}function Ru(n,t){return n[0]*t[0]+n[1]*t[1]+n[2]*t[2]+n[3]*t[3]}function Du(n,t,e){n.push("C",Ru(Rl,t),",",Ru(Rl,e),",",Ru(Dl,t),",",Ru(Dl,e),",",Ru(Pl,t),",",Ru(Pl,e))}function Pu(n,t){return(t[1]-n[1])/(t[0]-n[0])}function Uu(n){for(var t=0,e=n.length-1,r=[],i=n[0],u=n[1],o=r[0]=Pu(i,u);++t<e;)r[t]=(o+(o=Pu(i=u,u=n[t+1])))/2;return r[t]=o,r}function ju(n){for(var t,e,r,i,u=[],o=Uu(n),a=-1,l=n.length-1;++a<l;)t=Pu(n[a],n[a+1]),xo(t)<Uo?o[a]=o[a+1]=0:(e=o[a]/t,r=o[a+1]/t,i=e*e+r*r,i>9&&(i=3*t/Math.sqrt(i),o[a]=i*e,o[a+1]=i*r));for(a=-1;++a<=l;)i=(n[Math.min(l,a+1)][0]-n[Math.max(0,a-1)][0])/(6*(1+o[a]*o[a])),u.push([i||0,o[a]*i||0]);return u}function Fu(n){return n.length<3?xu(n):n[0]+Au(n,ju(n))}function Hu(n){for(var t,e,r,i=-1,u=n.length;++i<u;)t=n[i],e=t[0],r=t[1]-Io,t[0]=e*Math.cos(r),t[1]=e*Math.sin(r);return n}function Ou(n){function t(t){function l(){v.push("M",a(n(y),s),f,c(n(d.reverse()),s),"Z")}for(var h,p,g,v=[],d=[],y=[],m=-1,M=t.length,x=En(e),b=En(i),_=e===r?function(){
-			return p}:En(r),w=i===u?function(){return g}:En(u);++m<M;)o.call(this,h=t[m],m)?(d.push([p=+x.call(this,h,m),g=+b.call(this,h,m)]),y.push([+_.call(this,h,m),+w.call(this,h,m)])):d.length&&(l(),d=[],y=[]);return d.length&&l(),v.length?v.join(""):null}var e=Ce,r=Ce,i=0,u=ze,o=zt,a=xu,l=a.key,c=a,f="L",s=.7;return t.x=function(n){return arguments.length?(e=r=n,t):r},t.x0=function(n){return arguments.length?(e=n,t):e},t.x1=function(n){return arguments.length?(r=n,t):r},t.y=function(n){return arguments.length?(i=u=n,t):u},t.y0=function(n){return arguments.length?(i=n,t):i},t.y1=function(n){return arguments.length?(u=n,t):u},t.defined=function(n){return arguments.length?(o=n,t):o},t.interpolate=function(n){return arguments.length?(l="function"==typeof n?a=n:(a=Tl.get(n)||xu).key,c=a.reverse||a,f=a.closed?"M":"L",t):l},t.tension=function(n){return arguments.length?(s=n,t):s},t}function Iu(n){return n.radius}function Yu(n){return[n.x,n.y]}function Zu(n){return function(){var t=n.apply(this,arguments),e=t[0],r=t[1]-Io;return[e*Math.cos(r),e*Math.sin(r)]}}function Vu(){return 64}function Xu(){return"circle"}function $u(n){var t=Math.sqrt(n/Fo);return"M0,"+t+"A"+t+","+t+" 0 1,1 0,"+-t+"A"+t+","+t+" 0 1,1 0,"+t+"Z"}function Bu(n){return function(){var t,e,r;(t=this[n])&&(r=t[e=t.active])&&(r.timer.c=null,r.timer.t=NaN,--t.count?delete t[e]:delete this[n],t.active+=.5,r.event&&r.event.interrupt.call(this,this.__data__,r.index))}}function Wu(n,t,e){return ko(n,Yl),n.namespace=t,n.id=e,n}function Ju(n,t,e,r){var i=n.id,u=n.namespace;return Y(n,"function"==typeof e?function(n,o,a){n[u][i].tween.set(t,r(e.call(n,n.__data__,o,a)))}:(e=r(e),function(n){n[u][i].tween.set(t,e)}))}function Gu(n){return null==n&&(n=""),function(){this.textContent=n}}function Ku(n){return null==n?"__transition__":"__transition_"+n+"__"}function Qu(n,t,e,r,i){function u(n){var t=v.delay;return f.t=t+l,n>=t?o(n-t):void(f.c=o)}function o(e){var i=g.active,u=g[i];u&&(u.timer.c=null,u.timer.t=NaN,--g.count,delete g[i],u.event&&u.event.interrupt.call(n,n.__data__,u.index));for(var o in g)if(r>+o){var c=g[o];c.timer.c=null,c.timer.t=NaN,--g.count,delete g[o]}f.c=a,qn(function(){return f.c&&a(e||1)&&(f.c=null,f.t=NaN),1},0,l),g.active=r,v.event&&v.event.start.call(n,n.__data__,t),p=[],v.tween.forEach(function(e,r){(r=r.call(n,n.__data__,t))&&p.push(r)}),h=v.ease,s=v.duration}function a(i){for(var u=i/s,o=h(u),a=p.length;a>0;)p[--a].call(n,o);return u>=1?(v.event&&v.event.end.call(n,n.__data__,t),--g.count?delete g[r]:delete n[e],1):void 0}var l,f,s,h,p,g=n[e]||(n[e]={active:0,count:0}),v=g[r];v||(l=i.time,f=qn(u,0,l),v=g[r]={tween:new c,time:l,timer:f,delay:i.delay,duration:i.duration,ease:i.ease,index:t},i=null,++g.count)}function no(n,t,e){n.attr("transform",function(n){var r=t(n);return"translate("+(isFinite(r)?r:e(n))+",0)"})}function to(n,t,e){n.attr("transform",function(n){var r=t(n);return"translate(0,"+(isFinite(r)?r:e(n))+")"})}function eo(n){return n.toISOString()}function ro(n,t,e){function r(t){return n(t)}function i(n,e){var r=n[1]-n[0],i=r/e,u=ao.bisect(Kl,i);return u==Kl.length?[t.year,Ki(n.map(function(n){return n/31536e6}),e)[2]]:u?t[i/Kl[u-1]<Kl[u]/i?u-1:u]:[tc,Ki(n,e)[2]]}return r.invert=function(t){return io(n.invert(t))},r.domain=function(t){return arguments.length?(n.domain(t),r):n.domain().map(io)},r.nice=function(n,t){function e(e){return!isNaN(e)&&!n.range(e,io(+e+1),t).length}var u=r.domain(),o=Yi(u),a=null==n?i(o,10):"number"==typeof n&&i(o,n);return a&&(n=a[0],t=a[1]),r.domain(Xi(u,t>1?{floor:function(t){for(;e(t=n.floor(t));)t=io(t-1);return t},ceil:function(t){for(;e(t=n.ceil(t));)t=io(+t+1);return t}}:n))},r.ticks=function(n,t){var e=Yi(r.domain()),u=null==n?i(e,10):"number"==typeof n?i(e,n):!n.range&&[{range:n},t];return u&&(n=u[0],t=u[1]),n.range(e[0],io(+e[1]+1),1>t?1:t)},r.tickFormat=function(){return e},r.copy=function(){return ro(n.copy(),t,e)},Ji(r,n)}function io(n){return new Date(n)}function uo(n){return JSON.parse(n.responseText)}function oo(n){var t=fo.createRange();return t.selectNode(fo.body),t.createContextualFragment(n.responseText)}var ao={version:"3.5.17"},lo=[].slice,co=function(n){return lo.call(n)},fo=this.document;if(fo)try{co(fo.documentElement.childNodes)[0].nodeType}catch(so){co=function(n){for(var t=n.length,e=new Array(t);t--;)e[t]=n[t];return e}}if(Date.now||(Date.now=function(){return+new Date}),fo)try{fo.createElement("DIV").style.setProperty("opacity",0,"")}catch(ho){var po=this.Element.prototype,go=po.setAttribute,vo=po.setAttributeNS,yo=this.CSSStyleDeclaration.prototype,mo=yo.setProperty;po.setAttribute=function(n,t){go.call(this,n,t+"")},po.setAttributeNS=function(n,t,e){vo.call(this,n,t,e+"")},yo.setProperty=function(n,t,e){mo.call(this,n,t+"",e)}}ao.ascending=e,ao.descending=function(n,t){return n>t?-1:t>n?1:t>=n?0:NaN},ao.min=function(n,t){var e,r,i=-1,u=n.length;if(1===arguments.length){for(;++i<u;)if(null!=(r=n[i])&&r>=r){e=r;break}for(;++i<u;)null!=(r=n[i])&&e>r&&(e=r)}else{for(;++i<u;)if(null!=(r=t.call(n,n[i],i))&&r>=r){e=r;break}for(;++i<u;)null!=(r=t.call(n,n[i],i))&&e>r&&(e=r)}return e},ao.max=function(n,t){var e,r,i=-1,u=n.length;if(1===arguments.length){for(;++i<u;)if(null!=(r=n[i])&&r>=r){e=r;break}for(;++i<u;)null!=(r=n[i])&&r>e&&(e=r)}else{for(;++i<u;)if(null!=(r=t.call(n,n[i],i))&&r>=r){e=r;break}for(;++i<u;)null!=(r=t.call(n,n[i],i))&&r>e&&(e=r)}return e},ao.extent=function(n,t){var e,r,i,u=-1,o=n.length;if(1===arguments.length){for(;++u<o;)if(null!=(r=n[u])&&r>=r){e=i=r;break}for(;++u<o;)null!=(r=n[u])&&(e>r&&(e=r),r>i&&(i=r))}else{for(;++u<o;)if(null!=(r=t.call(n,n[u],u))&&r>=r){e=i=r;break}for(;++u<o;)null!=(r=t.call(n,n[u],u))&&(e>r&&(e=r),r>i&&(i=r))}return[e,i]},ao.sum=function(n,t){var e,r=0,u=n.length,o=-1;if(1===arguments.length)for(;++o<u;)i(e=+n[o])&&(r+=e);else for(;++o<u;)i(e=+t.call(n,n[o],o))&&(r+=e);return r},ao.mean=function(n,t){var e,u=0,o=n.length,a=-1,l=o;if(1===arguments.length)for(;++a<o;)i(e=r(n[a]))?u+=e:--l;else for(;++a<o;)i(e=r(t.call(n,n[a],a)))?u+=e:--l;return l?u/l:void 0},ao.quantile=function(n,t){var e=(n.length-1)*t+1,r=Math.floor(e),i=+n[r-1],u=e-r;return u?i+u*(n[r]-i):i},ao.median=function(n,t){var u,o=[],a=n.length,l=-1;if(1===arguments.length)for(;++l<a;)i(u=r(n[l]))&&o.push(u);else for(;++l<a;)i(u=r(t.call(n,n[l],l)))&&o.push(u);return o.length?ao.quantile(o.sort(e),.5):void 0},ao.variance=function(n,t){var e,u,o=n.length,a=0,l=0,c=-1,f=0;if(1===arguments.length)for(;++c<o;)i(e=r(n[c]))&&(u=e-a,a+=u/++f,l+=u*(e-a));else for(;++c<o;)i(e=r(t.call(n,n[c],c)))&&(u=e-a,a+=u/++f,l+=u*(e-a));return f>1?l/(f-1):void 0},ao.deviation=function(){var n=ao.variance.apply(this,arguments);return n?Math.sqrt(n):n};var Mo=u(e);ao.bisectLeft=Mo.left,ao.bisect=ao.bisectRight=Mo.right,ao.bisector=function(n){return u(1===n.length?function(t,r){return e(n(t),r)}:n)},ao.shuffle=function(n,t,e){(u=arguments.length)<3&&(e=n.length,2>u&&(t=0));for(var r,i,u=e-t;u;)i=Math.random()*u--|0,r=n[u+t],n[u+t]=n[i+t],n[i+t]=r;return n},ao.permute=function(n,t){for(var e=t.length,r=new Array(e);e--;)r[e]=n[t[e]];return r},ao.pairs=function(n){for(var t,e=0,r=n.length-1,i=n[0],u=new Array(0>r?0:r);r>e;)u[e]=[t=i,i=n[++e]];return u},ao.transpose=function(n){if(!(i=n.length))return[];for(var t=-1,e=ao.min(n,o),r=new Array(e);++t<e;)for(var i,u=-1,a=r[t]=new Array(i);++u<i;)a[u]=n[u][t];return r},ao.zip=function(){return ao.transpose(arguments)},ao.keys=function(n){var t=[];for(var e in n)t.push(e);return t},ao.values=function(n){var t=[];for(var e in n)t.push(n[e]);return t},ao.entries=function(n){var t=[];for(var e in n)t.push({key:e,value:n[e]});return t},ao.merge=function(n){for(var t,e,r,i=n.length,u=-1,o=0;++u<i;)o+=n[u].length;for(e=new Array(o);--i>=0;)for(r=n[i],t=r.length;--t>=0;)e[--o]=r[t];return e};var xo=Math.abs;ao.range=function(n,t,e){if(arguments.length<3&&(e=1,arguments.length<2&&(t=n,n=0)),(t-n)/e===1/0)throw new Error("infinite range");var r,i=[],u=a(xo(e)),o=-1;if(n*=u,t*=u,e*=u,0>e)for(;(r=n+e*++o)>t;)i.push(r/u);else for(;(r=n+e*++o)<t;)i.push(r/u);return i},ao.map=function(n,t){var e=new c;if(n instanceof c)n.forEach(function(n,t){e.set(n,t)});else if(Array.isArray(n)){var r,i=-1,u=n.length;if(1===arguments.length)for(;++i<u;)e.set(i,n[i]);else for(;++i<u;)e.set(t.call(n,r=n[i],i),r)}else for(var o in n)e.set(o,n[o]);return e};var bo="__proto__",_o="\x00";l(c,{has:h,get:function(n){return this._[f(n)]},set:function(n,t){return this._[f(n)]=t},remove:p,keys:g,values:function(){var n=[];for(var t in this._)n.push(this._[t]);return n},entries:function(){var n=[];for(var t in this._)n.push({key:s(t),value:this._[t]});return n},size:v,empty:d,forEach:function(n){for(var t in this._)n.call(this,s(t),this._[t])}}),ao.nest=function(){function n(t,o,a){if(a>=u.length)return r?r.call(i,o):e?o.sort(e):o;for(var l,f,s,h,p=-1,g=o.length,v=u[a++],d=new c;++p<g;)(h=d.get(l=v(f=o[p])))?h.push(f):d.set(l,[f]);return t?(f=t(),s=function(e,r){f.set(e,n(t,r,a))}):(f={},s=function(e,r){f[e]=n(t,r,a)}),d.forEach(s),f}function t(n,e){if(e>=u.length)return n;var r=[],i=o[e++];return n.forEach(function(n,i){r.push({key:n,values:t(i,e)})}),i?r.sort(function(n,t){return i(n.key,t.key)}):r}var e,r,i={},u=[],o=[];return i.map=function(t,e){return n(e,t,0)},i.entries=function(e){return t(n(ao.map,e,0),0)},i.key=function(n){return u.push(n),i},i.sortKeys=function(n){return o[u.length-1]=n,i},i.sortValues=function(n){return e=n,i},i.rollup=function(n){return r=n,i},i},ao.set=function(n){var t=new y;if(n)for(var e=0,r=n.length;r>e;++e)t.add(n[e]);return t},l(y,{has:h,add:function(n){return this._[f(n+="")]=!0,n},remove:p,values:g,size:v,empty:d,forEach:function(n){for(var t in this._)n.call(this,s(t))}}),ao.behavior={},ao.rebind=function(n,t){for(var e,r=1,i=arguments.length;++r<i;)n[e=arguments[r]]=M(n,t,t[e]);return n};var wo=["webkit","ms","moz","Moz","o","O"];ao.dispatch=function(){for(var n=new _,t=-1,e=arguments.length;++t<e;)n[arguments[t]]=w(n);return n},_.prototype.on=function(n,t){var e=n.indexOf("."),r="";if(e>=0&&(r=n.slice(e+1),n=n.slice(0,e)),n)return arguments.length<2?this[n].on(r):this[n].on(r,t);if(2===arguments.length){if(null==t)for(n in this)this.hasOwnProperty(n)&&this[n].on(r,null);return this}},ao.event=null,ao.requote=function(n){return n.replace(So,"\\$&")};var So=/[\\\^\$\*\+\?\|\[\]\(\)\.\{\}]/g,ko={}.__proto__?function(n,t){n.__proto__=t}:function(n,t){for(var e in t)n[e]=t[e]},No=function(n,t){return t.querySelector(n)},Eo=function(n,t){return t.querySelectorAll(n)},Ao=function(n,t){var e=n.matches||n[x(n,"matchesSelector")];return(Ao=function(n,t){return e.call(n,t)})(n,t)};"function"==typeof Sizzle&&(No=function(n,t){return Sizzle(n,t)[0]||null},Eo=Sizzle,Ao=Sizzle.matchesSelector),ao.selection=function(){return ao.select(fo.documentElement)};var Co=ao.selection.prototype=[];Co.select=function(n){var t,e,r,i,u=[];n=A(n);for(var o=-1,a=this.length;++o<a;){u.push(t=[]),t.parentNode=(r=this[o]).parentNode;for(var l=-1,c=r.length;++l<c;)(i=r[l])?(t.push(e=n.call(i,i.__data__,l,o)),e&&"__data__"in i&&(e.__data__=i.__data__)):t.push(null)}return E(u)},Co.selectAll=function(n){var t,e,r=[];n=C(n);for(var i=-1,u=this.length;++i<u;)for(var o=this[i],a=-1,l=o.length;++a<l;)(e=o[a])&&(r.push(t=co(n.call(e,e.__data__,a,i))),t.parentNode=e);return E(r)};var zo="http://www.w3.org/1999/xhtml",Lo={svg:"http://www.w3.org/2000/svg",xhtml:zo,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};ao.ns={prefix:Lo,qualify:function(n){var t=n.indexOf(":"),e=n;return t>=0&&"xmlns"!==(e=n.slice(0,t))&&(n=n.slice(t+1)),Lo.hasOwnProperty(e)?{space:Lo[e],local:n}:n}},Co.attr=function(n,t){if(arguments.length<2){if("string"==typeof n){var e=this.node();return n=ao.ns.qualify(n),n.local?e.getAttributeNS(n.space,n.local):e.getAttribute(n)}for(t in n)this.each(z(t,n[t]));return this}return this.each(z(n,t))},Co.classed=function(n,t){if(arguments.length<2){if("string"==typeof n){var e=this.node(),r=(n=T(n)).length,i=-1;if(t=e.classList){for(;++i<r;)if(!t.contains(n[i]))return!1}else for(t=e.getAttribute("class");++i<r;)if(!q(n[i]).test(t))return!1;return!0}for(t in n)this.each(R(t,n[t]));return this}return this.each(R(n,t))},Co.style=function(n,e,r){var i=arguments.length;if(3>i){if("string"!=typeof n){2>i&&(e="");for(r in n)this.each(P(r,n[r],e));return this}if(2>i){var u=this.node();return t(u).getComputedStyle(u,null).getPropertyValue(n)}r=""}return this.each(P(n,e,r))},Co.property=function(n,t){if(arguments.length<2){if("string"==typeof n)return this.node()[n];for(t in n)this.each(U(t,n[t]));return this}return this.each(U(n,t))},Co.text=function(n){return arguments.length?this.each("function"==typeof n?function(){var t=n.apply(this,arguments);this.textContent=null==t?"":t}:null==n?function(){this.textContent=""}:function(){this.textContent=n}):this.node().textContent},Co.html=function(n){return arguments.length?this.each("function"==typeof n?function(){var t=n.apply(this,arguments);this.innerHTML=null==t?"":t}:null==n?function(){this.innerHTML=""}:function(){this.innerHTML=n}):this.node().innerHTML},Co.append=function(n){return n=j(n),this.select(function(){return this.appendChild(n.apply(this,arguments))})},Co.insert=function(n,t){return n=j(n),t=A(t),this.select(function(){return this.insertBefore(n.apply(this,arguments),t.apply(this,arguments)||null)})},Co.remove=function(){return this.each(F)},Co.data=function(n,t){function e(n,e){var r,i,u,o=n.length,s=e.length,h=Math.min(o,s),p=new Array(s),g=new Array(s),v=new Array(o);if(t){var d,y=new c,m=new Array(o);for(r=-1;++r<o;)(i=n[r])&&(y.has(d=t.call(i,i.__data__,r))?v[r]=i:y.set(d,i),m[r]=d);for(r=-1;++r<s;)(i=y.get(d=t.call(e,u=e[r],r)))?i!==!0&&(p[r]=i,i.__data__=u):g[r]=H(u),y.set(d,!0);for(r=-1;++r<o;)r in m&&y.get(m[r])!==!0&&(v[r]=n[r])}else{for(r=-1;++r<h;)i=n[r],u=e[r],i?(i.__data__=u,p[r]=i):g[r]=H(u);for(;s>r;++r)g[r]=H(e[r]);for(;o>r;++r)v[r]=n[r]}g.update=p,g.parentNode=p.parentNode=v.parentNode=n.parentNode,a.push(g),l.push(p),f.push(v)}var r,i,u=-1,o=this.length;if(!arguments.length){for(n=new Array(o=(r=this[0]).length);++u<o;)(i=r[u])&&(n[u]=i.__data__);return n}var a=Z([]),l=E([]),f=E([]);if("function"==typeof n)for(;++u<o;)e(r=this[u],n.call(r,r.parentNode.__data__,u));else for(;++u<o;)e(r=this[u],n);return l.enter=function(){return a},l.exit=function(){return f},l},Co.datum=function(n){return arguments.length?this.property("__data__",n):this.property("__data__")},Co.filter=function(n){var t,e,r,i=[];"function"!=typeof n&&(n=O(n));for(var u=0,o=this.length;o>u;u++){i.push(t=[]),t.parentNode=(e=this[u]).parentNode;for(var a=0,l=e.length;l>a;a++)(r=e[a])&&n.call(r,r.__data__,a,u)&&t.push(r)}return E(i)},Co.order=function(){for(var n=-1,t=this.length;++n<t;)for(var e,r=this[n],i=r.length-1,u=r[i];--i>=0;)(e=r[i])&&(u&&u!==e.nextSibling&&u.parentNode.insertBefore(e,u),u=e);return this},Co.sort=function(n){n=I.apply(this,arguments);for(var t=-1,e=this.length;++t<e;)this[t].sort(n);return this.order()},Co.each=function(n){return Y(this,function(t,e,r){n.call(t,t.__data__,e,r)})},Co.call=function(n){var t=co(arguments);return n.apply(t[0]=this,t),this},Co.empty=function(){return!this.node()},Co.node=function(){for(var n=0,t=this.length;t>n;n++)for(var e=this[n],r=0,i=e.length;i>r;r++){var u=e[r];if(u)return u}return null},Co.size=function(){var n=0;return Y(this,function(){++n}),n};var qo=[];ao.selection.enter=Z,ao.selection.enter.prototype=qo,qo.append=Co.append,qo.empty=Co.empty,qo.node=Co.node,qo.call=Co.call,qo.size=Co.size,qo.select=function(n){for(var t,e,r,i,u,o=[],a=-1,l=this.length;++a<l;){r=(i=this[a]).update,o.push(t=[]),t.parentNode=i.parentNode;for(var c=-1,f=i.length;++c<f;)(u=i[c])?(t.push(r[c]=e=n.call(i.parentNode,u.__data__,c,a)),e.__data__=u.__data__):t.push(null)}return E(o)},qo.insert=function(n,t){return arguments.length<2&&(t=V(this)),Co.insert.call(this,n,t)},ao.select=function(t){var e;return"string"==typeof t?(e=[No(t,fo)],e.parentNode=fo.documentElement):(e=[t],e.parentNode=n(t)),E([e])},ao.selectAll=function(n){var t;return"string"==typeof n?(t=co(Eo(n,fo)),t.parentNode=fo.documentElement):(t=co(n),t.parentNode=null),E([t])},Co.on=function(n,t,e){var r=arguments.length;if(3>r){if("string"!=typeof n){2>r&&(t=!1);for(e in n)this.each(X(e,n[e],t));return this}if(2>r)return(r=this.node()["__on"+n])&&r._;e=!1}return this.each(X(n,t,e))};var To=ao.map({mouseenter:"mouseover",mouseleave:"mouseout"});fo&&To.forEach(function(n){"on"+n in fo&&To.remove(n)});var Ro,Do=0;ao.mouse=function(n){return J(n,k())};var Po=this.navigator&&/WebKit/.test(this.navigator.userAgent)?-1:0;ao.touch=function(n,t,e){if(arguments.length<3&&(e=t,t=k().changedTouches),t)for(var r,i=0,u=t.length;u>i;++i)if((r=t[i]).identifier===e)return J(n,r)},ao.behavior.drag=function(){function n(){this.on("mousedown.drag",u).on("touchstart.drag",o)}function e(n,t,e,u,o){return function(){function a(){var n,e,r=t(h,v);r&&(n=r[0]-M[0],e=r[1]-M[1],g|=n|e,M=r,p({type:"drag",x:r[0]+c[0],y:r[1]+c[1],dx:n,dy:e}))}function l(){t(h,v)&&(y.on(u+d,null).on(o+d,null),m(g),p({type:"dragend"}))}var c,f=this,s=ao.event.target.correspondingElement||ao.event.target,h=f.parentNode,p=r.of(f,arguments),g=0,v=n(),d=".drag"+(null==v?"":"-"+v),y=ao.select(e(s)).on(u+d,a).on(o+d,l),m=W(s),M=t(h,v);i?(c=i.apply(f,arguments),c=[c.x-M[0],c.y-M[1]]):c=[0,0],p({type:"dragstart"})}}var r=N(n,"drag","dragstart","dragend"),i=null,u=e(b,ao.mouse,t,"mousemove","mouseup"),o=e(G,ao.touch,m,"touchmove","touchend");return n.origin=function(t){return arguments.length?(i=t,n):i},ao.rebind(n,r,"on")},ao.touches=function(n,t){return arguments.length<2&&(t=k().touches),t?co(t).map(function(t){var e=J(n,t);return e.identifier=t.identifier,e}):[]};var Uo=1e-6,jo=Uo*Uo,Fo=Math.PI,Ho=2*Fo,Oo=Ho-Uo,Io=Fo/2,Yo=Fo/180,Zo=180/Fo,Vo=Math.SQRT2,Xo=2,$o=4;ao.interpolateZoom=function(n,t){var e,r,i=n[0],u=n[1],o=n[2],a=t[0],l=t[1],c=t[2],f=a-i,s=l-u,h=f*f+s*s;if(jo>h)r=Math.log(c/o)/Vo,e=function(n){return[i+n*f,u+n*s,o*Math.exp(Vo*n*r)]};else{var p=Math.sqrt(h),g=(c*c-o*o+$o*h)/(2*o*Xo*p),v=(c*c-o*o-$o*h)/(2*c*Xo*p),d=Math.log(Math.sqrt(g*g+1)-g),y=Math.log(Math.sqrt(v*v+1)-v);r=(y-d)/Vo,e=function(n){var t=n*r,e=rn(d),a=o/(Xo*p)*(e*un(Vo*t+d)-en(d));return[i+a*f,u+a*s,o*e/rn(Vo*t+d)]}}return e.duration=1e3*r,e},ao.behavior.zoom=function(){function n(n){n.on(L,s).on(Wo+".zoom",p).on("dblclick.zoom",g).on(R,h)}function e(n){return[(n[0]-k.x)/k.k,(n[1]-k.y)/k.k]}function r(n){return[n[0]*k.k+k.x,n[1]*k.k+k.y]}function i(n){k.k=Math.max(A[0],Math.min(A[1],n))}function u(n,t){t=r(t),k.x+=n[0]-t[0],k.y+=n[1]-t[1]}function o(t,e,r,o){t.__chart__={x:k.x,y:k.y,k:k.k},i(Math.pow(2,o)),u(d=e,r),t=ao.select(t),C>0&&(t=t.transition().duration(C)),t.call(n.event)}function a(){b&&b.domain(x.range().map(function(n){return(n-k.x)/k.k}).map(x.invert)),w&&w.domain(_.range().map(function(n){return(n-k.y)/k.k}).map(_.invert))}function l(n){z++||n({type:"zoomstart"})}function c(n){a(),n({type:"zoom",scale:k.k,translate:[k.x,k.y]})}function f(n){--z||(n({type:"zoomend"}),d=null)}function s(){function n(){a=1,u(ao.mouse(i),h),c(o)}function r(){s.on(q,null).on(T,null),p(a),f(o)}var i=this,o=D.of(i,arguments),a=0,s=ao.select(t(i)).on(q,n).on(T,r),h=e(ao.mouse(i)),p=W(i);Il.call(i),l(o)}function h(){function n(){var n=ao.touches(g);return p=k.k,n.forEach(function(n){n.identifier in d&&(d[n.identifier]=e(n))}),n}function t(){var t=ao.event.target;ao.select(t).on(x,r).on(b,a),_.push(t);for(var e=ao.event.changedTouches,i=0,u=e.length;u>i;++i)d[e[i].identifier]=null;var l=n(),c=Date.now();if(1===l.length){if(500>c-M){var f=l[0];o(g,f,d[f.identifier],Math.floor(Math.log(k.k)/Math.LN2)+1),S()}M=c}else if(l.length>1){var f=l[0],s=l[1],h=f[0]-s[0],p=f[1]-s[1];y=h*h+p*p}}function r(){var n,t,e,r,o=ao.touches(g);Il.call(g);for(var a=0,l=o.length;l>a;++a,r=null)if(e=o[a],r=d[e.identifier]){if(t)break;n=e,t=r}if(r){var f=(f=e[0]-n[0])*f+(f=e[1]-n[1])*f,s=y&&Math.sqrt(f/y);n=[(n[0]+e[0])/2,(n[1]+e[1])/2],t=[(t[0]+r[0])/2,(t[1]+r[1])/2],i(s*p)}M=null,u(n,t),c(v)}function a(){if(ao.event.touches.length){for(var t=ao.event.changedTouches,e=0,r=t.length;r>e;++e)delete d[t[e].identifier];for(var i in d)return void n()}ao.selectAll(_).on(m,null),w.on(L,s).on(R,h),N(),f(v)}var p,g=this,v=D.of(g,arguments),d={},y=0,m=".zoom-"+ao.event.changedTouches[0].identifier,x="touchmove"+m,b="touchend"+m,_=[],w=ao.select(g),N=W(g);t(),l(v),w.on(L,null).on(R,t)}function p(){var n=D.of(this,arguments);m?clearTimeout(m):(Il.call(this),v=e(d=y||ao.mouse(this)),l(n)),m=setTimeout(function(){m=null,f(n)},50),S(),i(Math.pow(2,.002*Bo())*k.k),u(d,v),c(n)}function g(){var n=ao.mouse(this),t=Math.log(k.k)/Math.LN2;o(this,n,e(n),ao.event.shiftKey?Math.ceil(t)-1:Math.floor(t)+1)}var v,d,y,m,M,x,b,_,w,k={x:0,y:0,k:1},E=[960,500],A=Jo,C=250,z=0,L="mousedown.zoom",q="mousemove.zoom",T="mouseup.zoom",R="touchstart.zoom",D=N(n,"zoomstart","zoom","zoomend");return Wo||(Wo="onwheel"in fo?(Bo=function(){return-ao.event.deltaY*(ao.event.deltaMode?120:1)},"wheel"):"onmousewheel"in fo?(Bo=function(){return ao.event.wheelDelta},"mousewheel"):(Bo=function(){return-ao.event.detail},"MozMousePixelScroll")),n.event=function(n){n.each(function(){var n=D.of(this,arguments),t=k;Hl?ao.select(this).transition().each("start.zoom",function(){k=this.__chart__||{x:0,y:0,k:1},l(n)}).tween("zoom:zoom",function(){var e=E[0],r=E[1],i=d?d[0]:e/2,u=d?d[1]:r/2,o=ao.interpolateZoom([(i-k.x)/k.k,(u-k.y)/k.k,e/k.k],[(i-t.x)/t.k,(u-t.y)/t.k,e/t.k]);return function(t){var r=o(t),a=e/r[2];this.__chart__=k={x:i-r[0]*a,y:u-r[1]*a,k:a},c(n)}}).each("interrupt.zoom",function(){f(n)}).each("end.zoom",function(){f(n)}):(this.__chart__=k,l(n),c(n),f(n))})},n.translate=function(t){return arguments.length?(k={x:+t[0],y:+t[1],k:k.k},a(),n):[k.x,k.y]},n.scale=function(t){return arguments.length?(k={x:k.x,y:k.y,k:null},i(+t),a(),n):k.k},n.scaleExtent=function(t){return arguments.length?(A=null==t?Jo:[+t[0],+t[1]],n):A},n.center=function(t){return arguments.length?(y=t&&[+t[0],+t[1]],n):y},n.size=function(t){return arguments.length?(E=t&&[+t[0],+t[1]],n):E},n.duration=function(t){return arguments.length?(C=+t,n):C},n.x=function(t){return arguments.length?(b=t,x=t.copy(),k={x:0,y:0,k:1},n):b},n.y=function(t){return arguments.length?(w=t,_=t.copy(),k={x:0,y:0,k:1},n):w},ao.rebind(n,D,"on")};var Bo,Wo,Jo=[0,1/0];ao.color=an,an.prototype.toString=function(){return this.rgb()+""},ao.hsl=ln;var Go=ln.prototype=new an;Go.brighter=function(n){return n=Math.pow(.7,arguments.length?n:1),new ln(this.h,this.s,this.l/n)},Go.darker=function(n){return n=Math.pow(.7,arguments.length?n:1),new ln(this.h,this.s,n*this.l)},Go.rgb=function(){return cn(this.h,this.s,this.l)},ao.hcl=fn;var Ko=fn.prototype=new an;Ko.brighter=function(n){return new fn(this.h,this.c,Math.min(100,this.l+Qo*(arguments.length?n:1)))},Ko.darker=function(n){return new fn(this.h,this.c,Math.max(0,this.l-Qo*(arguments.length?n:1)))},Ko.rgb=function(){return sn(this.h,this.c,this.l).rgb()},ao.lab=hn;var Qo=18,na=.95047,ta=1,ea=1.08883,ra=hn.prototype=new an;ra.brighter=function(n){return new hn(Math.min(100,this.l+Qo*(arguments.length?n:1)),this.a,this.b)},ra.darker=function(n){return new hn(Math.max(0,this.l-Qo*(arguments.length?n:1)),this.a,this.b)},ra.rgb=function(){return pn(this.l,this.a,this.b)},ao.rgb=mn;var ia=mn.prototype=new an;ia.brighter=function(n){n=Math.pow(.7,arguments.length?n:1);var t=this.r,e=this.g,r=this.b,i=30;return t||e||r?(t&&i>t&&(t=i),e&&i>e&&(e=i),r&&i>r&&(r=i),new mn(Math.min(255,t/n),Math.min(255,e/n),Math.min(255,r/n))):new mn(i,i,i)},ia.darker=function(n){return n=Math.pow(.7,arguments.length?n:1),new mn(n*this.r,n*this.g,n*this.b)},ia.hsl=function(){return wn(this.r,this.g,this.b)},ia.toString=function(){return"#"+bn(this.r)+bn(this.g)+bn(this.b)};var ua=ao.map({aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074});ua.forEach(function(n,t){ua.set(n,Mn(t))}),ao.functor=En,ao.xhr=An(m),ao.dsv=function(n,t){function e(n,e,u){arguments.length<3&&(u=e,e=null);var o=Cn(n,t,null==e?r:i(e),u);return o.row=function(n){return arguments.length?o.response(null==(e=n)?r:i(n)):e},o}function r(n){return e.parse(n.responseText)}function i(n){return function(t){return e.parse(t.responseText,n)}}function u(t){return t.map(o).join(n)}function o(n){return a.test(n)?'"'+n.replace(/\"/g,'""')+'"':n}var a=new RegExp('["'+n+"\n]"),l=n.charCodeAt(0);return e.parse=function(n,t){var r;return e.parseRows(n,function(n,e){if(r)return r(n,e-1);var i=new Function("d","return {"+n.map(function(n,t){return JSON.stringify(n)+": d["+t+"]"}).join(",")+"}");r=t?function(n,e){return t(i(n),e)}:i})},e.parseRows=function(n,t){function e(){if(f>=c)return o;if(i)return i=!1,u;var t=f;if(34===n.charCodeAt(t)){for(var e=t;e++<c;)if(34===n.charCodeAt(e)){if(34!==n.charCodeAt(e+1))break;++e}f=e+2;var r=n.charCodeAt(e+1);return 13===r?(i=!0,10===n.charCodeAt(e+2)&&++f):10===r&&(i=!0),n.slice(t+1,e).replace(/""/g,'"')}for(;c>f;){var r=n.charCodeAt(f++),a=1;if(10===r)i=!0;else if(13===r)i=!0,10===n.charCodeAt(f)&&(++f,++a);else if(r!==l)continue;return n.slice(t,f-a)}return n.slice(t)}for(var r,i,u={},o={},a=[],c=n.length,f=0,s=0;(r=e())!==o;){for(var h=[];r!==u&&r!==o;)h.push(r),r=e();t&&null==(h=t(h,s++))||a.push(h)}return a},e.format=function(t){if(Array.isArray(t[0]))return e.formatRows(t);var r=new y,i=[];return t.forEach(function(n){for(var t in n)r.has(t)||i.push(r.add(t))}),[i.map(o).join(n)].concat(t.map(function(t){return i.map(function(n){return o(t[n])}).join(n)})).join("\n")},e.formatRows=function(n){return n.map(u).join("\n")},e},ao.csv=ao.dsv(",","text/csv"),ao.tsv=ao.dsv("	","text/tab-separated-values");var oa,aa,la,ca,fa=this[x(this,"requestAnimationFrame")]||function(n){setTimeout(n,17)};ao.timer=function(){qn.apply(this,arguments)},ao.timer.flush=function(){Rn(),Dn()},ao.round=function(n,t){return t?Math.round(n*(t=Math.pow(10,t)))/t:Math.round(n)};var sa=["y","z","a","f","p","n","\xb5","m","","k","M","G","T","P","E","Z","Y"].map(Un);ao.formatPrefix=function(n,t){var e=0;return(n=+n)&&(0>n&&(n*=-1),t&&(n=ao.round(n,Pn(n,t))),e=1+Math.floor(1e-12+Math.log(n)/Math.LN10),e=Math.max(-24,Math.min(24,3*Math.floor((e-1)/3)))),sa[8+e/3]};var ha=/(?:([^{])?([<>=^]))?([+\- ])?([$#])?(0)?(\d+)?(,)?(\.-?\d+)?([a-z%])?/i,pa=ao.map({b:function(n){return n.toString(2)},c:function(n){return String.fromCharCode(n)},o:function(n){return n.toString(8)},x:function(n){return n.toString(16)},X:function(n){return n.toString(16).toUpperCase()},g:function(n,t){return n.toPrecision(t)},e:function(n,t){return n.toExponential(t)},f:function(n,t){return n.toFixed(t)},r:function(n,t){return(n=ao.round(n,Pn(n,t))).toFixed(Math.max(0,Math.min(20,Pn(n*(1+1e-15),t))))}}),ga=ao.time={},va=Date;Hn.prototype={getDate:function(){return this._.getUTCDate()},getDay:function(){return this._.getUTCDay()},getFullYear:function(){return this._.getUTCFullYear()},getHours:function(){return this._.getUTCHours()},getMilliseconds:function(){return this._.getUTCMilliseconds()},getMinutes:function(){return this._.getUTCMinutes()},getMonth:function(){return this._.getUTCMonth()},getSeconds:function(){return this._.getUTCSeconds()},getTime:function(){return this._.getTime()},getTimezoneOffset:function(){return 0},valueOf:function(){return this._.valueOf()},setDate:function(){da.setUTCDate.apply(this._,arguments)},setDay:function(){da.setUTCDay.apply(this._,arguments)},setFullYear:function(){da.setUTCFullYear.apply(this._,arguments)},setHours:function(){da.setUTCHours.apply(this._,arguments)},setMilliseconds:function(){da.setUTCMilliseconds.apply(this._,arguments)},setMinutes:function(){da.setUTCMinutes.apply(this._,arguments)},setMonth:function(){da.setUTCMonth.apply(this._,arguments)},setSeconds:function(){da.setUTCSeconds.apply(this._,arguments)},setTime:function(){da.setTime.apply(this._,arguments)}};var da=Date.prototype;ga.year=On(function(n){return n=ga.day(n),n.setMonth(0,1),n},function(n,t){n.setFullYear(n.getFullYear()+t)},function(n){return n.getFullYear()}),ga.years=ga.year.range,ga.years.utc=ga.year.utc.range,ga.day=On(function(n){var t=new va(2e3,0);return t.setFullYear(n.getFullYear(),n.getMonth(),n.getDate()),t},function(n,t){n.setDate(n.getDate()+t)},function(n){return n.getDate()-1}),ga.days=ga.day.range,ga.days.utc=ga.day.utc.range,ga.dayOfYear=function(n){var t=ga.year(n);return Math.floor((n-t-6e4*(n.getTimezoneOffset()-t.getTimezoneOffset()))/864e5)},["sunday","monday","tuesday","wednesday","thursday","friday","saturday"].forEach(function(n,t){t=7-t;var e=ga[n]=On(function(n){return(n=ga.day(n)).setDate(n.getDate()-(n.getDay()+t)%7),n},function(n,t){n.setDate(n.getDate()+7*Math.floor(t))},function(n){var e=ga.year(n).getDay();return Math.floor((ga.dayOfYear(n)+(e+t)%7)/7)-(e!==t)});ga[n+"s"]=e.range,ga[n+"s"].utc=e.utc.range,ga[n+"OfYear"]=function(n){var e=ga.year(n).getDay();return Math.floor((ga.dayOfYear(n)+(e+t)%7)/7)}}),ga.week=ga.sunday,ga.weeks=ga.sunday.range,ga.weeks.utc=ga.sunday.utc.range,ga.weekOfYear=ga.sundayOfYear;var ya={"-":"",_:" ",0:"0"},ma=/^\s*\d+/,Ma=/^%/;ao.locale=function(n){return{numberFormat:jn(n),timeFormat:Yn(n)}};var xa=ao.locale({decimal:".",thousands:",",grouping:[3],currency:["$",""],dateTime:"%a %b %e %X %Y",date:"%m/%d/%Y",time:"%H:%M:%S",periods:["AM","PM"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],
-			shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]});ao.format=xa.numberFormat,ao.geo={},ft.prototype={s:0,t:0,add:function(n){st(n,this.t,ba),st(ba.s,this.s,this),this.s?this.t+=ba.t:this.s=ba.t},reset:function(){this.s=this.t=0},valueOf:function(){return this.s}};var ba=new ft;ao.geo.stream=function(n,t){n&&_a.hasOwnProperty(n.type)?_a[n.type](n,t):ht(n,t)};var _a={Feature:function(n,t){ht(n.geometry,t)},FeatureCollection:function(n,t){for(var e=n.features,r=-1,i=e.length;++r<i;)ht(e[r].geometry,t)}},wa={Sphere:function(n,t){t.sphere()},Point:function(n,t){n=n.coordinates,t.point(n[0],n[1],n[2])},MultiPoint:function(n,t){for(var e=n.coordinates,r=-1,i=e.length;++r<i;)n=e[r],t.point(n[0],n[1],n[2])},LineString:function(n,t){pt(n.coordinates,t,0)},MultiLineString:function(n,t){for(var e=n.coordinates,r=-1,i=e.length;++r<i;)pt(e[r],t,0)},Polygon:function(n,t){gt(n.coordinates,t)},MultiPolygon:function(n,t){for(var e=n.coordinates,r=-1,i=e.length;++r<i;)gt(e[r],t)},GeometryCollection:function(n,t){for(var e=n.geometries,r=-1,i=e.length;++r<i;)ht(e[r],t)}};ao.geo.area=function(n){return Sa=0,ao.geo.stream(n,Na),Sa};var Sa,ka=new ft,Na={sphere:function(){Sa+=4*Fo},point:b,lineStart:b,lineEnd:b,polygonStart:function(){ka.reset(),Na.lineStart=vt},polygonEnd:function(){var n=2*ka;Sa+=0>n?4*Fo+n:n,Na.lineStart=Na.lineEnd=Na.point=b}};ao.geo.bounds=function(){function n(n,t){M.push(x=[f=n,h=n]),s>t&&(s=t),t>p&&(p=t)}function t(t,e){var r=dt([t*Yo,e*Yo]);if(y){var i=mt(y,r),u=[i[1],-i[0],0],o=mt(u,i);bt(o),o=_t(o);var l=t-g,c=l>0?1:-1,v=o[0]*Zo*c,d=xo(l)>180;if(d^(v>c*g&&c*t>v)){var m=o[1]*Zo;m>p&&(p=m)}else if(v=(v+360)%360-180,d^(v>c*g&&c*t>v)){var m=-o[1]*Zo;s>m&&(s=m)}else s>e&&(s=e),e>p&&(p=e);d?g>t?a(f,t)>a(f,h)&&(h=t):a(t,h)>a(f,h)&&(f=t):h>=f?(f>t&&(f=t),t>h&&(h=t)):t>g?a(f,t)>a(f,h)&&(h=t):a(t,h)>a(f,h)&&(f=t)}else n(t,e);y=r,g=t}function e(){b.point=t}function r(){x[0]=f,x[1]=h,b.point=n,y=null}function i(n,e){if(y){var r=n-g;m+=xo(r)>180?r+(r>0?360:-360):r}else v=n,d=e;Na.point(n,e),t(n,e)}function u(){Na.lineStart()}function o(){i(v,d),Na.lineEnd(),xo(m)>Uo&&(f=-(h=180)),x[0]=f,x[1]=h,y=null}function a(n,t){return(t-=n)<0?t+360:t}function l(n,t){return n[0]-t[0]}function c(n,t){return t[0]<=t[1]?t[0]<=n&&n<=t[1]:n<t[0]||t[1]<n}var f,s,h,p,g,v,d,y,m,M,x,b={point:n,lineStart:e,lineEnd:r,polygonStart:function(){b.point=i,b.lineStart=u,b.lineEnd=o,m=0,Na.polygonStart()},polygonEnd:function(){Na.polygonEnd(),b.point=n,b.lineStart=e,b.lineEnd=r,0>ka?(f=-(h=180),s=-(p=90)):m>Uo?p=90:-Uo>m&&(s=-90),x[0]=f,x[1]=h}};return function(n){p=h=-(f=s=1/0),M=[],ao.geo.stream(n,b);var t=M.length;if(t){M.sort(l);for(var e,r=1,i=M[0],u=[i];t>r;++r)e=M[r],c(e[0],i)||c(e[1],i)?(a(i[0],e[1])>a(i[0],i[1])&&(i[1]=e[1]),a(e[0],i[1])>a(i[0],i[1])&&(i[0]=e[0])):u.push(i=e);for(var o,e,g=-(1/0),t=u.length-1,r=0,i=u[t];t>=r;i=e,++r)e=u[r],(o=a(i[1],e[0]))>g&&(g=o,f=e[0],h=i[1])}return M=x=null,f===1/0||s===1/0?[[NaN,NaN],[NaN,NaN]]:[[f,s],[h,p]]}}(),ao.geo.centroid=function(n){Ea=Aa=Ca=za=La=qa=Ta=Ra=Da=Pa=Ua=0,ao.geo.stream(n,ja);var t=Da,e=Pa,r=Ua,i=t*t+e*e+r*r;return jo>i&&(t=qa,e=Ta,r=Ra,Uo>Aa&&(t=Ca,e=za,r=La),i=t*t+e*e+r*r,jo>i)?[NaN,NaN]:[Math.atan2(e,t)*Zo,tn(r/Math.sqrt(i))*Zo]};var Ea,Aa,Ca,za,La,qa,Ta,Ra,Da,Pa,Ua,ja={sphere:b,point:St,lineStart:Nt,lineEnd:Et,polygonStart:function(){ja.lineStart=At},polygonEnd:function(){ja.lineStart=Nt}},Fa=Rt(zt,jt,Ht,[-Fo,-Fo/2]),Ha=1e9;ao.geo.clipExtent=function(){var n,t,e,r,i,u,o={stream:function(n){return i&&(i.valid=!1),i=u(n),i.valid=!0,i},extent:function(a){return arguments.length?(u=Zt(n=+a[0][0],t=+a[0][1],e=+a[1][0],r=+a[1][1]),i&&(i.valid=!1,i=null),o):[[n,t],[e,r]]}};return o.extent([[0,0],[960,500]])},(ao.geo.conicEqualArea=function(){return Vt(Xt)}).raw=Xt,ao.geo.albers=function(){return ao.geo.conicEqualArea().rotate([96,0]).center([-.6,38.7]).parallels([29.5,45.5]).scale(1070)},ao.geo.albersUsa=function(){function n(n){var u=n[0],o=n[1];return t=null,e(u,o),t||(r(u,o),t)||i(u,o),t}var t,e,r,i,u=ao.geo.albers(),o=ao.geo.conicEqualArea().rotate([154,0]).center([-2,58.5]).parallels([55,65]),a=ao.geo.conicEqualArea().rotate([157,0]).center([-3,19.9]).parallels([8,18]),l={point:function(n,e){t=[n,e]}};return n.invert=function(n){var t=u.scale(),e=u.translate(),r=(n[0]-e[0])/t,i=(n[1]-e[1])/t;return(i>=.12&&.234>i&&r>=-.425&&-.214>r?o:i>=.166&&.234>i&&r>=-.214&&-.115>r?a:u).invert(n)},n.stream=function(n){var t=u.stream(n),e=o.stream(n),r=a.stream(n);return{point:function(n,i){t.point(n,i),e.point(n,i),r.point(n,i)},sphere:function(){t.sphere(),e.sphere(),r.sphere()},lineStart:function(){t.lineStart(),e.lineStart(),r.lineStart()},lineEnd:function(){t.lineEnd(),e.lineEnd(),r.lineEnd()},polygonStart:function(){t.polygonStart(),e.polygonStart(),r.polygonStart()},polygonEnd:function(){t.polygonEnd(),e.polygonEnd(),r.polygonEnd()}}},n.precision=function(t){return arguments.length?(u.precision(t),o.precision(t),a.precision(t),n):u.precision()},n.scale=function(t){return arguments.length?(u.scale(t),o.scale(.35*t),a.scale(t),n.translate(u.translate())):u.scale()},n.translate=function(t){if(!arguments.length)return u.translate();var c=u.scale(),f=+t[0],s=+t[1];return e=u.translate(t).clipExtent([[f-.455*c,s-.238*c],[f+.455*c,s+.238*c]]).stream(l).point,r=o.translate([f-.307*c,s+.201*c]).clipExtent([[f-.425*c+Uo,s+.12*c+Uo],[f-.214*c-Uo,s+.234*c-Uo]]).stream(l).point,i=a.translate([f-.205*c,s+.212*c]).clipExtent([[f-.214*c+Uo,s+.166*c+Uo],[f-.115*c-Uo,s+.234*c-Uo]]).stream(l).point,n},n.scale(1070)};var Oa,Ia,Ya,Za,Va,Xa,$a={point:b,lineStart:b,lineEnd:b,polygonStart:function(){Ia=0,$a.lineStart=$t},polygonEnd:function(){$a.lineStart=$a.lineEnd=$a.point=b,Oa+=xo(Ia/2)}},Ba={point:Bt,lineStart:b,lineEnd:b,polygonStart:b,polygonEnd:b},Wa={point:Gt,lineStart:Kt,lineEnd:Qt,polygonStart:function(){Wa.lineStart=ne},polygonEnd:function(){Wa.point=Gt,Wa.lineStart=Kt,Wa.lineEnd=Qt}};ao.geo.path=function(){function n(n){return n&&("function"==typeof a&&u.pointRadius(+a.apply(this,arguments)),o&&o.valid||(o=i(u)),ao.geo.stream(n,o)),u.result()}function t(){return o=null,n}var e,r,i,u,o,a=4.5;return n.area=function(n){return Oa=0,ao.geo.stream(n,i($a)),Oa},n.centroid=function(n){return Ca=za=La=qa=Ta=Ra=Da=Pa=Ua=0,ao.geo.stream(n,i(Wa)),Ua?[Da/Ua,Pa/Ua]:Ra?[qa/Ra,Ta/Ra]:La?[Ca/La,za/La]:[NaN,NaN]},n.bounds=function(n){return Va=Xa=-(Ya=Za=1/0),ao.geo.stream(n,i(Ba)),[[Ya,Za],[Va,Xa]]},n.projection=function(n){return arguments.length?(i=(e=n)?n.stream||re(n):m,t()):e},n.context=function(n){return arguments.length?(u=null==(r=n)?new Wt:new te(n),"function"!=typeof a&&u.pointRadius(a),t()):r},n.pointRadius=function(t){return arguments.length?(a="function"==typeof t?t:(u.pointRadius(+t),+t),n):a},n.projection(ao.geo.albersUsa()).context(null)},ao.geo.transform=function(n){return{stream:function(t){var e=new ie(t);for(var r in n)e[r]=n[r];return e}}},ie.prototype={point:function(n,t){this.stream.point(n,t)},sphere:function(){this.stream.sphere()},lineStart:function(){this.stream.lineStart()},lineEnd:function(){this.stream.lineEnd()},polygonStart:function(){this.stream.polygonStart()},polygonEnd:function(){this.stream.polygonEnd()}},ao.geo.projection=oe,ao.geo.projectionMutator=ae,(ao.geo.equirectangular=function(){return oe(ce)}).raw=ce.invert=ce,ao.geo.rotation=function(n){function t(t){return t=n(t[0]*Yo,t[1]*Yo),t[0]*=Zo,t[1]*=Zo,t}return n=se(n[0]%360*Yo,n[1]*Yo,n.length>2?n[2]*Yo:0),t.invert=function(t){return t=n.invert(t[0]*Yo,t[1]*Yo),t[0]*=Zo,t[1]*=Zo,t},t},fe.invert=ce,ao.geo.circle=function(){function n(){var n="function"==typeof r?r.apply(this,arguments):r,t=se(-n[0]*Yo,-n[1]*Yo,0).invert,i=[];return e(null,null,1,{point:function(n,e){i.push(n=t(n,e)),n[0]*=Zo,n[1]*=Zo}}),{type:"Polygon",coordinates:[i]}}var t,e,r=[0,0],i=6;return n.origin=function(t){return arguments.length?(r=t,n):r},n.angle=function(r){return arguments.length?(e=ve((t=+r)*Yo,i*Yo),n):t},n.precision=function(r){return arguments.length?(e=ve(t*Yo,(i=+r)*Yo),n):i},n.angle(90)},ao.geo.distance=function(n,t){var e,r=(t[0]-n[0])*Yo,i=n[1]*Yo,u=t[1]*Yo,o=Math.sin(r),a=Math.cos(r),l=Math.sin(i),c=Math.cos(i),f=Math.sin(u),s=Math.cos(u);return Math.atan2(Math.sqrt((e=s*o)*e+(e=c*f-l*s*a)*e),l*f+c*s*a)},ao.geo.graticule=function(){function n(){return{type:"MultiLineString",coordinates:t()}}function t(){return ao.range(Math.ceil(u/d)*d,i,d).map(h).concat(ao.range(Math.ceil(c/y)*y,l,y).map(p)).concat(ao.range(Math.ceil(r/g)*g,e,g).filter(function(n){return xo(n%d)>Uo}).map(f)).concat(ao.range(Math.ceil(a/v)*v,o,v).filter(function(n){return xo(n%y)>Uo}).map(s))}var e,r,i,u,o,a,l,c,f,s,h,p,g=10,v=g,d=90,y=360,m=2.5;return n.lines=function(){return t().map(function(n){return{type:"LineString",coordinates:n}})},n.outline=function(){return{type:"Polygon",coordinates:[h(u).concat(p(l).slice(1),h(i).reverse().slice(1),p(c).reverse().slice(1))]}},n.extent=function(t){return arguments.length?n.majorExtent(t).minorExtent(t):n.minorExtent()},n.majorExtent=function(t){return arguments.length?(u=+t[0][0],i=+t[1][0],c=+t[0][1],l=+t[1][1],u>i&&(t=u,u=i,i=t),c>l&&(t=c,c=l,l=t),n.precision(m)):[[u,c],[i,l]]},n.minorExtent=function(t){return arguments.length?(r=+t[0][0],e=+t[1][0],a=+t[0][1],o=+t[1][1],r>e&&(t=r,r=e,e=t),a>o&&(t=a,a=o,o=t),n.precision(m)):[[r,a],[e,o]]},n.step=function(t){return arguments.length?n.majorStep(t).minorStep(t):n.minorStep()},n.majorStep=function(t){return arguments.length?(d=+t[0],y=+t[1],n):[d,y]},n.minorStep=function(t){return arguments.length?(g=+t[0],v=+t[1],n):[g,v]},n.precision=function(t){return arguments.length?(m=+t,f=ye(a,o,90),s=me(r,e,m),h=ye(c,l,90),p=me(u,i,m),n):m},n.majorExtent([[-180,-90+Uo],[180,90-Uo]]).minorExtent([[-180,-80-Uo],[180,80+Uo]])},ao.geo.greatArc=function(){function n(){return{type:"LineString",coordinates:[t||r.apply(this,arguments),e||i.apply(this,arguments)]}}var t,e,r=Me,i=xe;return n.distance=function(){return ao.geo.distance(t||r.apply(this,arguments),e||i.apply(this,arguments))},n.source=function(e){return arguments.length?(r=e,t="function"==typeof e?null:e,n):r},n.target=function(t){return arguments.length?(i=t,e="function"==typeof t?null:t,n):i},n.precision=function(){return arguments.length?n:0},n},ao.geo.interpolate=function(n,t){return be(n[0]*Yo,n[1]*Yo,t[0]*Yo,t[1]*Yo)},ao.geo.length=function(n){return Ja=0,ao.geo.stream(n,Ga),Ja};var Ja,Ga={sphere:b,point:b,lineStart:_e,lineEnd:b,polygonStart:b,polygonEnd:b},Ka=we(function(n){return Math.sqrt(2/(1+n))},function(n){return 2*Math.asin(n/2)});(ao.geo.azimuthalEqualArea=function(){return oe(Ka)}).raw=Ka;var Qa=we(function(n){var t=Math.acos(n);return t&&t/Math.sin(t)},m);(ao.geo.azimuthalEquidistant=function(){return oe(Qa)}).raw=Qa,(ao.geo.conicConformal=function(){return Vt(Se)}).raw=Se,(ao.geo.conicEquidistant=function(){return Vt(ke)}).raw=ke;var nl=we(function(n){return 1/n},Math.atan);(ao.geo.gnomonic=function(){return oe(nl)}).raw=nl,Ne.invert=function(n,t){return[n,2*Math.atan(Math.exp(t))-Io]},(ao.geo.mercator=function(){return Ee(Ne)}).raw=Ne;var tl=we(function(){return 1},Math.asin);(ao.geo.orthographic=function(){return oe(tl)}).raw=tl;var el=we(function(n){return 1/(1+n)},function(n){return 2*Math.atan(n)});(ao.geo.stereographic=function(){return oe(el)}).raw=el,Ae.invert=function(n,t){return[-t,2*Math.atan(Math.exp(n))-Io]},(ao.geo.transverseMercator=function(){var n=Ee(Ae),t=n.center,e=n.rotate;return n.center=function(n){return n?t([-n[1],n[0]]):(n=t(),[n[1],-n[0]])},n.rotate=function(n){return n?e([n[0],n[1],n.length>2?n[2]+90:90]):(n=e(),[n[0],n[1],n[2]-90])},e([0,0,90])}).raw=Ae,ao.geom={},ao.geom.hull=function(n){function t(n){if(n.length<3)return[];var t,i=En(e),u=En(r),o=n.length,a=[],l=[];for(t=0;o>t;t++)a.push([+i.call(this,n[t],t),+u.call(this,n[t],t),t]);for(a.sort(qe),t=0;o>t;t++)l.push([a[t][0],-a[t][1]]);var c=Le(a),f=Le(l),s=f[0]===c[0],h=f[f.length-1]===c[c.length-1],p=[];for(t=c.length-1;t>=0;--t)p.push(n[a[c[t]][2]]);for(t=+s;t<f.length-h;++t)p.push(n[a[f[t]][2]]);return p}var e=Ce,r=ze;return arguments.length?t(n):(t.x=function(n){return arguments.length?(e=n,t):e},t.y=function(n){return arguments.length?(r=n,t):r},t)},ao.geom.polygon=function(n){return ko(n,rl),n};var rl=ao.geom.polygon.prototype=[];rl.area=function(){for(var n,t=-1,e=this.length,r=this[e-1],i=0;++t<e;)n=r,r=this[t],i+=n[1]*r[0]-n[0]*r[1];return.5*i},rl.centroid=function(n){var t,e,r=-1,i=this.length,u=0,o=0,a=this[i-1];for(arguments.length||(n=-1/(6*this.area()));++r<i;)t=a,a=this[r],e=t[0]*a[1]-a[0]*t[1],u+=(t[0]+a[0])*e,o+=(t[1]+a[1])*e;return[u*n,o*n]},rl.clip=function(n){for(var t,e,r,i,u,o,a=De(n),l=-1,c=this.length-De(this),f=this[c-1];++l<c;){for(t=n.slice(),n.length=0,i=this[l],u=t[(r=t.length-a)-1],e=-1;++e<r;)o=t[e],Te(o,f,i)?(Te(u,f,i)||n.push(Re(u,o,f,i)),n.push(o)):Te(u,f,i)&&n.push(Re(u,o,f,i)),u=o;a&&n.push(n[0]),f=i}return n};var il,ul,ol,al,ll,cl=[],fl=[];Ye.prototype.prepare=function(){for(var n,t=this.edges,e=t.length;e--;)n=t[e].edge,n.b&&n.a||t.splice(e,1);return t.sort(Ve),t.length},tr.prototype={start:function(){return this.edge.l===this.site?this.edge.a:this.edge.b},end:function(){return this.edge.l===this.site?this.edge.b:this.edge.a}},er.prototype={insert:function(n,t){var e,r,i;if(n){if(t.P=n,t.N=n.N,n.N&&(n.N.P=t),n.N=t,n.R){for(n=n.R;n.L;)n=n.L;n.L=t}else n.R=t;e=n}else this._?(n=or(this._),t.P=null,t.N=n,n.P=n.L=t,e=n):(t.P=t.N=null,this._=t,e=null);for(t.L=t.R=null,t.U=e,t.C=!0,n=t;e&&e.C;)r=e.U,e===r.L?(i=r.R,i&&i.C?(e.C=i.C=!1,r.C=!0,n=r):(n===e.R&&(ir(this,e),n=e,e=n.U),e.C=!1,r.C=!0,ur(this,r))):(i=r.L,i&&i.C?(e.C=i.C=!1,r.C=!0,n=r):(n===e.L&&(ur(this,e),n=e,e=n.U),e.C=!1,r.C=!0,ir(this,r))),e=n.U;this._.C=!1},remove:function(n){n.N&&(n.N.P=n.P),n.P&&(n.P.N=n.N),n.N=n.P=null;var t,e,r,i=n.U,u=n.L,o=n.R;if(e=u?o?or(o):u:o,i?i.L===n?i.L=e:i.R=e:this._=e,u&&o?(r=e.C,e.C=n.C,e.L=u,u.U=e,e!==o?(i=e.U,e.U=n.U,n=e.R,i.L=n,e.R=o,o.U=e):(e.U=i,i=e,n=e.R)):(r=n.C,n=e),n&&(n.U=i),!r){if(n&&n.C)return void(n.C=!1);do{if(n===this._)break;if(n===i.L){if(t=i.R,t.C&&(t.C=!1,i.C=!0,ir(this,i),t=i.R),t.L&&t.L.C||t.R&&t.R.C){t.R&&t.R.C||(t.L.C=!1,t.C=!0,ur(this,t),t=i.R),t.C=i.C,i.C=t.R.C=!1,ir(this,i),n=this._;break}}else if(t=i.L,t.C&&(t.C=!1,i.C=!0,ur(this,i),t=i.L),t.L&&t.L.C||t.R&&t.R.C){t.L&&t.L.C||(t.R.C=!1,t.C=!0,ir(this,t),t=i.L),t.C=i.C,i.C=t.L.C=!1,ur(this,i),n=this._;break}t.C=!0,n=i,i=i.U}while(!n.C);n&&(n.C=!1)}}},ao.geom.voronoi=function(n){function t(n){var t=new Array(n.length),r=a[0][0],i=a[0][1],u=a[1][0],o=a[1][1];return ar(e(n),a).cells.forEach(function(e,a){var l=e.edges,c=e.site,f=t[a]=l.length?l.map(function(n){var t=n.start();return[t.x,t.y]}):c.x>=r&&c.x<=u&&c.y>=i&&c.y<=o?[[r,o],[u,o],[u,i],[r,i]]:[];f.point=n[a]}),t}function e(n){return n.map(function(n,t){return{x:Math.round(u(n,t)/Uo)*Uo,y:Math.round(o(n,t)/Uo)*Uo,i:t}})}var r=Ce,i=ze,u=r,o=i,a=sl;return n?t(n):(t.links=function(n){return ar(e(n)).edges.filter(function(n){return n.l&&n.r}).map(function(t){return{source:n[t.l.i],target:n[t.r.i]}})},t.triangles=function(n){var t=[];return ar(e(n)).cells.forEach(function(e,r){for(var i,u,o=e.site,a=e.edges.sort(Ve),l=-1,c=a.length,f=a[c-1].edge,s=f.l===o?f.r:f.l;++l<c;)i=f,u=s,f=a[l].edge,s=f.l===o?f.r:f.l,r<u.i&&r<s.i&&cr(o,u,s)<0&&t.push([n[r],n[u.i],n[s.i]])}),t},t.x=function(n){return arguments.length?(u=En(r=n),t):r},t.y=function(n){return arguments.length?(o=En(i=n),t):i},t.clipExtent=function(n){return arguments.length?(a=null==n?sl:n,t):a===sl?null:a},t.size=function(n){return arguments.length?t.clipExtent(n&&[[0,0],n]):a===sl?null:a&&a[1]},t)};var sl=[[-1e6,-1e6],[1e6,1e6]];ao.geom.delaunay=function(n){return ao.geom.voronoi().triangles(n)},ao.geom.quadtree=function(n,t,e,r,i){function u(n){function u(n,t,e,r,i,u,o,a){if(!isNaN(e)&&!isNaN(r))if(n.leaf){var l=n.x,f=n.y;if(null!=l)if(xo(l-e)+xo(f-r)<.01)c(n,t,e,r,i,u,o,a);else{var s=n.point;n.x=n.y=n.point=null,c(n,s,l,f,i,u,o,a),c(n,t,e,r,i,u,o,a)}else n.x=e,n.y=r,n.point=t}else c(n,t,e,r,i,u,o,a)}function c(n,t,e,r,i,o,a,l){var c=.5*(i+a),f=.5*(o+l),s=e>=c,h=r>=f,p=h<<1|s;n.leaf=!1,n=n.nodes[p]||(n.nodes[p]=hr()),s?i=c:a=c,h?o=f:l=f,u(n,t,e,r,i,o,a,l)}var f,s,h,p,g,v,d,y,m,M=En(a),x=En(l);if(null!=t)v=t,d=e,y=r,m=i;else if(y=m=-(v=d=1/0),s=[],h=[],g=n.length,o)for(p=0;g>p;++p)f=n[p],f.x<v&&(v=f.x),f.y<d&&(d=f.y),f.x>y&&(y=f.x),f.y>m&&(m=f.y),s.push(f.x),h.push(f.y);else for(p=0;g>p;++p){var b=+M(f=n[p],p),_=+x(f,p);v>b&&(v=b),d>_&&(d=_),b>y&&(y=b),_>m&&(m=_),s.push(b),h.push(_)}var w=y-v,S=m-d;w>S?m=d+w:y=v+S;var k=hr();if(k.add=function(n){u(k,n,+M(n,++p),+x(n,p),v,d,y,m)},k.visit=function(n){pr(n,k,v,d,y,m)},k.find=function(n){return gr(k,n[0],n[1],v,d,y,m)},p=-1,null==t){for(;++p<g;)u(k,n[p],s[p],h[p],v,d,y,m);--p}else n.forEach(k.add);return s=h=n=f=null,k}var o,a=Ce,l=ze;return(o=arguments.length)?(a=fr,l=sr,3===o&&(i=e,r=t,e=t=0),u(n)):(u.x=function(n){return arguments.length?(a=n,u):a},u.y=function(n){return arguments.length?(l=n,u):l},u.extent=function(n){return arguments.length?(null==n?t=e=r=i=null:(t=+n[0][0],e=+n[0][1],r=+n[1][0],i=+n[1][1]),u):null==t?null:[[t,e],[r,i]]},u.size=function(n){return arguments.length?(null==n?t=e=r=i=null:(t=e=0,r=+n[0],i=+n[1]),u):null==t?null:[r-t,i-e]},u)},ao.interpolateRgb=vr,ao.interpolateObject=dr,ao.interpolateNumber=yr,ao.interpolateString=mr;var hl=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,pl=new RegExp(hl.source,"g");ao.interpolate=Mr,ao.interpolators=[function(n,t){var e=typeof t;return("string"===e?ua.has(t.toLowerCase())||/^(#|rgb\(|hsl\()/i.test(t)?vr:mr:t instanceof an?vr:Array.isArray(t)?xr:"object"===e&&isNaN(t)?dr:yr)(n,t)}],ao.interpolateArray=xr;var gl=function(){return m},vl=ao.map({linear:gl,poly:Er,quad:function(){return Sr},cubic:function(){return kr},sin:function(){return Ar},exp:function(){return Cr},circle:function(){return zr},elastic:Lr,back:qr,bounce:function(){return Tr}}),dl=ao.map({"in":m,out:_r,"in-out":wr,"out-in":function(n){return wr(_r(n))}});ao.ease=function(n){var t=n.indexOf("-"),e=t>=0?n.slice(0,t):n,r=t>=0?n.slice(t+1):"in";return e=vl.get(e)||gl,r=dl.get(r)||m,br(r(e.apply(null,lo.call(arguments,1))))},ao.interpolateHcl=Rr,ao.interpolateHsl=Dr,ao.interpolateLab=Pr,ao.interpolateRound=Ur,ao.transform=function(n){var t=fo.createElementNS(ao.ns.prefix.svg,"g");return(ao.transform=function(n){if(null!=n){t.setAttribute("transform",n);var e=t.transform.baseVal.consolidate()}return new jr(e?e.matrix:yl)})(n)},jr.prototype.toString=function(){return"translate("+this.translate+")rotate("+this.rotate+")skewX("+this.skew+")scale("+this.scale+")"};var yl={a:1,b:0,c:0,d:1,e:0,f:0};ao.interpolateTransform=$r,ao.layout={},ao.layout.bundle=function(){return function(n){for(var t=[],e=-1,r=n.length;++e<r;)t.push(Jr(n[e]));return t}},ao.layout.chord=function(){function n(){var n,c,s,h,p,g={},v=[],d=ao.range(u),y=[];for(e=[],r=[],n=0,h=-1;++h<u;){for(c=0,p=-1;++p<u;)c+=i[h][p];v.push(c),y.push(ao.range(u)),n+=c}for(o&&d.sort(function(n,t){return o(v[n],v[t])}),a&&y.forEach(function(n,t){n.sort(function(n,e){return a(i[t][n],i[t][e])})}),n=(Ho-f*u)/n,c=0,h=-1;++h<u;){for(s=c,p=-1;++p<u;){var m=d[h],M=y[m][p],x=i[m][M],b=c,_=c+=x*n;g[m+"-"+M]={index:m,subindex:M,startAngle:b,endAngle:_,value:x}}r[m]={index:m,startAngle:s,endAngle:c,value:v[m]},c+=f}for(h=-1;++h<u;)for(p=h-1;++p<u;){var w=g[h+"-"+p],S=g[p+"-"+h];(w.value||S.value)&&e.push(w.value<S.value?{source:S,target:w}:{source:w,target:S})}l&&t()}function t(){e.sort(function(n,t){return l((n.source.value+n.target.value)/2,(t.source.value+t.target.value)/2)})}var e,r,i,u,o,a,l,c={},f=0;return c.matrix=function(n){return arguments.length?(u=(i=n)&&i.length,e=r=null,c):i},c.padding=function(n){return arguments.length?(f=n,e=r=null,c):f},c.sortGroups=function(n){return arguments.length?(o=n,e=r=null,c):o},c.sortSubgroups=function(n){return arguments.length?(a=n,e=null,c):a},c.sortChords=function(n){return arguments.length?(l=n,e&&t(),c):l},c.chords=function(){return e||n(),e},c.groups=function(){return r||n(),r},c},ao.layout.force=function(){function n(n){return function(t,e,r,i){if(t.point!==n){var u=t.cx-n.x,o=t.cy-n.y,a=i-e,l=u*u+o*o;if(l>a*a/y){if(v>l){var c=t.charge/l;n.px-=u*c,n.py-=o*c}return!0}if(t.point&&l&&v>l){var c=t.pointCharge/l;n.px-=u*c,n.py-=o*c}}return!t.charge}}function t(n){n.px=ao.event.x,n.py=ao.event.y,l.resume()}var e,r,i,u,o,a,l={},c=ao.dispatch("start","tick","end"),f=[1,1],s=.9,h=ml,p=Ml,g=-30,v=xl,d=.1,y=.64,M=[],x=[];return l.tick=function(){if((i*=.99)<.005)return e=null,c.end({type:"end",alpha:i=0}),!0;var t,r,l,h,p,v,y,m,b,_=M.length,w=x.length;for(r=0;w>r;++r)l=x[r],h=l.source,p=l.target,m=p.x-h.x,b=p.y-h.y,(v=m*m+b*b)&&(v=i*o[r]*((v=Math.sqrt(v))-u[r])/v,m*=v,b*=v,p.x-=m*(y=h.weight+p.weight?h.weight/(h.weight+p.weight):.5),p.y-=b*y,h.x+=m*(y=1-y),h.y+=b*y);if((y=i*d)&&(m=f[0]/2,b=f[1]/2,r=-1,y))for(;++r<_;)l=M[r],l.x+=(m-l.x)*y,l.y+=(b-l.y)*y;if(g)for(ri(t=ao.geom.quadtree(M),i,a),r=-1;++r<_;)(l=M[r]).fixed||t.visit(n(l));for(r=-1;++r<_;)l=M[r],l.fixed?(l.x=l.px,l.y=l.py):(l.x-=(l.px-(l.px=l.x))*s,l.y-=(l.py-(l.py=l.y))*s);c.tick({type:"tick",alpha:i})},l.nodes=function(n){return arguments.length?(M=n,l):M},l.links=function(n){return arguments.length?(x=n,l):x},l.size=function(n){return arguments.length?(f=n,l):f},l.linkDistance=function(n){return arguments.length?(h="function"==typeof n?n:+n,l):h},l.distance=l.linkDistance,l.linkStrength=function(n){return arguments.length?(p="function"==typeof n?n:+n,l):p},l.friction=function(n){return arguments.length?(s=+n,l):s},l.charge=function(n){return arguments.length?(g="function"==typeof n?n:+n,l):g},l.chargeDistance=function(n){return arguments.length?(v=n*n,l):Math.sqrt(v)},l.gravity=function(n){return arguments.length?(d=+n,l):d},l.theta=function(n){return arguments.length?(y=n*n,l):Math.sqrt(y)},l.alpha=function(n){return arguments.length?(n=+n,i?n>0?i=n:(e.c=null,e.t=NaN,e=null,c.end({type:"end",alpha:i=0})):n>0&&(c.start({type:"start",alpha:i=n}),e=qn(l.tick)),l):i},l.start=function(){function n(n,r){if(!e){for(e=new Array(i),l=0;i>l;++l)e[l]=[];for(l=0;c>l;++l){var u=x[l];e[u.source.index].push(u.target),e[u.target.index].push(u.source)}}for(var o,a=e[t],l=-1,f=a.length;++l<f;)if(!isNaN(o=a[l][n]))return o;return Math.random()*r}var t,e,r,i=M.length,c=x.length,s=f[0],v=f[1];for(t=0;i>t;++t)(r=M[t]).index=t,r.weight=0;for(t=0;c>t;++t)r=x[t],"number"==typeof r.source&&(r.source=M[r.source]),"number"==typeof r.target&&(r.target=M[r.target]),++r.source.weight,++r.target.weight;for(t=0;i>t;++t)r=M[t],isNaN(r.x)&&(r.x=n("x",s)),isNaN(r.y)&&(r.y=n("y",v)),isNaN(r.px)&&(r.px=r.x),isNaN(r.py)&&(r.py=r.y);if(u=[],"function"==typeof h)for(t=0;c>t;++t)u[t]=+h.call(this,x[t],t);else for(t=0;c>t;++t)u[t]=h;if(o=[],"function"==typeof p)for(t=0;c>t;++t)o[t]=+p.call(this,x[t],t);else for(t=0;c>t;++t)o[t]=p;if(a=[],"function"==typeof g)for(t=0;i>t;++t)a[t]=+g.call(this,M[t],t);else for(t=0;i>t;++t)a[t]=g;return l.resume()},l.resume=function(){return l.alpha(.1)},l.stop=function(){return l.alpha(0)},l.drag=function(){return r||(r=ao.behavior.drag().origin(m).on("dragstart.force",Qr).on("drag.force",t).on("dragend.force",ni)),arguments.length?void this.on("mouseover.force",ti).on("mouseout.force",ei).call(r):r},ao.rebind(l,c,"on")};var ml=20,Ml=1,xl=1/0;ao.layout.hierarchy=function(){function n(i){var u,o=[i],a=[];for(i.depth=0;null!=(u=o.pop());)if(a.push(u),(c=e.call(n,u,u.depth))&&(l=c.length)){for(var l,c,f;--l>=0;)o.push(f=c[l]),f.parent=u,f.depth=u.depth+1;r&&(u.value=0),u.children=c}else r&&(u.value=+r.call(n,u,u.depth)||0),delete u.children;return oi(i,function(n){var e,i;t&&(e=n.children)&&e.sort(t),r&&(i=n.parent)&&(i.value+=n.value)}),a}var t=ci,e=ai,r=li;return n.sort=function(e){return arguments.length?(t=e,n):t},n.children=function(t){return arguments.length?(e=t,n):e},n.value=function(t){return arguments.length?(r=t,n):r},n.revalue=function(t){return r&&(ui(t,function(n){n.children&&(n.value=0)}),oi(t,function(t){var e;t.children||(t.value=+r.call(n,t,t.depth)||0),(e=t.parent)&&(e.value+=t.value)})),t},n},ao.layout.partition=function(){function n(t,e,r,i){var u=t.children;if(t.x=e,t.y=t.depth*i,t.dx=r,t.dy=i,u&&(o=u.length)){var o,a,l,c=-1;for(r=t.value?r/t.value:0;++c<o;)n(a=u[c],e,l=a.value*r,i),e+=l}}function t(n){var e=n.children,r=0;if(e&&(i=e.length))for(var i,u=-1;++u<i;)r=Math.max(r,t(e[u]));return 1+r}function e(e,u){var o=r.call(this,e,u);return n(o[0],0,i[0],i[1]/t(o[0])),o}var r=ao.layout.hierarchy(),i=[1,1];return e.size=function(n){return arguments.length?(i=n,e):i},ii(e,r)},ao.layout.pie=function(){function n(o){var a,l=o.length,c=o.map(function(e,r){return+t.call(n,e,r)}),f=+("function"==typeof r?r.apply(this,arguments):r),s=("function"==typeof i?i.apply(this,arguments):i)-f,h=Math.min(Math.abs(s)/l,+("function"==typeof u?u.apply(this,arguments):u)),p=h*(0>s?-1:1),g=ao.sum(c),v=g?(s-l*p)/g:0,d=ao.range(l),y=[];return null!=e&&d.sort(e===bl?function(n,t){return c[t]-c[n]}:function(n,t){return e(o[n],o[t])}),d.forEach(function(n){y[n]={data:o[n],value:a=c[n],startAngle:f,endAngle:f+=a*v+p,padAngle:h}}),y}var t=Number,e=bl,r=0,i=Ho,u=0;return n.value=function(e){return arguments.length?(t=e,n):t},n.sort=function(t){return arguments.length?(e=t,n):e},n.startAngle=function(t){return arguments.length?(r=t,n):r},n.endAngle=function(t){return arguments.length?(i=t,n):i},n.padAngle=function(t){return arguments.length?(u=t,n):u},n};var bl={};ao.layout.stack=function(){function n(a,l){if(!(h=a.length))return a;var c=a.map(function(e,r){return t.call(n,e,r)}),f=c.map(function(t){return t.map(function(t,e){return[u.call(n,t,e),o.call(n,t,e)]})}),s=e.call(n,f,l);c=ao.permute(c,s),f=ao.permute(f,s);var h,p,g,v,d=r.call(n,f,l),y=c[0].length;for(g=0;y>g;++g)for(i.call(n,c[0][g],v=d[g],f[0][g][1]),p=1;h>p;++p)i.call(n,c[p][g],v+=f[p-1][g][1],f[p][g][1]);return a}var t=m,e=gi,r=vi,i=pi,u=si,o=hi;return n.values=function(e){return arguments.length?(t=e,n):t},n.order=function(t){return arguments.length?(e="function"==typeof t?t:_l.get(t)||gi,n):e},n.offset=function(t){return arguments.length?(r="function"==typeof t?t:wl.get(t)||vi,n):r},n.x=function(t){return arguments.length?(u=t,n):u},n.y=function(t){return arguments.length?(o=t,n):o},n.out=function(t){return arguments.length?(i=t,n):i},n};var _l=ao.map({"inside-out":function(n){var t,e,r=n.length,i=n.map(di),u=n.map(yi),o=ao.range(r).sort(function(n,t){return i[n]-i[t]}),a=0,l=0,c=[],f=[];for(t=0;r>t;++t)e=o[t],l>a?(a+=u[e],c.push(e)):(l+=u[e],f.push(e));return f.reverse().concat(c)},reverse:function(n){return ao.range(n.length).reverse()},"default":gi}),wl=ao.map({silhouette:function(n){var t,e,r,i=n.length,u=n[0].length,o=[],a=0,l=[];for(e=0;u>e;++e){for(t=0,r=0;i>t;t++)r+=n[t][e][1];r>a&&(a=r),o.push(r)}for(e=0;u>e;++e)l[e]=(a-o[e])/2;return l},wiggle:function(n){var t,e,r,i,u,o,a,l,c,f=n.length,s=n[0],h=s.length,p=[];for(p[0]=l=c=0,e=1;h>e;++e){for(t=0,i=0;f>t;++t)i+=n[t][e][1];for(t=0,u=0,a=s[e][0]-s[e-1][0];f>t;++t){for(r=0,o=(n[t][e][1]-n[t][e-1][1])/(2*a);t>r;++r)o+=(n[r][e][1]-n[r][e-1][1])/a;u+=o*n[t][e][1]}p[e]=l-=i?u/i*a:0,c>l&&(c=l)}for(e=0;h>e;++e)p[e]-=c;return p},expand:function(n){var t,e,r,i=n.length,u=n[0].length,o=1/i,a=[];for(e=0;u>e;++e){for(t=0,r=0;i>t;t++)r+=n[t][e][1];if(r)for(t=0;i>t;t++)n[t][e][1]/=r;else for(t=0;i>t;t++)n[t][e][1]=o}for(e=0;u>e;++e)a[e]=0;return a},zero:vi});ao.layout.histogram=function(){function n(n,u){for(var o,a,l=[],c=n.map(e,this),f=r.call(this,c,u),s=i.call(this,f,c,u),u=-1,h=c.length,p=s.length-1,g=t?1:1/h;++u<p;)o=l[u]=[],o.dx=s[u+1]-(o.x=s[u]),o.y=0;if(p>0)for(u=-1;++u<h;)a=c[u],a>=f[0]&&a<=f[1]&&(o=l[ao.bisect(s,a,1,p)-1],o.y+=g,o.push(n[u]));return l}var t=!0,e=Number,r=bi,i=Mi;return n.value=function(t){return arguments.length?(e=t,n):e},n.range=function(t){return arguments.length?(r=En(t),n):r},n.bins=function(t){return arguments.length?(i="number"==typeof t?function(n){return xi(n,t)}:En(t),n):i},n.frequency=function(e){return arguments.length?(t=!!e,n):t},n},ao.layout.pack=function(){function n(n,u){var o=e.call(this,n,u),a=o[0],l=i[0],c=i[1],f=null==t?Math.sqrt:"function"==typeof t?t:function(){return t};if(a.x=a.y=0,oi(a,function(n){n.r=+f(n.value)}),oi(a,Ni),r){var s=r*(t?1:Math.max(2*a.r/l,2*a.r/c))/2;oi(a,function(n){n.r+=s}),oi(a,Ni),oi(a,function(n){n.r-=s})}return Ci(a,l/2,c/2,t?1:1/Math.max(2*a.r/l,2*a.r/c)),o}var t,e=ao.layout.hierarchy().sort(_i),r=0,i=[1,1];return n.size=function(t){return arguments.length?(i=t,n):i},n.radius=function(e){return arguments.length?(t=null==e||"function"==typeof e?e:+e,n):t},n.padding=function(t){return arguments.length?(r=+t,n):r},ii(n,e)},ao.layout.tree=function(){function n(n,i){var f=o.call(this,n,i),s=f[0],h=t(s);if(oi(h,e),h.parent.m=-h.z,ui(h,r),c)ui(s,u);else{var p=s,g=s,v=s;ui(s,function(n){n.x<p.x&&(p=n),n.x>g.x&&(g=n),n.depth>v.depth&&(v=n)});var d=a(p,g)/2-p.x,y=l[0]/(g.x+a(g,p)/2+d),m=l[1]/(v.depth||1);ui(s,function(n){n.x=(n.x+d)*y,n.y=n.depth*m})}return f}function t(n){for(var t,e={A:null,children:[n]},r=[e];null!=(t=r.pop());)for(var i,u=t.children,o=0,a=u.length;a>o;++o)r.push((u[o]=i={_:u[o],parent:t,children:(i=u[o].children)&&i.slice()||[],A:null,a:null,z:0,m:0,c:0,s:0,t:null,i:o}).a=i);return e.children[0]}function e(n){var t=n.children,e=n.parent.children,r=n.i?e[n.i-1]:null;if(t.length){Di(n);var u=(t[0].z+t[t.length-1].z)/2;r?(n.z=r.z+a(n._,r._),n.m=n.z-u):n.z=u}else r&&(n.z=r.z+a(n._,r._));n.parent.A=i(n,r,n.parent.A||e[0])}function r(n){n._.x=n.z+n.parent.m,n.m+=n.parent.m}function i(n,t,e){if(t){for(var r,i=n,u=n,o=t,l=i.parent.children[0],c=i.m,f=u.m,s=o.m,h=l.m;o=Ti(o),i=qi(i),o&&i;)l=qi(l),u=Ti(u),u.a=n,r=o.z+s-i.z-c+a(o._,i._),r>0&&(Ri(Pi(o,n,e),n,r),c+=r,f+=r),s+=o.m,c+=i.m,h+=l.m,f+=u.m;o&&!Ti(u)&&(u.t=o,u.m+=s-f),i&&!qi(l)&&(l.t=i,l.m+=c-h,e=n)}return e}function u(n){n.x*=l[0],n.y=n.depth*l[1]}var o=ao.layout.hierarchy().sort(null).value(null),a=Li,l=[1,1],c=null;return n.separation=function(t){return arguments.length?(a=t,n):a},n.size=function(t){return arguments.length?(c=null==(l=t)?u:null,n):c?null:l},n.nodeSize=function(t){return arguments.length?(c=null==(l=t)?null:u,n):c?l:null},ii(n,o)},ao.layout.cluster=function(){function n(n,u){var o,a=t.call(this,n,u),l=a[0],c=0;oi(l,function(n){var t=n.children;t&&t.length?(n.x=ji(t),n.y=Ui(t)):(n.x=o?c+=e(n,o):0,n.y=0,o=n)});var f=Fi(l),s=Hi(l),h=f.x-e(f,s)/2,p=s.x+e(s,f)/2;return oi(l,i?function(n){n.x=(n.x-l.x)*r[0],n.y=(l.y-n.y)*r[1]}:function(n){n.x=(n.x-h)/(p-h)*r[0],n.y=(1-(l.y?n.y/l.y:1))*r[1]}),a}var t=ao.layout.hierarchy().sort(null).value(null),e=Li,r=[1,1],i=!1;return n.separation=function(t){return arguments.length?(e=t,n):e},n.size=function(t){return arguments.length?(i=null==(r=t),n):i?null:r},n.nodeSize=function(t){return arguments.length?(i=null!=(r=t),n):i?r:null},ii(n,t)},ao.layout.treemap=function(){function n(n,t){for(var e,r,i=-1,u=n.length;++i<u;)r=(e=n[i]).value*(0>t?0:t),e.area=isNaN(r)||0>=r?0:r}function t(e){var u=e.children;if(u&&u.length){var o,a,l,c=s(e),f=[],h=u.slice(),g=1/0,v="slice"===p?c.dx:"dice"===p?c.dy:"slice-dice"===p?1&e.depth?c.dy:c.dx:Math.min(c.dx,c.dy);for(n(h,c.dx*c.dy/e.value),f.area=0;(l=h.length)>0;)f.push(o=h[l-1]),f.area+=o.area,"squarify"!==p||(a=r(f,v))<=g?(h.pop(),g=a):(f.area-=f.pop().area,i(f,v,c,!1),v=Math.min(c.dx,c.dy),f.length=f.area=0,g=1/0);f.length&&(i(f,v,c,!0),f.length=f.area=0),u.forEach(t)}}function e(t){var r=t.children;if(r&&r.length){var u,o=s(t),a=r.slice(),l=[];for(n(a,o.dx*o.dy/t.value),l.area=0;u=a.pop();)l.push(u),l.area+=u.area,null!=u.z&&(i(l,u.z?o.dx:o.dy,o,!a.length),l.length=l.area=0);r.forEach(e)}}function r(n,t){for(var e,r=n.area,i=0,u=1/0,o=-1,a=n.length;++o<a;)(e=n[o].area)&&(u>e&&(u=e),e>i&&(i=e));return r*=r,t*=t,r?Math.max(t*i*g/r,r/(t*u*g)):1/0}function i(n,t,e,r){var i,u=-1,o=n.length,a=e.x,c=e.y,f=t?l(n.area/t):0;
-			if(t==e.dx){for((r||f>e.dy)&&(f=e.dy);++u<o;)i=n[u],i.x=a,i.y=c,i.dy=f,a+=i.dx=Math.min(e.x+e.dx-a,f?l(i.area/f):0);i.z=!0,i.dx+=e.x+e.dx-a,e.y+=f,e.dy-=f}else{for((r||f>e.dx)&&(f=e.dx);++u<o;)i=n[u],i.x=a,i.y=c,i.dx=f,c+=i.dy=Math.min(e.y+e.dy-c,f?l(i.area/f):0);i.z=!1,i.dy+=e.y+e.dy-c,e.x+=f,e.dx-=f}}function u(r){var i=o||a(r),u=i[0];return u.x=u.y=0,u.value?(u.dx=c[0],u.dy=c[1]):u.dx=u.dy=0,o&&a.revalue(u),n([u],u.dx*u.dy/u.value),(o?e:t)(u),h&&(o=i),i}var o,a=ao.layout.hierarchy(),l=Math.round,c=[1,1],f=null,s=Oi,h=!1,p="squarify",g=.5*(1+Math.sqrt(5));return u.size=function(n){return arguments.length?(c=n,u):c},u.padding=function(n){function t(t){var e=n.call(u,t,t.depth);return null==e?Oi(t):Ii(t,"number"==typeof e?[e,e,e,e]:e)}function e(t){return Ii(t,n)}if(!arguments.length)return f;var r;return s=null==(f=n)?Oi:"function"==(r=typeof n)?t:"number"===r?(n=[n,n,n,n],e):e,u},u.round=function(n){return arguments.length?(l=n?Math.round:Number,u):l!=Number},u.sticky=function(n){return arguments.length?(h=n,o=null,u):h},u.ratio=function(n){return arguments.length?(g=n,u):g},u.mode=function(n){return arguments.length?(p=n+"",u):p},ii(u,a)},ao.random={normal:function(n,t){var e=arguments.length;return 2>e&&(t=1),1>e&&(n=0),function(){var e,r,i;do e=2*Math.random()-1,r=2*Math.random()-1,i=e*e+r*r;while(!i||i>1);return n+t*e*Math.sqrt(-2*Math.log(i)/i)}},logNormal:function(){var n=ao.random.normal.apply(ao,arguments);return function(){return Math.exp(n())}},bates:function(n){var t=ao.random.irwinHall(n);return function(){return t()/n}},irwinHall:function(n){return function(){for(var t=0,e=0;n>e;e++)t+=Math.random();return t}}},ao.scale={};var Sl={floor:m,ceil:m};ao.scale.linear=function(){return Wi([0,1],[0,1],Mr,!1)};var kl={s:1,g:1,p:1,r:1,e:1};ao.scale.log=function(){return ru(ao.scale.linear().domain([0,1]),10,!0,[1,10])};var Nl=ao.format(".0e"),El={floor:function(n){return-Math.ceil(-n)},ceil:function(n){return-Math.floor(-n)}};ao.scale.pow=function(){return iu(ao.scale.linear(),1,[0,1])},ao.scale.sqrt=function(){return ao.scale.pow().exponent(.5)},ao.scale.ordinal=function(){return ou([],{t:"range",a:[[]]})},ao.scale.category10=function(){return ao.scale.ordinal().range(Al)},ao.scale.category20=function(){return ao.scale.ordinal().range(Cl)},ao.scale.category20b=function(){return ao.scale.ordinal().range(zl)},ao.scale.category20c=function(){return ao.scale.ordinal().range(Ll)};var Al=[2062260,16744206,2924588,14034728,9725885,9197131,14907330,8355711,12369186,1556175].map(xn),Cl=[2062260,11454440,16744206,16759672,2924588,10018698,14034728,16750742,9725885,12955861,9197131,12885140,14907330,16234194,8355711,13092807,12369186,14408589,1556175,10410725].map(xn),zl=[3750777,5395619,7040719,10264286,6519097,9216594,11915115,13556636,9202993,12426809,15186514,15190932,8666169,11356490,14049643,15177372,8077683,10834324,13528509,14589654].map(xn),Ll=[3244733,7057110,10406625,13032431,15095053,16616764,16625259,16634018,3253076,7652470,10607003,13101504,7695281,10394312,12369372,14342891,6513507,9868950,12434877,14277081].map(xn);ao.scale.quantile=function(){return au([],[])},ao.scale.quantize=function(){return lu(0,1,[0,1])},ao.scale.threshold=function(){return cu([.5],[0,1])},ao.scale.identity=function(){return fu([0,1])},ao.svg={},ao.svg.arc=function(){function n(){var n=Math.max(0,+e.apply(this,arguments)),c=Math.max(0,+r.apply(this,arguments)),f=o.apply(this,arguments)-Io,s=a.apply(this,arguments)-Io,h=Math.abs(s-f),p=f>s?0:1;if(n>c&&(g=c,c=n,n=g),h>=Oo)return t(c,p)+(n?t(n,1-p):"")+"Z";var g,v,d,y,m,M,x,b,_,w,S,k,N=0,E=0,A=[];if((y=(+l.apply(this,arguments)||0)/2)&&(d=u===ql?Math.sqrt(n*n+c*c):+u.apply(this,arguments),p||(E*=-1),c&&(E=tn(d/c*Math.sin(y))),n&&(N=tn(d/n*Math.sin(y)))),c){m=c*Math.cos(f+E),M=c*Math.sin(f+E),x=c*Math.cos(s-E),b=c*Math.sin(s-E);var C=Math.abs(s-f-2*E)<=Fo?0:1;if(E&&yu(m,M,x,b)===p^C){var z=(f+s)/2;m=c*Math.cos(z),M=c*Math.sin(z),x=b=null}}else m=M=0;if(n){_=n*Math.cos(s-N),w=n*Math.sin(s-N),S=n*Math.cos(f+N),k=n*Math.sin(f+N);var L=Math.abs(f-s+2*N)<=Fo?0:1;if(N&&yu(_,w,S,k)===1-p^L){var q=(f+s)/2;_=n*Math.cos(q),w=n*Math.sin(q),S=k=null}}else _=w=0;if(h>Uo&&(g=Math.min(Math.abs(c-n)/2,+i.apply(this,arguments)))>.001){v=c>n^p?0:1;var T=g,R=g;if(Fo>h){var D=null==S?[_,w]:null==x?[m,M]:Re([m,M],[S,k],[x,b],[_,w]),P=m-D[0],U=M-D[1],j=x-D[0],F=b-D[1],H=1/Math.sin(Math.acos((P*j+U*F)/(Math.sqrt(P*P+U*U)*Math.sqrt(j*j+F*F)))/2),O=Math.sqrt(D[0]*D[0]+D[1]*D[1]);R=Math.min(g,(n-O)/(H-1)),T=Math.min(g,(c-O)/(H+1))}if(null!=x){var I=mu(null==S?[_,w]:[S,k],[m,M],c,T,p),Y=mu([x,b],[_,w],c,T,p);g===T?A.push("M",I[0],"A",T,",",T," 0 0,",v," ",I[1],"A",c,",",c," 0 ",1-p^yu(I[1][0],I[1][1],Y[1][0],Y[1][1]),",",p," ",Y[1],"A",T,",",T," 0 0,",v," ",Y[0]):A.push("M",I[0],"A",T,",",T," 0 1,",v," ",Y[0])}else A.push("M",m,",",M);if(null!=S){var Z=mu([m,M],[S,k],n,-R,p),V=mu([_,w],null==x?[m,M]:[x,b],n,-R,p);g===R?A.push("L",V[0],"A",R,",",R," 0 0,",v," ",V[1],"A",n,",",n," 0 ",p^yu(V[1][0],V[1][1],Z[1][0],Z[1][1]),",",1-p," ",Z[1],"A",R,",",R," 0 0,",v," ",Z[0]):A.push("L",V[0],"A",R,",",R," 0 0,",v," ",Z[0])}else A.push("L",_,",",w)}else A.push("M",m,",",M),null!=x&&A.push("A",c,",",c," 0 ",C,",",p," ",x,",",b),A.push("L",_,",",w),null!=S&&A.push("A",n,",",n," 0 ",L,",",1-p," ",S,",",k);return A.push("Z"),A.join("")}function t(n,t){return"M0,"+n+"A"+n+","+n+" 0 1,"+t+" 0,"+-n+"A"+n+","+n+" 0 1,"+t+" 0,"+n}var e=hu,r=pu,i=su,u=ql,o=gu,a=vu,l=du;return n.innerRadius=function(t){return arguments.length?(e=En(t),n):e},n.outerRadius=function(t){return arguments.length?(r=En(t),n):r},n.cornerRadius=function(t){return arguments.length?(i=En(t),n):i},n.padRadius=function(t){return arguments.length?(u=t==ql?ql:En(t),n):u},n.startAngle=function(t){return arguments.length?(o=En(t),n):o},n.endAngle=function(t){return arguments.length?(a=En(t),n):a},n.padAngle=function(t){return arguments.length?(l=En(t),n):l},n.centroid=function(){var n=(+e.apply(this,arguments)+ +r.apply(this,arguments))/2,t=(+o.apply(this,arguments)+ +a.apply(this,arguments))/2-Io;return[Math.cos(t)*n,Math.sin(t)*n]},n};var ql="auto";ao.svg.line=function(){return Mu(m)};var Tl=ao.map({linear:xu,"linear-closed":bu,step:_u,"step-before":wu,"step-after":Su,basis:zu,"basis-open":Lu,"basis-closed":qu,bundle:Tu,cardinal:Eu,"cardinal-open":ku,"cardinal-closed":Nu,monotone:Fu});Tl.forEach(function(n,t){t.key=n,t.closed=/-closed$/.test(n)});var Rl=[0,2/3,1/3,0],Dl=[0,1/3,2/3,0],Pl=[0,1/6,2/3,1/6];ao.svg.line.radial=function(){var n=Mu(Hu);return n.radius=n.x,delete n.x,n.angle=n.y,delete n.y,n},wu.reverse=Su,Su.reverse=wu,ao.svg.area=function(){return Ou(m)},ao.svg.area.radial=function(){var n=Ou(Hu);return n.radius=n.x,delete n.x,n.innerRadius=n.x0,delete n.x0,n.outerRadius=n.x1,delete n.x1,n.angle=n.y,delete n.y,n.startAngle=n.y0,delete n.y0,n.endAngle=n.y1,delete n.y1,n},ao.svg.chord=function(){function n(n,a){var l=t(this,u,n,a),c=t(this,o,n,a);return"M"+l.p0+r(l.r,l.p1,l.a1-l.a0)+(e(l,c)?i(l.r,l.p1,l.r,l.p0):i(l.r,l.p1,c.r,c.p0)+r(c.r,c.p1,c.a1-c.a0)+i(c.r,c.p1,l.r,l.p0))+"Z"}function t(n,t,e,r){var i=t.call(n,e,r),u=a.call(n,i,r),o=l.call(n,i,r)-Io,f=c.call(n,i,r)-Io;return{r:u,a0:o,a1:f,p0:[u*Math.cos(o),u*Math.sin(o)],p1:[u*Math.cos(f),u*Math.sin(f)]}}function e(n,t){return n.a0==t.a0&&n.a1==t.a1}function r(n,t,e){return"A"+n+","+n+" 0 "+ +(e>Fo)+",1 "+t}function i(n,t,e,r){return"Q 0,0 "+r}var u=Me,o=xe,a=Iu,l=gu,c=vu;return n.radius=function(t){return arguments.length?(a=En(t),n):a},n.source=function(t){return arguments.length?(u=En(t),n):u},n.target=function(t){return arguments.length?(o=En(t),n):o},n.startAngle=function(t){return arguments.length?(l=En(t),n):l},n.endAngle=function(t){return arguments.length?(c=En(t),n):c},n},ao.svg.diagonal=function(){function n(n,i){var u=t.call(this,n,i),o=e.call(this,n,i),a=(u.y+o.y)/2,l=[u,{x:u.x,y:a},{x:o.x,y:a},o];return l=l.map(r),"M"+l[0]+"C"+l[1]+" "+l[2]+" "+l[3]}var t=Me,e=xe,r=Yu;return n.source=function(e){return arguments.length?(t=En(e),n):t},n.target=function(t){return arguments.length?(e=En(t),n):e},n.projection=function(t){return arguments.length?(r=t,n):r},n},ao.svg.diagonal.radial=function(){var n=ao.svg.diagonal(),t=Yu,e=n.projection;return n.projection=function(n){return arguments.length?e(Zu(t=n)):t},n},ao.svg.symbol=function(){function n(n,r){return(Ul.get(t.call(this,n,r))||$u)(e.call(this,n,r))}var t=Xu,e=Vu;return n.type=function(e){return arguments.length?(t=En(e),n):t},n.size=function(t){return arguments.length?(e=En(t),n):e},n};var Ul=ao.map({circle:$u,cross:function(n){var t=Math.sqrt(n/5)/2;return"M"+-3*t+","+-t+"H"+-t+"V"+-3*t+"H"+t+"V"+-t+"H"+3*t+"V"+t+"H"+t+"V"+3*t+"H"+-t+"V"+t+"H"+-3*t+"Z"},diamond:function(n){var t=Math.sqrt(n/(2*Fl)),e=t*Fl;return"M0,"+-t+"L"+e+",0 0,"+t+" "+-e+",0Z"},square:function(n){var t=Math.sqrt(n)/2;return"M"+-t+","+-t+"L"+t+","+-t+" "+t+","+t+" "+-t+","+t+"Z"},"triangle-down":function(n){var t=Math.sqrt(n/jl),e=t*jl/2;return"M0,"+e+"L"+t+","+-e+" "+-t+","+-e+"Z"},"triangle-up":function(n){var t=Math.sqrt(n/jl),e=t*jl/2;return"M0,"+-e+"L"+t+","+e+" "+-t+","+e+"Z"}});ao.svg.symbolTypes=Ul.keys();var jl=Math.sqrt(3),Fl=Math.tan(30*Yo);Co.transition=function(n){for(var t,e,r=Hl||++Zl,i=Ku(n),u=[],o=Ol||{time:Date.now(),ease:Nr,delay:0,duration:250},a=-1,l=this.length;++a<l;){u.push(t=[]);for(var c=this[a],f=-1,s=c.length;++f<s;)(e=c[f])&&Qu(e,f,i,r,o),t.push(e)}return Wu(u,i,r)},Co.interrupt=function(n){return this.each(null==n?Il:Bu(Ku(n)))};var Hl,Ol,Il=Bu(Ku()),Yl=[],Zl=0;Yl.call=Co.call,Yl.empty=Co.empty,Yl.node=Co.node,Yl.size=Co.size,ao.transition=function(n,t){return n&&n.transition?Hl?n.transition(t):n:ao.selection().transition(n)},ao.transition.prototype=Yl,Yl.select=function(n){var t,e,r,i=this.id,u=this.namespace,o=[];n=A(n);for(var a=-1,l=this.length;++a<l;){o.push(t=[]);for(var c=this[a],f=-1,s=c.length;++f<s;)(r=c[f])&&(e=n.call(r,r.__data__,f,a))?("__data__"in r&&(e.__data__=r.__data__),Qu(e,f,u,i,r[u][i]),t.push(e)):t.push(null)}return Wu(o,u,i)},Yl.selectAll=function(n){var t,e,r,i,u,o=this.id,a=this.namespace,l=[];n=C(n);for(var c=-1,f=this.length;++c<f;)for(var s=this[c],h=-1,p=s.length;++h<p;)if(r=s[h]){u=r[a][o],e=n.call(r,r.__data__,h,c),l.push(t=[]);for(var g=-1,v=e.length;++g<v;)(i=e[g])&&Qu(i,g,a,o,u),t.push(i)}return Wu(l,a,o)},Yl.filter=function(n){var t,e,r,i=[];"function"!=typeof n&&(n=O(n));for(var u=0,o=this.length;o>u;u++){i.push(t=[]);for(var e=this[u],a=0,l=e.length;l>a;a++)(r=e[a])&&n.call(r,r.__data__,a,u)&&t.push(r)}return Wu(i,this.namespace,this.id)},Yl.tween=function(n,t){var e=this.id,r=this.namespace;return arguments.length<2?this.node()[r][e].tween.get(n):Y(this,null==t?function(t){t[r][e].tween.remove(n)}:function(i){i[r][e].tween.set(n,t)})},Yl.attr=function(n,t){function e(){this.removeAttribute(a)}function r(){this.removeAttributeNS(a.space,a.local)}function i(n){return null==n?e:(n+="",function(){var t,e=this.getAttribute(a);return e!==n&&(t=o(e,n),function(n){this.setAttribute(a,t(n))})})}function u(n){return null==n?r:(n+="",function(){var t,e=this.getAttributeNS(a.space,a.local);return e!==n&&(t=o(e,n),function(n){this.setAttributeNS(a.space,a.local,t(n))})})}if(arguments.length<2){for(t in n)this.attr(t,n[t]);return this}var o="transform"==n?$r:Mr,a=ao.ns.qualify(n);return Ju(this,"attr."+n,t,a.local?u:i)},Yl.attrTween=function(n,t){function e(n,e){var r=t.call(this,n,e,this.getAttribute(i));return r&&function(n){this.setAttribute(i,r(n))}}function r(n,e){var r=t.call(this,n,e,this.getAttributeNS(i.space,i.local));return r&&function(n){this.setAttributeNS(i.space,i.local,r(n))}}var i=ao.ns.qualify(n);return this.tween("attr."+n,i.local?r:e)},Yl.style=function(n,e,r){function i(){this.style.removeProperty(n)}function u(e){return null==e?i:(e+="",function(){var i,u=t(this).getComputedStyle(this,null).getPropertyValue(n);return u!==e&&(i=Mr(u,e),function(t){this.style.setProperty(n,i(t),r)})})}var o=arguments.length;if(3>o){if("string"!=typeof n){2>o&&(e="");for(r in n)this.style(r,n[r],e);return this}r=""}return Ju(this,"style."+n,e,u)},Yl.styleTween=function(n,e,r){function i(i,u){var o=e.call(this,i,u,t(this).getComputedStyle(this,null).getPropertyValue(n));return o&&function(t){this.style.setProperty(n,o(t),r)}}return arguments.length<3&&(r=""),this.tween("style."+n,i)},Yl.text=function(n){return Ju(this,"text",n,Gu)},Yl.remove=function(){var n=this.namespace;return this.each("end.transition",function(){var t;this[n].count<2&&(t=this.parentNode)&&t.removeChild(this)})},Yl.ease=function(n){var t=this.id,e=this.namespace;return arguments.length<1?this.node()[e][t].ease:("function"!=typeof n&&(n=ao.ease.apply(ao,arguments)),Y(this,function(r){r[e][t].ease=n}))},Yl.delay=function(n){var t=this.id,e=this.namespace;return arguments.length<1?this.node()[e][t].delay:Y(this,"function"==typeof n?function(r,i,u){r[e][t].delay=+n.call(r,r.__data__,i,u)}:(n=+n,function(r){r[e][t].delay=n}))},Yl.duration=function(n){var t=this.id,e=this.namespace;return arguments.length<1?this.node()[e][t].duration:Y(this,"function"==typeof n?function(r,i,u){r[e][t].duration=Math.max(1,n.call(r,r.__data__,i,u))}:(n=Math.max(1,n),function(r){r[e][t].duration=n}))},Yl.each=function(n,t){var e=this.id,r=this.namespace;if(arguments.length<2){var i=Ol,u=Hl;try{Hl=e,Y(this,function(t,i,u){Ol=t[r][e],n.call(t,t.__data__,i,u)})}finally{Ol=i,Hl=u}}else Y(this,function(i){var u=i[r][e];(u.event||(u.event=ao.dispatch("start","end","interrupt"))).on(n,t)});return this},Yl.transition=function(){for(var n,t,e,r,i=this.id,u=++Zl,o=this.namespace,a=[],l=0,c=this.length;c>l;l++){a.push(n=[]);for(var t=this[l],f=0,s=t.length;s>f;f++)(e=t[f])&&(r=e[o][i],Qu(e,f,o,u,{time:r.time,ease:r.ease,delay:r.delay+r.duration,duration:r.duration})),n.push(e)}return Wu(a,o,u)},ao.svg.axis=function(){function n(n){n.each(function(){var n,c=ao.select(this),f=this.__chart__||e,s=this.__chart__=e.copy(),h=null==l?s.ticks?s.ticks.apply(s,a):s.domain():l,p=null==t?s.tickFormat?s.tickFormat.apply(s,a):m:t,g=c.selectAll(".tick").data(h,s),v=g.enter().insert("g",".domain").attr("class","tick").style("opacity",Uo),d=ao.transition(g.exit()).style("opacity",Uo).remove(),y=ao.transition(g.order()).style("opacity",1),M=Math.max(i,0)+o,x=Zi(s),b=c.selectAll(".domain").data([0]),_=(b.enter().append("path").attr("class","domain"),ao.transition(b));v.append("line"),v.append("text");var w,S,k,N,E=v.select("line"),A=y.select("line"),C=g.select("text").text(p),z=v.select("text"),L=y.select("text"),q="top"===r||"left"===r?-1:1;if("bottom"===r||"top"===r?(n=no,w="x",k="y",S="x2",N="y2",C.attr("dy",0>q?"0em":".71em").style("text-anchor","middle"),_.attr("d","M"+x[0]+","+q*u+"V0H"+x[1]+"V"+q*u)):(n=to,w="y",k="x",S="y2",N="x2",C.attr("dy",".32em").style("text-anchor",0>q?"end":"start"),_.attr("d","M"+q*u+","+x[0]+"H0V"+x[1]+"H"+q*u)),E.attr(N,q*i),z.attr(k,q*M),A.attr(S,0).attr(N,q*i),L.attr(w,0).attr(k,q*M),s.rangeBand){var T=s,R=T.rangeBand()/2;f=s=function(n){return T(n)+R}}else f.rangeBand?f=s:d.call(n,s,f);v.call(n,f,s),y.call(n,s,s)})}var t,e=ao.scale.linear(),r=Vl,i=6,u=6,o=3,a=[10],l=null;return n.scale=function(t){return arguments.length?(e=t,n):e},n.orient=function(t){return arguments.length?(r=t in Xl?t+"":Vl,n):r},n.ticks=function(){return arguments.length?(a=co(arguments),n):a},n.tickValues=function(t){return arguments.length?(l=t,n):l},n.tickFormat=function(e){return arguments.length?(t=e,n):t},n.tickSize=function(t){var e=arguments.length;return e?(i=+t,u=+arguments[e-1],n):i},n.innerTickSize=function(t){return arguments.length?(i=+t,n):i},n.outerTickSize=function(t){return arguments.length?(u=+t,n):u},n.tickPadding=function(t){return arguments.length?(o=+t,n):o},n.tickSubdivide=function(){return arguments.length&&n},n};var Vl="bottom",Xl={top:1,right:1,bottom:1,left:1};ao.svg.brush=function(){function n(t){t.each(function(){var t=ao.select(this).style("pointer-events","all").style("-webkit-tap-highlight-color","rgba(0,0,0,0)").on("mousedown.brush",u).on("touchstart.brush",u),o=t.selectAll(".background").data([0]);o.enter().append("rect").attr("class","background").style("visibility","hidden").style("cursor","crosshair"),t.selectAll(".extent").data([0]).enter().append("rect").attr("class","extent").style("cursor","move");var a=t.selectAll(".resize").data(v,m);a.exit().remove(),a.enter().append("g").attr("class",function(n){return"resize "+n}).style("cursor",function(n){return $l[n]}).append("rect").attr("x",function(n){return/[ew]$/.test(n)?-3:null}).attr("y",function(n){return/^[ns]/.test(n)?-3:null}).attr("width",6).attr("height",6).style("visibility","hidden"),a.style("display",n.empty()?"none":null);var l,s=ao.transition(t),h=ao.transition(o);c&&(l=Zi(c),h.attr("x",l[0]).attr("width",l[1]-l[0]),r(s)),f&&(l=Zi(f),h.attr("y",l[0]).attr("height",l[1]-l[0]),i(s)),e(s)})}function e(n){n.selectAll(".resize").attr("transform",function(n){return"translate("+s[+/e$/.test(n)]+","+h[+/^s/.test(n)]+")"})}function r(n){n.select(".extent").attr("x",s[0]),n.selectAll(".extent,.n>rect,.s>rect").attr("width",s[1]-s[0])}function i(n){n.select(".extent").attr("y",h[0]),n.selectAll(".extent,.e>rect,.w>rect").attr("height",h[1]-h[0])}function u(){function u(){32==ao.event.keyCode&&(C||(M=null,L[0]-=s[1],L[1]-=h[1],C=2),S())}function v(){32==ao.event.keyCode&&2==C&&(L[0]+=s[1],L[1]+=h[1],C=0,S())}function d(){var n=ao.mouse(b),t=!1;x&&(n[0]+=x[0],n[1]+=x[1]),C||(ao.event.altKey?(M||(M=[(s[0]+s[1])/2,(h[0]+h[1])/2]),L[0]=s[+(n[0]<M[0])],L[1]=h[+(n[1]<M[1])]):M=null),E&&y(n,c,0)&&(r(k),t=!0),A&&y(n,f,1)&&(i(k),t=!0),t&&(e(k),w({type:"brush",mode:C?"move":"resize"}))}function y(n,t,e){var r,i,u=Zi(t),l=u[0],c=u[1],f=L[e],v=e?h:s,d=v[1]-v[0];return C&&(l-=f,c-=d+f),r=(e?g:p)?Math.max(l,Math.min(c,n[e])):n[e],C?i=(r+=f)+d:(M&&(f=Math.max(l,Math.min(c,2*M[e]-r))),r>f?(i=r,r=f):i=f),v[0]!=r||v[1]!=i?(e?a=null:o=null,v[0]=r,v[1]=i,!0):void 0}function m(){d(),k.style("pointer-events","all").selectAll(".resize").style("display",n.empty()?"none":null),ao.select("body").style("cursor",null),q.on("mousemove.brush",null).on("mouseup.brush",null).on("touchmove.brush",null).on("touchend.brush",null).on("keydown.brush",null).on("keyup.brush",null),z(),w({type:"brushend"})}var M,x,b=this,_=ao.select(ao.event.target),w=l.of(b,arguments),k=ao.select(b),N=_.datum(),E=!/^(n|s)$/.test(N)&&c,A=!/^(e|w)$/.test(N)&&f,C=_.classed("extent"),z=W(b),L=ao.mouse(b),q=ao.select(t(b)).on("keydown.brush",u).on("keyup.brush",v);if(ao.event.changedTouches?q.on("touchmove.brush",d).on("touchend.brush",m):q.on("mousemove.brush",d).on("mouseup.brush",m),k.interrupt().selectAll("*").interrupt(),C)L[0]=s[0]-L[0],L[1]=h[0]-L[1];else if(N){var T=+/w$/.test(N),R=+/^n/.test(N);x=[s[1-T]-L[0],h[1-R]-L[1]],L[0]=s[T],L[1]=h[R]}else ao.event.altKey&&(M=L.slice());k.style("pointer-events","none").selectAll(".resize").style("display",null),ao.select("body").style("cursor",_.style("cursor")),w({type:"brushstart"}),d()}var o,a,l=N(n,"brushstart","brush","brushend"),c=null,f=null,s=[0,0],h=[0,0],p=!0,g=!0,v=Bl[0];return n.event=function(n){n.each(function(){var n=l.of(this,arguments),t={x:s,y:h,i:o,j:a},e=this.__chart__||t;this.__chart__=t,Hl?ao.select(this).transition().each("start.brush",function(){o=e.i,a=e.j,s=e.x,h=e.y,n({type:"brushstart"})}).tween("brush:brush",function(){var e=xr(s,t.x),r=xr(h,t.y);return o=a=null,function(i){s=t.x=e(i),h=t.y=r(i),n({type:"brush",mode:"resize"})}}).each("end.brush",function(){o=t.i,a=t.j,n({type:"brush",mode:"resize"}),n({type:"brushend"})}):(n({type:"brushstart"}),n({type:"brush",mode:"resize"}),n({type:"brushend"}))})},n.x=function(t){return arguments.length?(c=t,v=Bl[!c<<1|!f],n):c},n.y=function(t){return arguments.length?(f=t,v=Bl[!c<<1|!f],n):f},n.clamp=function(t){return arguments.length?(c&&f?(p=!!t[0],g=!!t[1]):c?p=!!t:f&&(g=!!t),n):c&&f?[p,g]:c?p:f?g:null},n.extent=function(t){var e,r,i,u,l;return arguments.length?(c&&(e=t[0],r=t[1],f&&(e=e[0],r=r[0]),o=[e,r],c.invert&&(e=c(e),r=c(r)),e>r&&(l=e,e=r,r=l),e==s[0]&&r==s[1]||(s=[e,r])),f&&(i=t[0],u=t[1],c&&(i=i[1],u=u[1]),a=[i,u],f.invert&&(i=f(i),u=f(u)),i>u&&(l=i,i=u,u=l),i==h[0]&&u==h[1]||(h=[i,u])),n):(c&&(o?(e=o[0],r=o[1]):(e=s[0],r=s[1],c.invert&&(e=c.invert(e),r=c.invert(r)),e>r&&(l=e,e=r,r=l))),f&&(a?(i=a[0],u=a[1]):(i=h[0],u=h[1],f.invert&&(i=f.invert(i),u=f.invert(u)),i>u&&(l=i,i=u,u=l))),c&&f?[[e,i],[r,u]]:c?[e,r]:f&&[i,u])},n.clear=function(){return n.empty()||(s=[0,0],h=[0,0],o=a=null),n},n.empty=function(){return!!c&&s[0]==s[1]||!!f&&h[0]==h[1]},ao.rebind(n,l,"on")};var $l={n:"ns-resize",e:"ew-resize",s:"ns-resize",w:"ew-resize",nw:"nwse-resize",ne:"nesw-resize",se:"nwse-resize",sw:"nesw-resize"},Bl=[["n","e","s","w","nw","ne","se","sw"],["e","w"],["n","s"],[]],Wl=ga.format=xa.timeFormat,Jl=Wl.utc,Gl=Jl("%Y-%m-%dT%H:%M:%S.%LZ");Wl.iso=Date.prototype.toISOString&&+new Date("2000-01-01T00:00:00.000Z")?eo:Gl,eo.parse=function(n){var t=new Date(n);return isNaN(t)?null:t},eo.toString=Gl.toString,ga.second=On(function(n){return new va(1e3*Math.floor(n/1e3))},function(n,t){n.setTime(n.getTime()+1e3*Math.floor(t))},function(n){return n.getSeconds()}),ga.seconds=ga.second.range,ga.seconds.utc=ga.second.utc.range,ga.minute=On(function(n){return new va(6e4*Math.floor(n/6e4))},function(n,t){n.setTime(n.getTime()+6e4*Math.floor(t))},function(n){return n.getMinutes()}),ga.minutes=ga.minute.range,ga.minutes.utc=ga.minute.utc.range,ga.hour=On(function(n){var t=n.getTimezoneOffset()/60;return new va(36e5*(Math.floor(n/36e5-t)+t))},function(n,t){n.setTime(n.getTime()+36e5*Math.floor(t))},function(n){return n.getHours()}),ga.hours=ga.hour.range,ga.hours.utc=ga.hour.utc.range,ga.month=On(function(n){return n=ga.day(n),n.setDate(1),n},function(n,t){n.setMonth(n.getMonth()+t)},function(n){return n.getMonth()}),ga.months=ga.month.range,ga.months.utc=ga.month.utc.range;var Kl=[1e3,5e3,15e3,3e4,6e4,3e5,9e5,18e5,36e5,108e5,216e5,432e5,864e5,1728e5,6048e5,2592e6,7776e6,31536e6],Ql=[[ga.second,1],[ga.second,5],[ga.second,15],[ga.second,30],[ga.minute,1],[ga.minute,5],[ga.minute,15],[ga.minute,30],[ga.hour,1],[ga.hour,3],[ga.hour,6],[ga.hour,12],[ga.day,1],[ga.day,2],[ga.week,1],[ga.month,1],[ga.month,3],[ga.year,1]],nc=Wl.multi([[".%L",function(n){return n.getMilliseconds()}],[":%S",function(n){return n.getSeconds()}],["%I:%M",function(n){return n.getMinutes()}],["%I %p",function(n){return n.getHours()}],["%a %d",function(n){return n.getDay()&&1!=n.getDate()}],["%b %d",function(n){return 1!=n.getDate()}],["%B",function(n){return n.getMonth()}],["%Y",zt]]),tc={range:function(n,t,e){return ao.range(Math.ceil(n/e)*e,+t,e).map(io)},floor:m,ceil:m};Ql.year=ga.year,ga.scale=function(){return ro(ao.scale.linear(),Ql,nc)};var ec=Ql.map(function(n){return[n[0].utc,n[1]]}),rc=Jl.multi([[".%L",function(n){return n.getUTCMilliseconds()}],[":%S",function(n){return n.getUTCSeconds()}],["%I:%M",function(n){return n.getUTCMinutes()}],["%I %p",function(n){return n.getUTCHours()}],["%a %d",function(n){return n.getUTCDay()&&1!=n.getUTCDate()}],["%b %d",function(n){return 1!=n.getUTCDate()}],["%B",function(n){return n.getUTCMonth()}],["%Y",zt]]);ec.year=ga.year.utc,ga.scale.utc=function(){return ro(ao.scale.linear(),ec,rc)},ao.text=An(function(n){return n.responseText}),ao.json=function(n,t){return Cn(n,"application/json",uo,t)},ao.html=function(n,t){return Cn(n,"text/html",oo,t)},ao.xml=An(function(n){return n.responseXML}),"function"==typeof define&&define.amd?(this.d3=ao,define(ao)):"object"==typeof module&&module.exports?module.exports=ao:this.d3=ao}();},{}],
-			2:[function(require,module,exports){
-			"use strict";
-
-			var d3 = require('d3');
-
-
-			//aigner: functions for drawing expand- and collapse-symbols
-			function drawExpandSymbol(aCircle, line1, line2)
-			{        
-				 aCircle = aCircle
-					.attr("r", 10)
-					.style("stroke", "black")
-					.style("stroke-width", 2)
-					.style("fill", "#99CC00")
-					.style("fill-opacity", .6)
-				line1 = line1
-					.attr("x1", parseFloat(aCircle.attr("cx"))-5)
-					.attr("y1", parseFloat(aCircle.attr("cy")))
-					.attr("x2", parseFloat(aCircle.attr("cx"))+5)
-					.attr("y2", parseFloat(aCircle.attr("cy")))
-					.style("stroke", "black")
-					.style("stroke-width", 2);
-				line2 = line2
-					.attr("x1", parseFloat(aCircle.attr("cx")))
-					.attr("y1", parseFloat(aCircle.attr("cy"))-5)
-					.attr("x2", parseFloat(aCircle.attr("cx")))
-					.attr("y2", parseFloat(aCircle.attr("cy"))+5)
-					.style("stroke", "black")
-					.style("stroke-width", 2);
-			}
-			function drawRemoveSymbol(anXdsm, aCircle, aMinus)
-			{        
-				 var xOffset=150;
-				 var yOffset=12;
-				 aCircle = aCircle
-					.attr("cx", anXdsm.svg.attr("width")-xOffset)
-					.attr("cy", yOffset)
-					.attr("r", 10)
-					.classed("remCircle",true)
-				aMinus = aMinus
-					.attr("x1", anXdsm.svg.attr("width")-xOffset+5)
-					.attr("y1", yOffset)
-					.attr("x2", anXdsm.svg.attr("width")-xOffset-5)
-					.attr("y2", yOffset)
-					.classed("remMinus",true)
-			}
-			//d3-context-menu for right-click-option
-			d3.contextMenu = function (menu, openCallback) {
-
-				// create the div element that will hold the context menu
-				d3.selectAll('.d3-context-menu').data([1])
-					.enter()
-					.append('div')
-					.attr('class', 'd3-context-menu');
-
-				// close menu
-				d3.select('body').on('click.d3-context-menu', function() {
-					d3.select('.d3-context-menu').style('display', 'none');
-				});
-
-				// this gets executed when a contextmenu event occurs
-				return function(data, index) {	
-					var elm = this;
-
-					d3.selectAll('.d3-context-menu').html('');
-					var list = d3.selectAll('.d3-context-menu').append('ul');
-						list.selectAll('li').data(menu).enter()
-						.append('li')
-						.html(function(d) {
-							return d.title;
-						})
-						.on('mousedown', function(d, i) {
-							d.onMouseDown(elm, data, index);
-						})
-						.on('mouseup', function(d, i) {
-							d.onMouseUp(elm, data, index);
-							d3.select('.d3-context-menu').style('display', 'none');
-						})
-						.on('mouseenter',function(d,i){
-							d.onMouseOver(elm,data,index);
-							if(d.childrenItems.length>0 )
-								 {
-                                  var li = this
-								  d3.select(this).selectAll("ul").remove(); 
-								  d3.select(this)
-									.append("ul")
-                                    .style("top",String(li.offsetTop-5)+"px")
-									.selectAll("li")
-									   .data(d.childrenItems)
-										.enter().append("li")
-										  .text(function(d) { return d.title; })
-									 .on("mouseenter", function(d,i){
-											d.onMouseOver(elm,data,index);
-										})
-									 .on('click',  function(d, i) {
-											d.onMouseClick(elm, d, index);
-										})
-									 .on('mouseleave',function(d,i){
-										
-										});
-								 }
-							 else
-								 return false;
-						})
-						.on('mouseleave',function(d,i){
-							d3.select(this).selectAll("ul").style('display', 'none')                  
-						});
-					
-					  
-
-					// the openCallback allows an action to fire before the menu is displayed
-					// an example usage would be closing a tooltip
-					if (openCallback) openCallback(data, index);
-
-					// display context menu
-					d3.select('.d3-context-menu')
-						.style('left', (d3.event.pageX - 2) + 'px')
-						.style('top', (d3.event.pageY - 2) + 'px')
-						.style('display', 'block');
-                    
-                    //Prevent the default event, which is the left-click. 
-                    //This means, the context-menu will only appear on right mouse clicks
-					d3.event.preventDefault();
-                    
-                    //Place context-menu always on top of everything esle
-                    d3.select(".d3-context-menu").style("z-index",Number.MAX_SAFE_INTEGER);
-				};
-			};
-
-
-			//aigner: Function creates a table
-			function tabulate(aTable,data,columns) {
-				var thead = aTable.append('thead');
-				var	tbody = aTable.append('tbody');  
-
-				// create a row for each object in the data
-				var rows = tbody.selectAll('tr')
-				  .data(data)
-				  .enter()
-				  .append('tr');
-
-				// create a cell in each row for each column
-				var cells = rows.selectAll('td')
-				  .data(function (row) {
-					return columns.map(function (column) {
-					  return {column: column, value: row[column]};
-					});
-				  })
-				  .enter()
-				  .append('td')
-					.html(function (d) { return d.value; });
-
-				return aTable;
-			}
-
-			//aigner: Move to front function
-			d3.selection.prototype.moveToFront = function() {  
-			  return this.each(function(){
-				this.parentNode.appendChild(this);
-			  });
-			};
-			//aigner: Move to back function
-			d3.selection.prototype.moveToBack = function() {  
-				return this.each(function() { 
-					var firstChild = this.parentNode.firstChild; 
-					if (firstChild) { 
-						this.parentNode.insertBefore(this, firstChild); 
-					} 
-				});
-			};
-
-
-			//aigner: biHisankey functions (Source: http://bl.ocks.org/Neilos/584b9a5d44d5fe00f779)
-			d3.biHiSankey = function () {
-			  "use strict";
-
-			  var biHiSankey = {},
-				nodeWidth = 24,
-				nodeSpacing = 8,
-				linkSpacing = 5,
-				arrowheadScaleFactor = 0, // Specifies the proportion of a link's stroke width to be allowed for the marker at the end of the link.
-				size = [1, 1], // default to one pixel by one pixel
-				nodes = [],
-				nodeMap = {},
-				parentNodes = [],
-				leafNodes = [],
-				links = [],
-				xScaleFactor = 1,
-				yScaleFactor = 1,
-				defaultLinkCurvature = 0.5;
-
-			  function center(node) {
-				return node.y + node.height / 2;
-			  }
-
-			  function value(link) {
-				return link.value;
-			  }
-
-			  function initializeNodeArrayProperties(node) {
-				node.sourceLinks = [];
-				node.rightLinks = [];
-				node.targetLinks = [];
-				node.leftLinks = [];
-				node.connectedNodes = [];
-				node.children = [];
-				node.ancestors = [];
-			  }
-			  // generates the nodeMap {"1": <node1>, "2": <node2>}
-			  // and initializes the array properties of each node
-			  function initializeNodeMap() {
-				nodes.forEach(function (node) {
-				  nodeMap[node.id] = node;
-				  initializeNodeArrayProperties(node);
-				});
-			  }
-
-			  function computeLeafNodes() {
-				leafNodes = nodes.filter(function (node) {
-				  return !node.children.length;
-				});
-			  }
-
-			  function computeParentNodes() {
-				parentNodes = nodes.filter(function (node) {
-				  return node.children.length;
-				});
-			  }
-
-			  function addAncestorsToChildren(node) {
-				node.children.forEach(function (child) {
-				  child.ancestors = child.ancestors.concat(this.ancestors.concat([this]));
-				  addAncestorsToChildren(child);
-				}, node);
-			  }
-
-			  // generate hierarchical connections between parent and child nodes
-			  function computeNodeHierarchy() {
-				var parent,
-					rootNodes = [];
-
-				nodes.forEach(function (node) {
-				  parent = null;
-				  if (parent) {
-					node.parent = parent;
-					parent.children.push(node);
-				  } else {
-					node.parent = null;
-					rootNodes.push(node);
-				  }
-				});
-
-				computeLeafNodes();
-				computeParentNodes();
-
-				rootNodes.forEach(function (rNode) {
-				  addAncestorsToChildren(rNode);
-				});
-			  }
-
-			  // Populate the sourceLinks and targetLinks for each node.
-			  function computeNodeLinks() {
-				var sourceNode, targetNode;
-				links.forEach(function (link) {
-				  sourceNode = nodeMap[link.source] || link.source;
-				  targetNode = nodeMap[link.target] || link.target;
-				  link.id = link.source + '-' + link.target;
-				  link.source = sourceNode;
-				  link.target = targetNode;
-				  sourceNode.sourceLinks.push(link);
-				  targetNode.targetLinks.push(link);
-				});
-			  }
-
-			  function visible(linkCollection) {
-				return linkCollection.filter(function (link) {
-				  return link.source.state === "collapsed" && link.target.state === "collapsed";
-				});
-			  }
-
-			  // When child nodes are collapsed into their parents (or higher ancestors)
-			  // the links between the child nodes should be represented by links
-			  // between the containing ancestors. This function adds those extra links.
-			  function computeAncestorLinks() {
-				// Leaf nodes are never parents of other nodes
-				// Duplicate source and target links between a leaf node and another leaf node
-				// and add to the leaf nodes' parents
-				leafNodes.forEach(function (leafNode) {
-				  leafNode.sourceLinks.forEach(function (sourceLink) {
-					var ancestorTargets,
-					target = sourceLink.target;
-					if (leafNodes.indexOf(target) >= 0) {
-					  ancestorTargets = target.ancestors.filter(function (tAncestor) {
-						return leafNode.ancestors.indexOf(tAncestor) < 0;
-					  });
-					  ancestorTargets.forEach(function (ancestorTarget) {
-						var ancestorLink = { source: leafNode,
-											target: ancestorTarget,
-											value: sourceLink.value,
-											id: leafNode.id + "-" + ancestorTarget.id };
-
-						leafNode.sourceLinks.push(ancestorLink);
-						ancestorTarget.targetLinks.push(ancestorLink);
-						links.push(ancestorLink);
-					  });
-					}
-				  });
-
-				  leafNode.targetLinks.forEach(function (targetLink) {
-					var ancestorSources, source = targetLink.source;
-					if (leafNodes.indexOf(source) >= 0) {
-					  ancestorSources = source.ancestors.filter(function (sAncestor) {
-						return leafNode.ancestors.indexOf(sAncestor) < 0;
-					  });
-					  ancestorSources.forEach(function (ancestorSource) {
-						var ancestorLink = { source: ancestorSource,
-											target: leafNode,
-											value: targetLink.value,
-											id: ancestorSource.id + "-" + leafNode.id };
-						ancestorSource.sourceLinks.push(ancestorLink);
-						leafNode.targetLinks.push(ancestorLink);
-						links.push(ancestorLink);
-					  });
-					}
-				  });
-				});
-
-				// Add links between parents (for when both parents are in collapsed state)
-				parentNodes.forEach(function (parentNode) {
-				  parentNode.sourceLinks.forEach(function (sourceLink) {
-					var ancestorTargets, target = sourceLink.target;
-					if (leafNodes.indexOf(target) >= 0) {
-					  ancestorTargets = target.ancestors.filter(function (tAncestor) {
-						return parentNode.ancestors.indexOf(tAncestor) < 0;
-					  });
-					  ancestorTargets.forEach(function (ancestorTarget) {
-						var ancestorLink = { source: parentNode,
-											target: ancestorTarget,
-											value: sourceLink.value,
-											id: parentNode.id + "-" + ancestorTarget.id };
-
-						parentNode.sourceLinks.push(ancestorLink);
-						ancestorTarget.targetLinks.push(ancestorLink);
-						links.push(ancestorLink);
-					  });
-					}
-				  });
-				});
-			  }
-
-			  // To reduce clutter in the diagram merge links that are from the
-			  // same source to the same target by creating a new link
-			  // with a value equal to the sum of the values of the merged links
-			  function mergeLinks() {
-				var linkGroups = d3.nest()
-				  .key(function (link) { return link.source.id + "->" + link.target.id; })
-				  .entries(links)
-				  .map(function (object) { return object.values; });
-
-				links = linkGroups.map(function (linkGroup) {
-				  return linkGroup.reduce(function (previousLink, currentLink) {
-					return {
-					  "source": previousLink.source,
-					  "target": previousLink.target,
-					  "id": d3.min([previousLink.id, currentLink.id]),
-					  "value": previousLink.value + currentLink.value
-					};
-				  });
-				});
-			  }
-
-			  function nodeHeight(sideLinks) {
-				var spacing = Math.max(sideLinks.length - 1, 0) * linkSpacing,
-					scaledValueSum = d3.sum(sideLinks, value) * yScaleFactor;
-				return scaledValueSum + spacing;
-			  }
-
-			  // Compute the value of each node by summing the associated links.
-			  // Compute the number of spaces between the links
-			  // Compute the number of source links for later decrementing
-			  function computeNodeValues() {
-				nodes.forEach(function (node) {
-				  node.value = Math.max(
-					d3.sum(node.leftLinks, value),
-					d3.sum(node.rightLinks, value)
-				  );
-				  node.inputs = d3.sum(visible(node.targetLinks), value);
-				  node.outputs = d3.sum(visible(node.sourceLinks), value);
-				  node.height = Math.max(nodeHeight(visible(node.leftLinks)), nodeHeight(visible(node.rightLinks)));
-				  node.linkSpaceCount = Math.max(Math.max(node.leftLinks.length, node.rightLinks.length) - 1, 0);
-				});
-			  }
-
-			  function computeConnectedNodes() {
-				var sourceNode, targetNode;
-				links.forEach(function (link) {
-				  sourceNode = link.source;
-				  targetNode = link.target;
-				  if (sourceNode.connectedNodes.indexOf(targetNode) < 0) {
-					sourceNode.connectedNodes.push(targetNode);
-				  }
-				  if (targetNode.connectedNodes.indexOf(sourceNode) < 0) {
-					targetNode.connectedNodes.push(sourceNode);
-				  }
-				});
-			  }
-
-			  function sourceAndTargetNodesWithSameX() {
-				var nodeArray = [];
-				links.filter(function (link) {
-				  return link.target.x === link.source.x;
-				}).forEach(function (link) {
-				  if (nodeArray.indexOf(link.target) < 0) {
-					nodeArray.push(link.target);
-				  }
-				});
-				return nodeArray;
-			  }
-
-			  function compressInXDirection() {
-				var connectedNodesXPositions,
-					nodesByXPosition = d3.nest()
-					  .key(function (node) { return node.x; })
-					  .sortKeys(d3.ascending)
-					  .entries(nodes)
-					  .map(function (object) { return object.values; });
-
-				nodesByXPosition.forEach(function (xnodes) {
-				  xnodes.forEach(function (node) {
-					connectedNodesXPositions = node.connectedNodes.map(function (connectedNode) {
-					  return connectedNode.x;
-					});
-					// keep decrementing the x value of the node
-					// unless it would have the same x value as one of its source or target nodes
-					// or node.x is already 0
-					while (node.x > 0 && connectedNodesXPositions.indexOf(node.x - 1) < 0) {
-					  node.x -= 1;
-					}
-				  });
-				});
-			  }
-
-			  function scaleNodeXPositions() {
-				var minX = d3.min(nodes, function (node) { return node.x; }),
-					maxX = d3.max(nodes, function (node) { return node.x; }) - minX;
-				xScaleFactor = (size[0] - nodeWidth) / maxX;
-
-				nodes.forEach(function (node) {
-				  node.x *= xScaleFactor;
-				});
-			  }
-
-			  function computeNodeXPositions() {
-				var remainingNodes = nodes,
-					nextNodes,
-					x = 0,
-					addToNextNodes = function (link) {
-					  if (nextNodes.indexOf(link.target) < 0 && link.target.x === this.x) {
-						nextNodes.push(link.target);
-					  }
-					},
-					setValues = function (node) {
-					  node.x = x;
-					  node.width = nodeWidth;
-					  node.sourceLinks.forEach(addToNextNodes, node);
-					};
-
-				while (remainingNodes.length) {
-				  nextNodes = [];
-				  remainingNodes.forEach(setValues);
-				  if (nextNodes.length) {
-					remainingNodes = nextNodes;
-				  } else {
-					remainingNodes = sourceAndTargetNodesWithSameX();
-				  }
-				  x += 1;
-				}
-
-				compressInXDirection();
-				scaleNodeXPositions();
-			  }
-
-			  function computeLeftAndRightLinks() {
-				var source, target;
-				nodes.forEach(function (node) {
-				  node.rightLinks = [];
-				  node.leftLinks = [];
-				});
-				links.forEach(function (link) {
-				  source = link.source;
-				  target = link.target;
-				  if (source.x < target.x) {
-					source.rightLinks.push(link);
-					target.leftLinks.push(link);
-					link.direction = 1;
-				  } else {
-					source.leftLinks.push(link);
-					target.rightLinks.push(link);
-					link.direction = -1;
-				  }
-				});
-			  }
-
-			  function adjustTop(adjustment) {
-				nodes.forEach(function (node) {
-				  node.y -= adjustment;
-				});
-			  }
-
-			  function computeNodeYPositions(iterations) {
-				var minY,
-					alpha,
-					nodesByXPosition = d3.nest()
-					  .key(function (node) { return node.x; })
-					  .sortKeys(d3.ascending)
-					  .entries(nodes)
-					  .map(function (object) { return object.values; });
-
-				function calculateYScaleFactor() {
-				  var linkSpacesCount, nodeValueSum, discretionaryY;
-				  yScaleFactor = d3.min(nodesByXPosition, function (nodes) {
-					linkSpacesCount = d3.sum(nodes, function (node) {
-					  return node.linkSpaceCount;
-					});
-					nodeValueSum = d3.sum(nodes, function (node) {
-					  return node.value;
-					});
-					discretionaryY = (size[1]
-									- (nodes.length - 1) * nodeSpacing
-									- linkSpacesCount * linkSpacing);
-
-					return  discretionaryY / nodeValueSum;
-				  });
-
-				  // Fat links are those with lengths less than about 4 times their heights
-				  // Fat links don't bend well
-				  // Test that yScaleFactor is not so big that it causes "fat" links; adjust yScaleFactor accordingly
-				  links.forEach(function (link) {
-					var linkLength = Math.abs(link.source.x - link.target.x),
-						linkHeight = link.value * yScaleFactor;
-					if (linkLength / linkHeight < 4) {
-					  yScaleFactor = 0.25 * linkLength / link.value;
-					}
-				  });
-				}
-
-				function initializeNodeYPosition() {
-				  nodesByXPosition.forEach(function (nodes) {
-					nodes.forEach(function (node, i) {
-					  node.y = i;
-					  node.heightAllowance = node.value * yScaleFactor + linkSpacing * node.linkSpaceCount;
-					});
-				  });
-				}
-
-				function calculateLinkThickness() {
-				  links.forEach(function (link) {
-					link.thickness = link.value * yScaleFactor;
-				  });
-				}
-
-				function relaxLeftToRight(alpha) {
-				  function weightedSource(link) {
-					return center(link.source) * link.value;
-				  }
-
-				  nodesByXPosition.forEach(function (nodes) {
-					nodes.forEach(function (node) {
-					  if (node.rightLinks.length) {
-						var y = d3.sum(node.rightLinks, weightedSource) / d3.sum(node.rightLinks, value);
-						node.y += (y - center(node)) * alpha;
-					  }
-					});
-				  });
-				}
-
-				function relaxRightToLeft(alpha) {
-				  function weightedTarget(link) {
-					return center(link.target) * link.value;
-				  }
-
-				  nodesByXPosition.slice().reverse().forEach(function (nodes) {
-					nodes.forEach(function (node) {
-					  if (node.leftLinks.length) {
-						var y = d3.sum(node.leftLinks, weightedTarget) / d3.sum(node.leftLinks, value);
-						node.y += (y - center(node)) * alpha;
-					  }
-					});
-				  });
-				}
-
-				function resolveCollisions() {
-				  function ascendingYPosition(a, b) {
-					return a.y - b.y;
-				  }
-
-				  nodesByXPosition.forEach(function (nodes) {
-					var node,
-						dy,
-						y0 = 0,
-						n = nodes.length,
-						i;
-
-					nodes.sort(ascendingYPosition);
-
-					// Push any overlapping nodes down.
-					for (i = 0; i < n; ++i) {
-					  node = nodes[i];
-					  dy = y0 - node.y;
-					  if (dy > 0) {
-						node.y += dy;
-					  }
-					  y0 = node.y + node.heightAllowance + nodeSpacing;
-					}
-
-					// If the bottommost node goes outside the bounds, push it back up.
-					dy = y0 - nodeSpacing - size[1];
-					if (dy > 0) {
-					  node.y -= dy;
-					  y0 = node.y;
-
-					  // Push any overlapping nodes back up.
-					  for (i = n - 2; i >= 0; --i) {
-						node = nodes[i];
-						dy = node.y + node.heightAllowance + nodeSpacing - y0;
-						if (dy > 0) {
-						  node.y -= dy;
-						}
-						y0 = node.y;
-					  }
-					}
-				  });
-				}
-
-				calculateYScaleFactor();
-				initializeNodeYPosition();
-				calculateLinkThickness();
-				resolveCollisions();
-
-				for (alpha = 1; iterations > 0; --iterations) {
-				  alpha *= 0.99;
-				  relaxRightToLeft(alpha);
-				  resolveCollisions();
-				  relaxLeftToRight(alpha);
-				  resolveCollisions();
-				}
-
-				minY = d3.min(nodes, function (node) { return node.y; });
-				adjustTop(minY);
-			  }
-
-			  function computeLinkYPositions() {
-
-				function ascendingLeftNodeYPosition(a, b) {
-				  var aLeftNode = (a.direction > 0) ? a.source : a.target,
-					  bLeftNode = (b.direction > 0) ? b.source : b.target;
-				  return aLeftNode.y - bLeftNode.y;
-				}
-
-				function ascendingRightNodeYPosition(a, b) {
-				  var aRightNode = (a.direction > 0) ? a.target : a.source,
-					  bRightNode = (b.direction > 0) ? b.target : b.source;
-				  return aRightNode.y - bRightNode.y;
-				}
-
-				nodes.forEach(function (node) {
-				  node.rightLinks.sort(ascendingRightNodeYPosition);
-				  node.leftLinks.sort(ascendingLeftNodeYPosition);
-				});
-
-				nodes.forEach(function (node) {
-				  var rightY = 0, leftY = 0;
-
-				  node.rightLinks.forEach(function (link) {
-					if (link.direction > 0) {
-					  link.sourceY = rightY;
-					  if (link.target.state === "collapsed") {
-						rightY += link.thickness + linkSpacing;
-					  }
-					}
-					else {
-					  link.targetY = rightY;
-					  if (link.source.state === "collapsed") {
-						rightY += link.thickness + linkSpacing;
-					  }
-					}
-				  });
-
-				  node.leftLinks.forEach(function (link) {
-					if (link.direction < 0) {
-					  link.sourceY = leftY;
-					  if (link.target.state === "collapsed") {
-						leftY += link.thickness + linkSpacing;
-					  }
-					}
-					else {
-					  link.targetY = leftY;
-					  if (link.source.state === "collapsed") {
-						leftY += link.thickness + linkSpacing;
-					  }
-					}
-				  });
-
-				});
-			  }
-
-
-			  biHiSankey.arrowheadScaleFactor = function (_) {
-				if (!arguments.length) { return arrowheadScaleFactor; }
-				arrowheadScaleFactor = +_;
-				return biHiSankey;
-			  };
-
-			  biHiSankey.collapsedNodes = function () {
-				return nodes.filter(function (node) { return node.state === "collapsed"; });
-			  };
-
-			  biHiSankey.connected = function (nodeA, nodeB) {
-				return nodeA.connectedNodes.indexOf(nodeB) >= 0;
-			  };
-
-			  biHiSankey.expandedNodes = function () {
-				return nodes.filter(function (node) { return node.state === "expanded"; });
-			  };
-
-			  biHiSankey.layout = function (iterations) {
-				computeNodeXPositions();
-				computeLeftAndRightLinks();
-				computeNodeValues();
-				computeNodeYPositions(iterations);
-				computeNodeValues();
-				computeLinkYPositions();
-				return biHiSankey;
-			  };
-
-			  biHiSankey.link = function () {
-				var curvature = defaultLinkCurvature;
-
-				function leftToRightLink(link) {
-				  var arrowHeadLength = link.thickness * arrowheadScaleFactor,
-					  straightSectionLength = (3 * link.thickness / 4) - arrowHeadLength,
-					  x0 = link.source.x + link.source.width,
-					  x1 = x0 + arrowHeadLength / 2,
-					  x4 = link.target.x - straightSectionLength - arrowHeadLength,
-					  xi = d3.interpolateNumber(x0, x4),
-					  x2 = xi(curvature),
-					  x3 = xi(1 - curvature),
-					  y0 = link.source.y + link.sourceY + link.thickness / 2,
-					  y1 = link.target.y + link.targetY + link.thickness / 2;
-				  return "M" + x0 + "," + y0
-					   + "L" + x1 + "," + y0
-					   + "C" + x2 + "," + y0
-					   + " " + x3 + "," + y1
-					   + " " + x4 + "," + y1
-					   + "L" + (x4 + straightSectionLength) + "," + y1;
-				}
-
-				function rightToLeftLink(link) {
-				  var arrowHeadLength = link.thickness * arrowheadScaleFactor,
-					  straightSectionLength = link.thickness / 4,
-					  x0 = link.source.x,
-					  x1 = x0 - arrowHeadLength / 2,
-					  x4 = link.target.x + link.target.width + straightSectionLength + arrowHeadLength,
-					  xi = d3.interpolateNumber(x0, x4),
-					  x2 = xi(curvature),
-					  x3 = xi(1 - curvature),
-					  y0 = link.source.y + link.sourceY + link.thickness / 2,
-					  y1 = link.target.y + link.targetY + link.thickness / 2;
-				  return "M" + x0 + "," + y0
-					   + "L" + x1 + "," + y0
-					   + "C" + x2 + "," + y0
-					   + " " + x3 + "," + y1
-					   + " " + x4 + "," + y1
-					   + "L" + (x4 - straightSectionLength) + "," + y1;
-				}
-
-				function link(d) {
-				  if (d.source.x < d.target.x) {
-					return leftToRightLink(d);
-				  }
-				  return rightToLeftLink(d);
-				}
-
-				link.curvature = function (_) {
-				  if (!arguments.length) { return curvature; }
-				  curvature = +_;
-				  return link;
-				};
-
-				return link;
-			  };
-
-			  biHiSankey.links = function (_) {
-				if (!arguments.length) { return links; }
-				links = _.filter(function (link) {
-				  return link.source !== link.target; // filter out links that go nowhere
-				});
-				return biHiSankey;
-			  };
-
-			  biHiSankey.linkSpacing = function (_) {
-				if (!arguments.length) { return linkSpacing; }
-				linkSpacing = +_;
-				return biHiSankey;
-			  };
-
-			  biHiSankey.nodes = function (_) {
-				if (!arguments.length) { return nodes; }
-				nodes = _;
-				return biHiSankey;
-			  };
-
-			  biHiSankey.nodeWidth = function (_) {
-				if (!arguments.length) { return nodeWidth; }
-				nodeWidth = +_;
-				return biHiSankey;
-			  };
-
-			  biHiSankey.nodeSpacing = function (_) {
-				if (!arguments.length) { return nodeSpacing; }
-				nodeSpacing = +_;
-				return biHiSankey;
-			  };
-
-			  biHiSankey.relayout = function () {
-				computeLeftAndRightLinks();
-				computeNodeValues();
-				computeLinkYPositions();
-				return biHiSankey;
-			  };
-
-			  biHiSankey.size = function (_) {
-				if (!arguments.length) { return size; }
-				size = _;
-				return biHiSankey;
-			  };
-
-			  biHiSankey.visibleLinks = function () {
-				return visible(links);
-			  };
-
-			  biHiSankey.initializeNodes = function (callback) {
-				initializeNodeMap();
-				computeNodeHierarchy();
-				computeNodeLinks();
-				computeAncestorLinks();
-				mergeLinks();
-				computeConnectedNodes();
-				nodes.forEach(callback);
-				return biHiSankey;
-			  };
-
-			  return biHiSankey;
-			};
-
-
-			'use strict';
-
-			var sankeyDiagramDiv, svg, tooltip, biHiSankey, path, defs, colorScale, isTransitioning;
-
-			var OPACITY = {
-				NODE_DEFAULT: 0.9,
-				NODE_FADED: 0.1,
-				NODE_HIGHLIGHT: 0.8,
-				LINK_DEFAULT: 0.6,
-				LINK_FADED: 0.05,
-				LINK_HIGHLIGHT: 0.9
-			  },
-			  LINK_COLOR = "#b3b3b3",
-			  INFLOW_COLOR = "#CC0000",
-			  OUTFLOW_COLOR = "#99CC00",
-			  NODE_WIDTH = 36,
-			  COLLAPSER = {
-				RADIUS: NODE_WIDTH / 2,
-				SPACING: 2
-			  },
-			  OUTER_MARGIN = 10,
-			  MARGIN = {
-				TOP: 2 * (COLLAPSER.RADIUS + OUTER_MARGIN),
-				RIGHT: OUTER_MARGIN,
-				BOTTOM: OUTER_MARGIN,
-				LEFT: OUTER_MARGIN
-			  },
-			  TRANSITION_DURATION = 400,
-			  HEIGHT = 2000 - MARGIN.TOP - MARGIN.BOTTOM,
-			  WIDTH = 960 - MARGIN.LEFT - MARGIN.RIGHT,
-			  LAYOUT_INTERATIONS = 32,
-			  REFRESH_INTERVAL = 7000;
-
-			var formatNumber = function (d) {
-			  var numberFormat = d3.format(",.0f"); // zero decimal places
-			  return  numberFormat(d) + " connections";
-			},
-
-			formatFlow = function (d) {
-			  var flowFormat = d3.format(",.0f"); // zero decimal places with sign
-			  return flowFormat(Math.abs(d));
-			},
-
-			// Used when temporarily disabling user interractions to allow animations to complete
-			disableUserInterractions = function (time) {
-			  isTransitioning = true;
-			  setTimeout(function(){
-				isTransitioning = false;
-			  }, time);
-			},
-
-			hideTooltip = function () {
-			  return tooltip.transition()
-				.duration(TRANSITION_DURATION)
-				.style("opacity", 0);
-			},
-
-			showTooltip = function () {
-			  return tooltip
-				.style("left", d3.event.pageX + "px")
-				.style("top", d3.event.pageY + 15 + "px")
-				.transition()
-				  .duration(TRANSITION_DURATION)
-				  .style("opacity", 1);
-			};
-
-			colorScale = d3.scale.category10(),
-
-			sankeyDiagramDiv =  d3.select("body").append("div").attr("class","sankeyDiagramDiv")
-			svg = sankeyDiagramDiv.append("svg")
-					.attr("width", WIDTH + MARGIN.LEFT + MARGIN.RIGHT)
-					.attr("height", HEIGHT + MARGIN.TOP + MARGIN.BOTTOM)
-				  .append("g")
-					.attr("transform", "translate(" + MARGIN.LEFT + "," + MARGIN.TOP + ")");
-
-			svg.append("g").attr("id", "links");
-			svg.append("g").attr("id", "nodes");
-			svg.append("g").attr("id", "collapsers");
-
-			tooltip = d3.select(".sankeyDiagramDiv").append("div").attr("id", "tooltip");
-
-			tooltip.style("opacity", 0)
-				.append("p")
-				  .attr("class", "value");
-
-			biHiSankey = d3.biHiSankey();
-
-			// Set the biHiSankey diagram properties
-			biHiSankey
-			  .nodeWidth(NODE_WIDTH)
-			  .nodeSpacing(10)
-			  .linkSpacing(4)
-			  .arrowheadScaleFactor(0.5) // Specifies that 0.5 of the link's stroke WIDTH should be allowed for the marker at the end of the link.
-			  .size([WIDTH, HEIGHT]);
-
-			path = biHiSankey.link().curvature(0.45);
-
-			defs = svg.append("defs");
-
-			defs.append("marker")
-			  .style("fill", LINK_COLOR)
-			  .attr("id", "arrowHead")
-			  .attr("viewBox", "0 0 6 10")
-			  .attr("refX", "1")
-			  .attr("refY", "5")
-			  .attr("markerUnits", "strokeWidth")
-			  .attr("markerWidth", "1")
-			  .attr("markerHeight", "1")
-			  .attr("orient", "auto")
-			  .append("path")
-				.attr("d", "M 0 0 L 1 0 L 6 5 L 1 10 L 0 10 z");
-
-			defs.append("marker")
-			  .style("fill", OUTFLOW_COLOR)
-			  .attr("id", "arrowHeadInflow")
-			  .attr("viewBox", "0 0 6 10")
-			  .attr("refX", "1")
-			  .attr("refY", "5")
-			  .attr("markerUnits", "strokeWidth")
-			  .attr("markerWidth", "1")
-			  .attr("markerHeight", "1")
-			  .attr("orient", "auto")
-			  .append("path")
-				.attr("d", "M 0 0 L 1 0 L 6 5 L 1 10 L 0 10 z");
-
-			defs.append("marker")
-			  .style("fill", INFLOW_COLOR)
-			  .attr("id", "arrowHeadOutlow")
-			  .attr("viewBox", "0 0 6 10")
-			  .attr("refX", "1")
-			  .attr("refY", "5")
-			  .attr("markerUnits", "strokeWidth")
-			  .attr("markerWidth", "1")
-			  .attr("markerHeight", "1")
-			  .attr("orient", "auto")
-			  .append("path")
-				.attr("d", "M 0 0 L 1 0 L 6 5 L 1 10 L 0 10 z");
-
-			function update() {
-			  var link, linkEnter, node, nodeEnter, collapser, collapserEnter;
-
-			  function dragmove(node) {
-				node.x = Math.max(0, Math.min(WIDTH - node.width, d3.event.x));
-				node.y = Math.max(0, Math.min(HEIGHT - node.height, d3.event.y));
-				d3.select(this)
-					.attr("transform", "translate(" + node.x + "," + node.y + ")")
-					.style("cursor", "grabbing")
-				biHiSankey.relayout();
-				svg.selectAll(".sankeyNode").selectAll("rect").attr("height", function (d) { return d.height; });
-				link.attr("d", path);
-			  }
-
-			  function containChildren(node) {
-				node.children.forEach(function (child) {
-				  child.state = "contained";
-				  child.parent = this;
-				  child._parent = null;
-				  containChildren(child);
-				}, node);
-			  }
-
-			  function expand(node) {
-				node.state = "expanded";
-				node.children.forEach(function (child) {
-				  child.state = "collapsed";
-				  child._parent = this;
-				  child.parent = null;
-				  containChildren(child);
-				}, node);
-			  }
-
-			  function collapse(node) {
-				node.state = "collapsed";
-				containChildren(node);
-			  }
-
-			  function restoreLinksAndNodes() {
-				link
-				  .style("stroke", LINK_COLOR)
-				  .style("marker-end", function () { return 'url(#arrowHead)'; })
-				  .transition()
-					.duration(TRANSITION_DURATION)
-					.style("opacity", OPACITY.LINK_DEFAULT);
-				
-
-				node
-				  .selectAll("rect")
-					.style("fill", function (d) {
-					  d.color = colorScale(d.name.replace(/ .*/, ""));
-					  return d.color;
-					})
-					.style("stroke", function (d) {
-					  return d3.rgb(colorScale(d.name.replace(/ .*/, ""))).darker(0.1);
-					})
-					.style("fill-opacity", OPACITY.NODE_DEFAULT);
-
-				node.filter(function (n) { return n.state === "collapsed"; })
-				  .transition()
-					.duration(TRANSITION_DURATION)
-					.style("opacity", OPACITY.NODE_DEFAULT);
-			  }
-
-			  function showHideChildren(node) {
-				disableUserInterractions(2 * TRANSITION_DURATION);
-				hideTooltip();
-				if (node.state === "collapsed") { expand(node); }
-				else { collapse(node); }
-
-				biHiSankey.relayout();
-				update();
-				link.attr("d", path);
-				restoreLinksAndNodes();
-			  }
-
-			  function highlightConnected(g) {
-				link.filter(function (d) { return d.source === g; })
-				  .style("marker-end", function () { return 'url(#arrowHeadInflow)'; })
-				  .style("stroke", OUTFLOW_COLOR)
-				  .style("opacity", OPACITY.LINK_DEFAULT);
-
-				link.filter(function (d) { return d.target === g; })
-				  .style("marker-end", function () { return 'url(#arrowHeadOutlow)'; })
-				  .style("stroke", INFLOW_COLOR)
-				  .style("opacity", OPACITY.LINK_DEFAULT);
-				  
-				link.forEach(function (aLink) {
-				  aLink.moveToFront;
-				});
-			  }
-
-			  function fadeUnconnected(g) {
-				link.filter(function (d) { return d.source !== g && d.target !== g; })
-				  .style("marker-end", function () { return 'url(#arrowHead)'; })
-				  .transition()
-					.duration(TRANSITION_DURATION)
-					.style("opacity", OPACITY.LINK_FADED);
-
-				node.filter(function (d) {
-				  return (d.name === g.name) ? false : !biHiSankey.connected(d, g);
-				}).transition()
-				  .duration(TRANSITION_DURATION)
-				  .style("opacity", OPACITY.NODE_FADED);
-			  }
-
-			  link = svg.select("#links").selectAll("path.link")
-				.data(biHiSankey.visibleLinks(), function (d) { return d.id; });
-
-			  link.transition()
-				.duration(TRANSITION_DURATION)
-				.style("stroke-WIDTH", function (d) { return Math.max(1, d.thickness); })
-				.attr("d", path)
-				.style("opacity", OPACITY.LINK_DEFAULT);
-
-
-			  link.exit().remove();
-
-
-			  linkEnter = link.enter().append("path")
-				.attr("class", "link")
-				.style("fill", "none");
-
-			  linkEnter.on('mouseenter', function (d) {
-				if (!isTransitioning) {
-				  showTooltip().select(".value").text(function () {
-					if (d.direction > 0) {
-					  return d.source.name + " → " + d.target.name + "\n" + formatNumber(d.value);
-					}
-					return d.target.name + " ← " + d.source.name + "\n" + formatNumber(d.value);
-				  });
-
-				  d3.select(this)
-					.style("stroke", LINK_COLOR)
-					.transition()
-					  .duration(TRANSITION_DURATION / 2)
-					  .style("opacity", OPACITY.LINK_HIGHLIGHT);
-				}
-			  });
-
-			  linkEnter.on('mouseleave', function () {
-				if (!isTransitioning) {
-				  hideTooltip();
-
-				  d3.select(this)
-					.style("stroke", LINK_COLOR)
-					.transition()
-					  .duration(TRANSITION_DURATION / 2)
-					  .style("opacity", OPACITY.LINK_DEFAULT);
-				}
-			  });
-			  
-                
-                <!-- //Highlight function, that shows usage of a node in the XDSM -->
-                <!-- function highlight(data) -->
-                <!-- { -->
-                    <!-- xPath = data.xPath; -->
-                    <!-- var allLinks = d3.selectAll(".link"); -->
-                    <!-- var allLinks_tmp = allLinks[0]; -->
-                    <!-- allLinks_tmp.forEach(function(p) { -->
-                        <!-- var firstElement_tmp = p.__data__.name.split("/")[1] -->
-                        <!-- var text_fromFirst = "/"+firstElement_tmp+xPath.split(firstElement_tmp)[1] -->
-                        <!-- if (include(p.__data__.name,text_fromFirst)) -->
-                        <!-- { -->
-                            <!-- d3.select(p).style("opacity", .8);			 -->
-                        <!-- } -->
-                        <!-- else -->
-                        <!-- { -->
-                            <!-- d3.select(p).style("opacity", 0);			 -->
-                        <!-- } -->
-                    <!-- }); -->
-                <!-- } -->
-                
-                function showVariableTable(aVariable)
-                {											
-                    var headLine = "Node Information (" + aVariable.name + ")";
-                    var data = [];
-                    // render the table(s)
-                    data.push({ "name" : "Name", "value" : "\""+aVariable.name+"\"" })
-                    data.push({ "name" : "xPath", "value" : aVariable.xPath })
-                    if (aVariable.type){data.push({ "name" : "Type", "value" : aVariable.type })}
-                    if (aVariable.level){data.push({ "name" : "Level", "value" : aVariable.level })}
-                    if (aVariable.children || aVariable._children)
-                    {
-                        var childrenNum=0;
-                        if (aVariable.children){childrenNum=childrenNum+aVariable.children.length}
-                        if (aVariable._children){childrenNum=childrenNum+aVariable._children.length}
-                        data.push({ "name" : "Number of children", "value" : childrenNum })
-                    }
-                    if (aVariable.dimension){data.push({ "name" : "Dimension", "value" : aVariable.dimension })}
-                    else if(aVariable.dimension===null){data.push({ "name" : "Dimension", "value" : "undefined" })}
-                    if (aVariable.value){data.push({ "name" : "Value(s)", "value" : aVariable.value })}
-                    
-                    var d3_body = d3.select("body");
-                    
-                    var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                    panel_div.append("div").attr("class","panel-heading")
-                        .append("div").attr("class","panel_title").append("h4").text(headLine)
-                    var listGroup = panel_div.append("div").attr("class","panel-body")
-                        .append("table").attr("id","myTable")
-                        .append("tbody")
-                        
-                    data.forEach(function(listElement)
-                    {
-                        var row = listGroup.append("tr")
-                        row.append("td").text(listElement.name)
-                        row.append("td").text(listElement.value)
-                        
-                    })
-                    $('.myPanel').lobiPanel({
-                        reload: false,
-                        editTitle: false,
-                        expand: false,
-                        unpin: false,
-                        resize: "none",
-                        minWidth: 200,
-                        minHeight: 200,
-                        maxWidth: 1100,
-                        maxHeight: 1200,
-                    });
-                    $('.myPanel').lobiPanel('unpin');
-                }
-
-                //menu --> functions for right click options
-                var nodeMenu = [
-                {
-                    title: 'Show node information',
-                    onMouseDown: function(elm, d, i) {
-                        showVariableTable(d);
-                    },
-                    onMouseUp: function(elm, d, i) {},
-                    onMouseOver: function(elm, d, i) {},
-                    childrenItems: []
-                },
-                {
-                    title: 'Show usage of node in diagram',
-                    onMouseDown: function(elm, d, i) {
-                        d3.selectAll(".treeFrame").attr("fill-opacity", .5);
-                        d3.selectAll(".nodeText").style("fill-opacity", 0.5);					
-                        highlight(d);
-                    },
-                    onMouseUp: function(elm, d, i) {				
-                        d3.selectAll(".link").style("opacity",.6)
-                        d3.selectAll(".treeFrame").attr("fill-opacity", .8);
-                        d3.selectAll(".nodeText").style("fill-opacity", 1);					
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: []
-                },
-                {
-                    title: 'Copy x-path to clipboard',
-                    onMouseDown: function(elm, d, i) {
-                        window.prompt("Copy to clipboard: Ctrl+C, Enter", d.xPath);
-                        d3.select('.d3-context-menu').style('display', 'none');
-                    },
-                    onMouseUp: function(elm, d, i) {
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: []
-                }
-                ]
-                
-                function showList(aTitle,aList,aMenu)
-                {
-                    if (aList.length != 0)
-                    {
-                        var d3_body = d3.select("body");
-                        
-                        var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                        panel_div.append("div").attr("class","panel-heading")
-                            .append("div").attr("class","panel_title").append("h4").text(aTitle)
-                        panel_div.append("input")
-                            .attr("id","myInput")
-                            .attr("placeholder","Filter search...")
-                            .attr("title","Type in a name")
-                            .attr("onkeyup","filterSearch()")
-                        var listGroup = panel_div.append("div").attr("class","panel-body")
-                            .append("table").attr("id","myTable")
-                            .append("tbody")
-                            
-                        var tr = listGroup
-                            .selectAll('tr')
-                            .data(aList).enter()
-                                .append('tr')
-                        var td = tr.append("td").html(function(d) { 
-                            if (d.xPath){return d.xPath;} 
-                            else {return d.name;} 
-                        })
-                        tr.on('contextmenu', d3.contextMenu(aMenu));
-                        $('.myPanel').lobiPanel({
-                            reload: false,
-                            editTitle: false,
-                            expand: false,
-                            unpin: false,
-                            resize: "none",
-                            minWidth: 200,
-                            minHeight: 200,
-                            maxWidth: 1100,
-                            maxHeight: 1200,
-                        });
-                        $('.myPanel').lobiPanel('unpin');
-                        $('.myPanel').lobiPanel('height','5000');
-                    }
-                }
-                
-			  
-				function showLinkTree(aLink,aVarCategory)
-				{
-					var name_tmp = "Variable flow: " + aLink.__data__.source.name +  "  →  " + aLink.__data__.target.name
-					var theSchema = currentGraph.variableSchemes[aVarCategory];
-					createTreeLayout(name_tmp,theSchema,aLink.__data__.name,link,nodeMenu);
-				}
-				
-				function showEdgeTable(aLink)
-				{						
-                    
-                    var headLine = "Edge Information (" + aLink.from + " - " + aLink.to + ")";
-					var anEdgeNameSplit = aLink.name.split(',')
-					var numberOfconnections = anEdgeNameSplit.length;
-					var dimension=0;
-					var nullDim=false;
-					var undefinedLeafs;
-					var theLeafNodes = JSON.parse(JSON.stringify(currentGraph.variableSchemes[varCategories[0].name]));
-					var pipeData = aLink.name;
-					prune_tree(pipeData,theLeafNodes)
-					var undefLeafsNumber=0;
-					var defLeafsNumber=0;
-					for (var k=0;k<theLeafNodes.length;k++)
-					{
-						if (theLeafNodes[k].dimension!=null){dimension = dimension+theLeafNodes[k].dimension}
-						else{nullDim=true}
-						if (theLeafNodes[k].value.includes("could not be found")||theLeafNodes[k].value.includes("unknown"))
-						{
-							if (undefLeafsNumber==0){undefinedLeafs += theLeafNodes[k].xPath;}
-							else {undefinedLeafs += "," + theLeafNodes[k].xPath;}
-							undefLeafsNumber ++;
-						}
-						else
-						{
-							defLeafsNumber++;
-						}
-					}		
-					//Render data for table
-					var data = [];
-					data.push({ "name" : "Total number of connections", "value" : numberOfconnections })
-					data.push({ "name" : "Number of referenced connections", "value" : defLeafsNumber })
-					data.push({ "name" : "Dimension of referenced connections", "value" : String(dimension) })
-					if (undefinedLeafs)
-					{
-						data.push({ "name" : "Number of unreferenced connections", "value" :  undefLeafsNumber})					
-					}
-                    
-                    
-                    
-                    var d3_body = d3.select("body");
-                    
-                    var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                    panel_div.append("div").attr("class","panel-heading")
-                        .append("div").attr("class","panel_title").append("h4").text(headLine)
-                    var listGroup = panel_div.append("div").attr("class","panel-body")
-                        .append("table").attr("id","myTable")
-                        .append("tbody")
-                        
-                    data.forEach(function(listElement)
-                    {
-                        var row = listGroup.append("tr")
-                        row.append("td").text(listElement.name)
-                        row.append("td").text(listElement.value)
-                        
-                    })
-                    $('.myPanel').lobiPanel({
-                            reload: false,
-                            editTitle: false,
-                            expand: false,
-                            unpin: false,
-                            resize: "none",
-                            minWidth: 200,
-                            minHeight: 200,
-                            maxWidth: 1100,
-                            maxHeight: 1200,
-                        });
-                    $('.myPanel').lobiPanel('unpin');
-				}
-				
-				//linkMenu --> functions for right click options
-				var linkChildrenItemsTree = [];
-				for (var j=0; j< varCategories.length; j++)
-				{
-					linkChildrenItemsTree.push({title: 'according to ' + varCategories[j].description,
-											varCategory: varCategories[j].name,
-											onMouseClick: function(elm, data, i) {showLinkTree(elm,data.varCategory)},
-											onMouseOver: function(elm,data,i){}});
-				}
-                var linkChildrenItemsList = [];
-				for (var j=0; j< varCategories.length; j++)
-				{
-					linkChildrenItemsList.push({title: 'according to ' + varCategories[j].description,
-											varCategory: varCategories[j].name,
-											onMouseClick: function(elm, data, i) {
-                                                var variables = [];
-                                                var pipeData = elm.__data__.name;
-                                                var title = "List view of variable flow: " + elm.__data__.source.id +  "  →  " + elm.__data__.target.id
-                                                variables = JSON.parse(JSON.stringify(currentGraph.variableSchemes[data.varCategory]))
-                                                prune_tree(pipeData,variables)
-                                                variables.forEach(function(variable)
-                                                {
-                                                    variable.name = variable.xPath
-                                                    //work around because nodeMenu expexts the data, to have a "data" object inside
-                                                    variable.data = variable
-                                                    variable.data.name = variable.xPath.split("/")[variable.xPath.split("/").length-1]
-                                                })
-                                                
-                                                showList(title,variables,nodeMenu);
-                                            },
-											onMouseOver: function(elm,data,i){}});
-				}
-				var linkMenu = [
-				{
-					title: 'Show edge info',
-					onMouseDown: function(elm, k, i) {
-						showEdgeTable(k)
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: []
-				},
-				{
-					title: 'Show variable tree...',
-					onMouseDown: function(elm, k, i) {
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: linkChildrenItemsTree
-				},
-				{
-					title: 'Show variable list...',
-					onMouseDown: function(elm, k, i) {
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: linkChildrenItemsList
-				}
-				]
-
-				var thisLink = d3.select(this);
-				linkEnter.on('contextmenu', d3.contextMenu(linkMenu))
-
-			  linkEnter.sort(function (a, b) { return b.thickness - a.thickness; })
-				.classed("leftToRight", function (d) {
-				  return d.direction > 0;
-				})
-				.classed("rightToLeft", function (d) {
-				  return d.direction < 0;
-				})
-				.style("marker-end", function () {
-				  return 'url(#arrowHead)';
-				})
-				.style("stroke", LINK_COLOR)
-				.style("opacity", 0)
-				.transition()
-				  .delay(TRANSITION_DURATION)
-				  .duration(TRANSITION_DURATION)
-				  .attr("d", path)
-				  .style("stroke-WIDTH", function (d) { return Math.max(1, d.thickness); })
-				  .style("opacity", OPACITY.LINK_DEFAULT);
-
-
-			  node = svg.select("#nodes").selectAll(".sankeyNode")
-				  .data(biHiSankey.collapsedNodes(), function (d) { return d.id; });
-
-
-			  node.transition()
-				.duration(TRANSITION_DURATION)
-				.attr("transform", function (d) { return "translate(" + d.x + "," + d.y + ")"; })
-				.style("opacity", OPACITY.NODE_DEFAULT)
-				.select("rect")
-				  
-				  .style("stroke", function(d) { 
-					  return d3.rgb(d.color).darker(2); })
-				  .style("stroke-WIDTH", "1px")
-				  .attr("height", function (d) { return d.height; })
-				  .attr("width", biHiSankey.nodeWidth());
-
-
-			  node.exit()
-				.transition()
-				  .duration(TRANSITION_DURATION)
-				  .attr("transform", function (d) {
-					var collapsedAncestor, endX, endY;
-					collapsedAncestor = d.ancestors.filter(function (a) {
-					  return a.state === "collapsed";
-					})[0];
-					endX = collapsedAncestor ? collapsedAncestor.x : d.x;
-					endY = collapsedAncestor ? collapsedAncestor.y : d.y;
-					return "translate(" + endX + "," + endY + ")";
-				  })
-				  .remove();
-
-
-			  nodeEnter = node.enter().append("g").attr("class", "sankeyNode");
-
-			  nodeEnter
-				.attr("transform", function (d) {
-				  var startX = d._parent ? d._parent.x : d.x,
-					  startY = d._parent ? d._parent.y : d.y;
-				  return "translate(" + startX + "," + startY + ")";
-				})
-				.style("opacity", 1e-6)
-				.transition()
-				  .duration(TRANSITION_DURATION)
-				  .style("opacity", OPACITY.NODE_DEFAULT)
-				  .attr("transform", function (d) { return "translate(" + d.x + "," + d.y + ")"; });
-
-			  nodeEnter.append("text");
-			  nodeEnter.append("rect")
-				.style("fill", function(d) { 
-					  return d.color = colorScale(d.name.replace(/ .*/, "")); })
-				  .style("stroke", function(d) { 
-					  return d3.rgb(d.color).darker(2); })
-				.style("stroke-WIDTH", "1px")
-				.attr("height", function (d) { return d.height; })
-				.attr("width", biHiSankey.nodeWidth());
-				
-			  node.append("svg:title").text("Click left to drag, click right to inspect")
-			  node.on("mouseenter", function (g) {
-				if (!isTransitioning) {
-				  restoreLinksAndNodes();
-				  highlightConnected(g);
-				  fadeUnconnected(g);
-
-				  d3.select(this).select("rect")
-					.style("stroke", function (d) {
-					  return d3.rgb(d.color).darker(0.1);
-					})
-					.style("fill-opacity", OPACITY.LINK_DEFAULT);
-
-				  tooltip
-					.style("left", g.x + MARGIN.LEFT + "px")
-					.style("top", d3.event.pageY-40 + "px")
-					.transition()
-					  .duration(TRANSITION_DURATION)
-					  .style("opacity", 1).select(".value")
-					  .text(function () {
-						var additionalInstructions = g.children.length ? "\n(Double click to expand)" : "";
-						return g.name + "\nInputs: " + formatFlow(g.inputs) + "\nOutputs: " + formatFlow(g.outputs);
-					  });
-				}
-			  });
-
-			  node.on("mouseleave", function () {
-				if (!isTransitioning) {
-				  hideTooltip();
-				  restoreLinksAndNodes();
-				}
-			  });
-
-			  node.filter(function (d) { return d.children.length; })
-				.on("dblclick", showHideChildren);
-				
-				
-				//aigner: Right click options for tools
-				//##############################################################################################################################
-				
-				//aigner: Table for competence/tool information
-				//############################################################
-				function showToolTable(aTool)
-                {
-                    var aToolNameSplit = aTool.name.split(': ')			
-                    var headLine;
-                    if (aToolNameSplit.length>1){headLine = "Competence Information: (" + aToolNameSplit[1] + ")";}
-                    else {headLine = "Competence Information: (" + aToolNameSplit[0] + ")";}
-                    
-                    
-                    var data = [];
-                    // render the table(s)
-                    if (aTool.metadata.length==0)
-                    {
-                        data.push({ "name" : "NO TOOL METADATA AVAILABLE", "value" : "..." })
-                    }
-                    function findSubMetaData(aMetaData)
-                    {
-                        for(var key in aMetaData)
-                        {
-                            if (typeof aMetaData[key] === 'object')
-                            {
-                                data.push({ "name" : key, "value" : ''}) ;
-                                findSubMetaData(aMetaData[key]);
-                            }
-                            else
-                            {
-                                data.push({ "name" : key, "value" : aMetaData[key] })
-                            }
-                        }
-                    }
-                    for (var j=0; j < aTool.metadata.length;j++)
-                    {
-                        var metaData = aTool.metadata[j];
-                        findSubMetaData(metaData);						
-                    }
-                
-                    
-                    var d3_body = d3.select("body");
-                    
-                    var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                    panel_div.append("div").attr("class","panel-heading")
-                        .append("div").attr("class","panel_title").append("h4").text(headLine)
-                    var listGroup = panel_div.append("div").attr("class","panel-body")
-                        .append("table").attr("id","myTable")
-                        .append("tbody")
-                        
-                    data.forEach(function(listElement)
-                    {
-                        var row = listGroup.append("tr")
-                        row.append("td").text(listElement.name)
-                        row.append("td").text(listElement.value)
-                        
-                    })
-                    $('.myPanel').lobiPanel({
-                            reload: false,
-                            editTitle: false,
-                            expand: false,
-                            unpin: false,
-                            resize: "none",
-                            minWidth: 200,
-                            minHeight: 200,
-                            maxWidth: 1100,
-                            maxHeight: 1200,
-                        });
-                    $('.myPanel').lobiPanel('unpin');
-                }
-				//############################################################
-				
-				//aigner: Creation of input/output tree
-				//############################################################
-				function showIOTree(categoryID, categoryDescr, theNode, io)
-				{	
-					var links = d3.selectAll(".link");
-					var array="";
-					var name_tmp = "";
-					links.each(function(theLink)
-					{		
-						if (io=="in")
-						{
-							if (theLink.to == theNode.id)
-							{
-								array = array + "," + theLink.name;
-							}
-							name_tmp = "Input tree view:" + theNode.id + "; Categorization: " + categoryDescr;
-						}
-						else if (io=="out")
-						{
-							if (theLink.from == theNode.id)
-							{
-								array = array + "," + theLink.name;
-							}
-							name_tmp = "Output tree view:" + theNode.id + "; Categorization: " + categoryDescr;
-						}
-					})
-					var theSchema = JSON.parse(JSON.stringify(currentGraph.variableSchemes[categoryID]));
-					createTreeLayout(name_tmp,theSchema,array,link,nodeMenu)
-				}
-				//############################################################
-
-				var inputChildrenitemsTree = [];
-				var outputChildrenitemsTree = [];
-				for (var j=0; j< varCategories.length; j++)
-				{
-					inputChildrenitemsTree.push({title: 'according to ' + varCategories[j].description,
-											 varCategory: varCategories[j].name,
-											 description: varCategories[j].description,
-											 onMouseClick: function(elm, data, i) {showIOTree(data.varCategory,data.description,elm.__data__,"in")},
-											 onMouseOver: function(elm,data,i){}});
-					outputChildrenitemsTree.push({title: 'according to ' + varCategories[j].description,
-											 varCategory: varCategories[j].name,
-											 description: varCategories[j].description,
-											 onMouseClick: function(elm, data, i) {showIOTree(data.varCategory,data.description,elm.__data__,"out")},
-											 onMouseOver: function(elm,data,i){}});
-				}
-                var inputChildrenitemsList = [];
-				var outputChildrenitemsList = [];
-				for (var j=0; j< varCategories.length; j++)
-				{
-					inputChildrenitemsList.push({title: 'according to ' + varCategories[j].description,
-											 varCategory: varCategories[j].name,
-											 description: varCategories[j].description,
-											 onMouseClick: function(elm, data, i) {
-                                                var links = d3.selectAll(".link");
-                                                    var pipeData="";
-                                                    var name_tmp = "";
-                                                    links.each(function(theLink)
-                                                    {		
-                                                        if (theLink.to == elm.__data__.id)
-                                                        {
-                                                            pipeData = pipeData + "," + theLink.name;
-                                                        }
-                                                    })
-                                                    
-                                                    var title = "List view of all inputs for " + elm.__data__.id + "; Categorization: " + data.description
-                                                    var variables = JSON.parse(JSON.stringify(currentGraph.variableSchemes[data.varCategory]))
-                                                    prune_tree(pipeData,variables)
-                                                    variables.forEach(function(variable)
-                                                    {
-                                                        variable.name = variable.xPath
-                                                        //work around because nodeMenu expexts the data, to have a "data" object inside
-                                                        variable.data = variable
-                                                        variable.data.name = variable.xPath.split("/")[variable.xPath.split("/").length-1]
-                                                    })
-                                                    
-                                                    showList(title,variables,nodeMenu);
-                                             },
-											 onMouseOver: function(elm,data,i){}});
-					outputChildrenitemsList.push({title: 'according to ' + varCategories[j].description,
-											 varCategory: varCategories[j].name,
-											 description: varCategories[j].description,
-											 onMouseClick: function(elm, data, i) {
-                                                    var links = d3.selectAll(".link");
-                                                    var pipeData="";
-                                                    var name_tmp = "";
-                                                    links.each(function(theLink)
-                                                    {		
-                                                        if (theLink.from == elm.__data__.id)
-                                                        {
-                                                            pipeData = pipeData + "," + theLink.name;
-                                                        }
-                                                    })
-                                                    
-                                                    var title = "List view of all outputs from " + elm.__data_.id + "; Categorization: " + data.description
-                                                    var variables = JSON.parse(JSON.stringify(currentGraph.variableSchemes[data.varCategory]))
-                                                    prune_tree(pipeData,variables)
-                                                    variables.forEach(function(variable)
-                                                    {
-                                                        variable.name = variable.xPath
-                                                        //work around because nodeMenu expexts the data, to have a "data" object inside
-                                                        variable.data = variable
-                                                        variable.data.name = variable.xPath.split("/")[variable.xPath.split("/").length-1]
-                                                    })
-                                                    
-                                                    showList(title,variables,nodeMenu);
-                                            
-                                             },
-											 onMouseOver: function(elm,data,i){}});
-				}
-				//menu --> functions for right click options
-				var toolMenu = [
-				{
-					title: 'Show competence info',
-					onMouseDown: function(elm, k, i) {
-						showToolTable(k);
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: []
-				},
-				{
-					title: 'Show input variable tree...',
-					onMouseDown: function(elm, k, i) {
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: inputChildrenitemsTree
-				},
-				{
-					title: 'Show output variable tree...',
-					onMouseDown: function(elm, k, i) {
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: outputChildrenitemsTree
-				},
-				{
-					title: 'Show input variable list...',
-					onMouseDown: function(elm, k, i) {
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: inputChildrenitemsList
-				},
-				{
-					title: 'Show output variable list...',
-					onMouseDown: function(elm, k, i) {
-					},
-					onMouseUp: function(elm, k, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: outputChildrenitemsList
-				}
-				]
-				//##############################################################################################################################
-				
-				node.on('contextmenu', d3.contextMenu(toolMenu));
-				
-			  // allow nodes to be dragged to new positions
-			  node.call(d3.behavior.drag()
-				.origin(function (d) 
-				{ 
-					 d3.select(this).style("cursor", "grabbing")	
-					return d; 
-				})
-				.on("dragstart", function () {
-					d3.select(this).style("cursor", "grabbing")	
-					this.parentNode.appendChild(this); })
-				.on("drag", dragmove));
-
-			  // add in the text for the nodes
-			  node.filter(function (d) { return d.value !== 0; })
-				.select("text")
-				  .attr("x", -6)
-				  .attr("y", function (d) { return d.height / 2; })
-				  .attr("dy", ".35em")
-				  .attr("text-anchor", "end")
-				  .attr("transform", null)
-				  .text(function (d) { return d.name; })
-				.filter(function (d) { return d.x < WIDTH / 2; })
-				  .attr("x", 6 + biHiSankey.nodeWidth())
-				  .attr("text-anchor", "start");
-
-
-			  collapser = svg.select("#collapsers").selectAll(".collapser")
-				.data(biHiSankey.expandedNodes(), function (d) { return d.id; });
-
-
-			  collapserEnter = collapser.enter().append("g").attr("class", "collapser");
-
-			  collapserEnter.append("circle")
-				.attr("r", COLLAPSER.RADIUS)
-				.style("fill", function (d) {
-				  d.color = colorScale(d.name.replace(/ .*/, ""));
-				  return d.color;
-				});
-
-			  collapserEnter
-				.style("opacity", OPACITY.NODE_DEFAULT)
-				.attr("transform", function (d) {
-				  return "translate(" + (d.x + d.width / 2) + "," + (d.y + COLLAPSER.RADIUS) + ")";
-				});
-
-			  collapserEnter.on("dblclick", showHideChildren);
-
-			  collapser.select("circle")
-				.attr("r", COLLAPSER.RADIUS);
-
-			  collapser.transition()
-				.delay(TRANSITION_DURATION)
-				.duration(TRANSITION_DURATION)
-				.attr("transform", function (d, i) {
-				  return "translate("
-					+ (COLLAPSER.RADIUS + i * 2 * (COLLAPSER.RADIUS + COLLAPSER.SPACING))
-					+ ","
-					+ (-COLLAPSER.RADIUS - OUTER_MARGIN)
-					+ ")";
-				});
-
-			  collapser.on("mouseenter", function (g) {
-				if (!isTransitioning) {
-				  showTooltip().select(".value")
-					.text(function () {
-					  return g.name + "\n(Double click to collapse)";
-					});
-
-				  d3.select(this)
-					.style("opacity", OPACITY.NODE_HIGHLIGHT)
-					.select("circle")
-
-				  node.filter(function (d) {
-					return d.ancestors.indexOf(g) >= 0;
-				  }).style("opacity", OPACITY.NODE_HIGHLIGHT)
-					.select("rect")
-				}
-			  });
-
-			  collapser.on("mouseleave", function (g) {
-				if (!isTransitioning) {
-				  hideTooltip();
-				  d3.select(this)
-					.style("opacity", OPACITY.NODE_DEFAULT)
-					.select("circle")
-
-				  node.filter(function (d) {
-					return d.ancestors.indexOf(g) >= 0;
-				  }).style("opacity", OPACITY.NODE_DEFAULT)
-					.select("rect")
-				}
-			  });
-
-			  collapser.exit().remove();
-
-			}
-
-
-			function createTreeLayout(theName,schema,theLinks,theAllLinks,nodeMenu)
-			{	
-                //aigner: Build the tree layout
-                //######################################################################
-				var treeData = (JSON.parse(JSON.stringify(schema)));
-                //The tree will only be pruned if there is pipeData, such as in an edge or for the input of a tool
-                if (theLinks)
-                {
-                    prune_tree(theLinks, treeData);
-                }
-                
-                //build tree layout for vistoms
-                var newTree = {};
-                buildTree(newTree, treeData)                    
-                treeData = newTree
-               //######################################################################
-               
-               
-				var width= 1000;
-				var height= 500;
-				var xOffset = 10;
-				var xOffset2 = 100;	
-				
-				// Calculate total nodes, max label length
-				var totalNodes = 0;
-				var maxLabelLength = 0;
-				// variables for drag/drop
-				var selectedNode = null;
-				var draggingNode = null;
-				// Misc. variables
-				var i = 0;
-				var duration = 500;
-				var root;
-				
-
-				// size of the diagram
-				var viewerWidth = width/3;
-				var viewerHeight = height+50;
-
-				var tree = d3.layout.tree()
-					.size([viewerHeight, viewerWidth])
-
-				// define a d3 diagonal projection for use by the node paths later on.
-				var diagonal = d3.svg.diagonal()
-					.projection(function(d) {
-						return [d.y+xOffset, d.x];
-					});
-
-				// A recursive helper function for performing some setup by walking through all nodes
-
-				function visit(parent, visitFn, childrenFn) {
-					if (!parent) return;
-
-					visitFn(parent);
-
-					var children = childrenFn(parent);
-					if (children) {
-						var count = children.length;
-						for (var i = 0; i < count; i++) {
-							visit(children[i], visitFn, childrenFn);
-						}
-					}
-				}
-
-				// Call visit function to establish maxLabelLength
-				visit(treeData, function(d) {
-					totalNodes++;
-					maxLabelLength = Math.max(d.name.length, maxLabelLength);
-				}, function(d) {
-					return d.children && d.children.length > 0 ? d.children : null;
-				});
-				
-				function getMaxLength(data)
-				{
-					var maxLen=0;;
-					for (var i = 0; i < data.length; i++)
-					{
-						maxLen = Math.max(data[i].name.length, maxLen);
-					}
-					for (var i = 0; i < data.length; i++)
-					{
-						data[i].labelLength = maxLen;
-						if (data[i].children)
-						{getMaxLength(data[i].children);}
-						if (data[i]._children)
-						{getMaxLength(data[i]._children);}
-					}
-					
-				}
-				if(treeData._children)
-				{getMaxLength(treeData._children);}
-				if(treeData.children)
-				{getMaxLength(treeData.children);}
-				treeData.labelLength = treeData.name.length;
-
-
-				// Collapse the node and all it's children
-				function collapse(d) {
-				  if(d.children) {
-					d._children = d.children
-					d._children.forEach(collapse)
-					d.children = null
-				  }
-				}
-				// Collapse the node and all it's children
-				function expand(d) {
-				  if(d._children) {
-					d.children = d._children
-					d.children.forEach(expand)
-					d._children = null
-				  }
-				}
-				// Toggle children on click.
-				function click(d) 
-				{
-					if (d.children) {
-						d._children = d.children;
-						d.children = null;
-					} else 
-					{
-						d.children = d._children;
-						d._children = null;
-					}
-					update(d,theAllLinks);
-				}
-				// Collapse/expand entire tree on double-click
-				function dblclick(d) 
-				{
-					if(d.children) 
-					{
-						collapse(d);
-					}
-					else if(d._children)
-					{
-						expand(d);
-					}
-					update(d,theAllLinks);
-				}	
-
-				
-				//aigner: Here the tree layout is created
-				var d3_body = d3.select("body")
-                var lobiID = String(getRandomInt(0,1000))
-                var divClassName = "treeDiv"+lobiID
-                var treeLayoutdiv = d3_body.append("div").attr("class",divClassName+" panel-default")
-                                                .style("left","200px")
-                                                .style("top","200px")
-                                                .style("position", "absolute")
-                treeLayoutdiv.append("div").attr("class","panel-heading")
-                    .append("div").attr("class","panel_title").append("h4").text(theName)
-                $('.'+divClassName).lobiPanel({
-                    reload: false,
-                    editTitle: false,
-                    unpin: false,
-                    minWidth: 200,
-                    maxWidth: 100000,
-                    minHeight: 200,
-                    maxHeight: 100000,
-                });
-                $('.'+divClassName).lobiPanel('unpin');
-										
-				var treeLayoutSVG = treeLayoutdiv.append("svg").attr("class","treeLayoutSVG")
-				var treeGroup = treeLayoutSVG.append("g").attr("class","treeGroup").style("position","absolute")
-								.attr("transform", "translate(50,0)");
-				var margin = {top: 20, right: 90, bottom: 20, left: 90},
-							  width = 960 - margin.left - margin.right,
-							  height = 500 - margin.top - margin.bottom;
-
-				// append the svg object to the body of the page
-				// appends a 'group' element to 'svg'
-				// moves the 'group' element to the top left margin
-				var offset_tmp = 60;
-				treeLayoutSVG = treeLayoutSVG.attr("width", width + 1.2*margin.right + margin.left+offset_tmp)
-						 .attr("height", height + margin.top + margin.bottom+offset_tmp);
-				treeLayoutdiv = treeLayoutdiv.attr("width", width + 1.2*margin.right + margin.left+offset_tmp)
-						 .attr("height", height + margin.top + margin.bottom+offset_tmp)
-						 .on("mouseover",function(){d3.select(this).style("cursor", "grab")})
-				treeGroup = treeGroup
-					.attr("width", width + margin.right + margin.left)
-					.attr("height", height + margin.top + margin.bottom);
-					
-                
-                var frame = treeGroup.append("rect")
-					.attr("class","treeFrame")
-					.attr("stroke-width", 1)
-					.attr("stroke", "white")
-					.attr("fill-opacity", .8);				
-				
-				// Define the root
-				root = treeData;
-				root.x0 = 0;
-				root.y0 = 0;
-				
-				// Append a group which holds all nodes and which the zoom Listener can act upon.
-				var svgGroup_xOff = root.name.length*10+50
-				var svgGroup = treeGroup.append("g")
-					.attr("class","tree_"+theName)
-					.attr("transform", "translate("+ svgGroup_xOff + "," + String(margin.top+10) + ")");
-				
-				collapse(root);
-				update(root,theAllLinks);
-				
-
-				function update(source,allLinks) 
-				{
-					// Compute the new height, function counts total children of root node and sets tree height accordingly.
-					// This prevents the layout looking squashed when new nodes are made visible or looking sparse when nodes are removed
-					// This makes the layout more consistent.
-					var levelWidth = [1];
-					var levelLength = [1];
-					var childCount = function(level, n) {
-
-						if (n.children && n.children.length > 0) {
-							if (levelWidth.length <= level + 1) levelWidth.push(0);
-							
-							levelWidth[level + 1] += n.children.length;
-							n.children.forEach(function(d) {
-								childCount(level + 1, d);
-							});
-						}
-					};
-					childCount(0, root);
-
-					var newHeight = d3.max(levelWidth) * 60; // 20 pixels per line
-					var newWidth = viewerWidth+300;
-					
-					//BENNI: fill in viewerHeight instead of newHeight for other expanding/collapsing beaviour
-					tree = tree.size([newHeight, newWidth]);
-					
-					frame = frame.attr("width",newWidth)
-						.attr("height",newHeight+60)
-						.attr("fill","white");
-						
-					
-					
-					// Compute the new tree layout.
-					var nodes = tree.nodes(root),
-						links = tree.links(nodes);
-						
-						
-					//aigner: count all descendants of a node
-					function countDescendants(node, counter) 
-					{
-						if (node._children)
-						{
-							node._children.forEach(function(n)
-							{
-								counter = countDescendants(n, counter);
-							});
-						}
-						else if (node.children)
-						{
-							node.children.forEach(function(n)
-							{
-								counter = countDescendants(n, counter);
-							});
-						}
-						else
-						{
-							counter ++;
-						}
-						return counter;
-					}
-					
-					
-					var depths = [];
-					var labelLength = [];
-					nodes.forEach(function(d) 
-					{				
-						//aigner: If node is collapsed show number of ancestors
-						if (d._children)
-						{
-							d._childrenNum = countDescendants(d, 0);
-							d.text = d.name + " (" + d._childrenNum + ")";
-						}
-						else 
-						{
-							d.text = d.name
-						}
-						
-						//aigner: Find maximum labelLength for each level
-						if (!depths.includes(d.depth))
-						{
-							depths.push(d.depth);
-							labelLength.push(d.text.length);
-						}
-						else
-						{
-							if (d.depth!=0){labelLength[depths.indexOf(d.depth)] = Math.max(d.text.length, labelLength[depths.indexOf(d.depth)]);}
-						}
-					});
-					// Set widths between levels based on labelLength of each level.
-					var newWidth=0;	
-					var depth_tmp = 0;			
-					nodes.forEach(function(d) 
-					{
-						if (d.parent)
-						{
-							d.y = d.parent.y+(labelLength[depths.indexOf(d.depth)])*10+50;
-						}
-						else{d.y=0}
-						
-						
-						if (newWidth<d.y)
-						{newWidth=d.y;}
-						
-						// console.log("##############")
-						// console.log(d.name)
-						// console.log("x = " + d.x)
-						// console.log("y = " + d.y)
-						// console.log("depth = " + depths.indexOf(d.depth))
-						// console.log("##############")
-					});	
-					
-					
-					
-                    newWidth=Math.max(newWidth,getTextWidth(theName,"Arial 12pt"));
-					//aigner: Adjust height and width of the frame
-					$('.'+divClassName).lobiPanel('setWidth', newWidth + margin.top + margin.bottom +400+maxLabelLength*25+offset_tmp);
-                    $('.'+divClassName).lobiPanel('setHeight', newHeight + margin.top + 2*margin.bottom+offset_tmp);
-					treeLayoutSVG = treeLayoutSVG.attr("height", newHeight + margin.top + margin.bottom+offset_tmp)
-					treeLayoutSVG = treeLayoutSVG.attr("width", newWidth + margin.top + margin.bottom +300+maxLabelLength*25+offset_tmp)
-					frame = frame.attr("height", newHeight + margin.top + margin.bottom)
-					frame = frame.attr("width", newWidth + margin.top + margin.bottom+300+maxLabelLength*15)
-
-					
-					//Function writeTreeToXML goes through tree nodes and puts the into an xml document
-					function writeTreeToXML(aNode,anXMLDoc,anXPath)
-					{
-						//Variable "children" 
-						//--> One children variable, no matter whether a node has "_children" (collapsed) or "children" (expanded)
-						var children;
-						if (aNode._children){children = aNode._children;}
-						else if (aNode.children){children = aNode.children;}
-						
-						//Get current xml element with its xPath
-						var element = anXMLDoc.evaluate(anXPath,anXMLDoc, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null ).singleNodeValue;
-						if (element != null) {element.value = '...';}
-						
-						//If a node has children (collapsed or expanded), loop through them
-						if (children)
-						{
-							for (var i=0; i < children.length;i++)
-							{
-								//Name of the new XML element --> childName
-								var child = children[i];
-								var childName = child.name.split(/[\[\]]+/);//Split childName at "[]" which is the uID 
-								var cleanChildName = childName[0].split(/[\+\*\^\-\ \#]+/);//Split childName all special characters
-								var newNode = anXMLDoc.createElement(String(cleanChildName[0]));
-								
-								//The children are appended to the xPath --> newXPath
-								var newXPath = anXPath+"/"+cleanChildName[0];
-								
-								//If childName contains a uID, make the uID an attribute
-								if (childName[1])
-								{
-									if (parseInt(childName[1]))
-									{
-										var dummyID = childName[1];
-										newNode.setAttribute("dummyID", dummyID)
-										newXPath = newXPath+"[@dummyID='"+dummyID+"']";
-									}
-									else
-									{
-										var uID = childName[1];
-										newNode.setAttribute("uID", uID)
-										newXPath = newXPath+"[@uID='"+uID+"']";
-									}
-								}
-								if (cleanChildName.length>1) {newNode.setAttribute("elementName", childName[0])};
-								
-								//Append the newNode to the xml structure
-								element.appendChild(newNode);
-								
-								
-								
-								////aigner: Sorting of XML elements according to "uID"
-								// var items = element.children;
-								// var itemsArr = [];
-								// for (var j in items) {
-									// if (items[j].nodeType == 1) { // get rid of the whitespace text nodes
-										// itemsArr.push(items[j]);
-									// }
-								// }
-								// itemsArr.sort(function(a,b){
-									// if (a.getAttribute("uID") < b.getAttribute("uID"))
-										// return -1;
-									// if (a.getAttribute("uID") > b.getAttribute("uID"))
-										// return 1;
-									// return 0;
-									// });
-
-								// for (j = 0; j < itemsArr.length; ++j) {
-								  // element.appendChild(itemsArr[j]);
-								// }
-								
-								//call function writeTreeToXML recursively for all children
-								writeTreeToXML(child,anXMLDoc,newXPath)
-							}
-						}
-						else
-						{
-							if (aNode.value){element.innerHTML = String(aNode.value);}
-							else{element.innerHTML = " ";}
-						}
-						//return the xml document
-						return anXMLDoc;
-					}
-					
-					function removeAttributeInAllElements(aDocument,attribute)
-					{
-					  var matchingElements = [];
-					  var allElements = aDocument.getElementsByTagName('*');
-					  for (var i = 0, n = allElements.length; i < n; i++)
-					  {
-						if (allElements[i].getAttribute(attribute) !== null)
-						{
-							allElements[i].removeAttribute(attribute);
-						}
-					  }
-					  return matchingElements;
-					}
-					
-					function putAncestorsInXMLString(strWrapper, aNode)
-					{
-						//Name of the new XML element
-						var nodeName = aNode.name.split(/[\[\]]+/);//Split name at "[]" which is the uID 
-						var cleanNodeName = nodeName[0].split(/[\+\*\^\-\ \#]+/);//Split nodeName all special characters
-						//If nodeName contains a uID, make the uID an attribute
-						if (nodeName[1])
-						{
-							var uID = nodeName[1];
-							strWrapper.val = "<"+cleanNodeName[0]+" uID='"+ uID +"'>"+strWrapper.val+"</"+cleanNodeName[0]+">";;
-						}
-						else
-						{
-							strWrapper.val = "<"+cleanNodeName[0]+">"+strWrapper.val+"</"+cleanNodeName[0]+">";;
-						}
-						var aParent = aNode.parent;
-						if (aParent)
-						{
-							return putAncestorsInXMLString(strWrapper, aParent);
-						}
-						else 
-						{
-							return strWrapper;
-						}
-					}
-					
-					function putAncestorsInXPath(strWrapper, aNode)
-					{
-						//Name of the new XML element
-						var nodeName = aNode.name.split(/[\[\]]+/);//Split name at "[]" which is the uID 
-						var cleanNodeName = nodeName[0].split(/[\+\*\^\-\ \#]+/);//Split nodeName all special characters
-						//If nodeName contains a uID, make the uID an attribute
-						if (nodeName[1])
-						{
-							var uID = nodeName[1];
-							strWrapper.val = "/"+cleanNodeName[0]+"[@uID='"+uID+"']"+strWrapper.val;
-						}
-						else
-						{
-							strWrapper.val = "/"+cleanNodeName[0]+strWrapper.val;
-						}
-						var aParent = aNode.parent;
-						if (aParent)
-						{
-							return putAncestorsInXPath(strWrapper, aParent);
-						}
-						else 
-						{
-							return strWrapper;
-						}
-					}
-					
-					// Function to download data to a file
-					function download(filename, text) {
-						var element = document.createElement('a');
-						element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(text));
-						element.setAttribute('download', filename);
-
-						element.style.display = 'none';
-						document.body.appendChild(element);
-
-						element.click();
-
-						document.body.removeChild(element);
-					}
-					
-					
-					var treeNodeMenu = nodeMenu;
-                    var treeMenu = [
-                    {
-						title: 'Download full tree as XML-file',
-						onMouseDown: function(elm, d, i) {
-							//Begin xml structure with the first element
-							var xmlString = "<"+nodes[0].name+">"+"</"+nodes[0].name+">";
-							//Create a new xml document
-							var parser = new DOMParser();
-							var xmlDocument = parser.parseFromString(xmlString, "text/xml"); //important to use "text/xml"
-							//Get initial xPath of the tree and pass it to the function "writeTreeToXML"
-							var initialXPath = "/"+nodes[0].name;								
-							writeTreeToXML(nodes[0],xmlDocument,initialXPath);
-							//remove all attributes dummyID
-							removeAttributeInAllElements(xmlDocument,'dummyID');
-							//Make the xml document a string
-							var serializer = new XMLSerializer();
-							var xmlString = serializer.serializeToString(xmlDocument);
-							xmlString = vkbeautify.xml(xmlString);														
-							//Download a document with the xml-schema
-							download(theName+'_full.xml',xmlString);						
-						},
-						onMouseUp: function(elm, d, i) {
-						},
-						onMouseOver: function(elm, d, i) {
-						},
-						childrenItems: []
-					},
-					{
-						title: 'Download tree as XML-file from current node',
-						onMouseDown: function(elm, d, i) {
-							var xmlString = putAncestorsInXMLString({ val : '' }, d).val;
-							var initialXPath = putAncestorsInXPath({ val : '' }, d).val;												
-							//Create a new xml document
-							var parser = new DOMParser();
-							var xmlDocument = parser.parseFromString(xmlString, "text/xml"); //important to use "text/xml"
-							//Get initial xPath of the tree and pass it to the function "writeCurrentTreeToXML"
-							writeTreeToXML(d,xmlDocument,initialXPath);
-							//remove all attributes dummyID
-							removeAttributeInAllElements(xmlDocument,'dummyID');
-							//Make the xml document a string
-							var serializer = new XMLSerializer();
-							xmlString = serializer.serializeToString(xmlDocument);
-							xmlString = vkbeautify.xml(xmlString);														
-							//Download a document with the xml-schema
-							download(theName+"_"+d.name+'.xml',xmlString);						
-						},
-						onMouseUp: function(elm, d, i) {
-						},
-						onMouseOver: function(elm, d, i) {
-						},
-						childrenItems: []
-					}
-                    ]
-					treeNodeMenu = nodeMenu.concat(treeMenu)
-					
-
-					// Update the nodes…
-					var treeNode = svgGroup.selectAll("g.treeNode")
-						.data(nodes, function(d) {
-							return d.id || (d.id = ++i);
-						});
-
-					var dblclick_timer = false;
-					// Enter any new nodes at the parent's previous position.
-					var nodeEnter = treeNode.enter().append('g')
-					  .attr('class', 'treeNode')
-					  .attr("transform", function(d) {
-						return "translate(" + source.y0 + "," + source.x0 + ")";
-					})
-					.on('contextmenu', d3.contextMenu(treeNodeMenu))
-					.on("mousedown", function(d) {
-						if (d3.event.which != 3)
-						{
-							// if double click timer is active, this click is the double click
-							if ( dblclick_timer )
-							{
-								clearTimeout(dblclick_timer)
-								dblclick_timer = false
-								// double click code code comes here
-								//console.log("DOUBLE CLICK")
-								dblclick(d);
-							}
-							// otherwise, what to do after single click (double click has timed out)
-							else dblclick_timer = setTimeout( function(){
-								dblclick_timer = false
-								// single click code code comes here
-								//console.log("SINGLE CLICK")
-								click(d);
-							}, 250)
-						}
-					})
-						
-					nodeEnter.append("circle")
-						.attr('class', 'nodeCircle')
-						.attr("r", 0)
-						.style("fill", function(d) {
-							if (d._children)
-							{
-								if(theName.includes("Input")){return '#ea9999'}
-								else if(theName.includes("Output")){return '#d6ea99'}
-								else {return "lightsteelblue"}
-							}
-							else {return "#fff"}
-						})
-						.style("stroke", function(d) {
-							if(theName.includes("Input")){
-								//console.log(d);
-								return '#CC0000'}
-							else if(theName.includes("Output")){
-								//console.log(d);
-								return '#99CC00'}
-						})
-						.attr("cx", function(d) {return xOffset});
-
-					nodeEnter.append("text")
-						.attr("x", function(d) 
-						{
-								return d.children || d._children ? -10+xOffset : 10+xOffset;
-						})
-						.attr("dy", ".35em")
-						.attr('class', 'nodeText')
-						.attr("text-anchor", function(d) {
-							return d.children || d._children ? "end" : "start";
-						})
-						.text(function(d) {
-							return d.text;
-						})
-						.style("fill-opacity", 0)
-						
-
-					// Update the text to reflect whether node has children or not.
-					treeNode.select('text')
-						.attr("x", function(d) {
-							return d.children || d._children ? -10+xOffset : 10+xOffset;
-						})
-						.attr("text-anchor", function(d) {
-							return d.children || d._children ? "end" : "start";
-						})
-						.text(function(d) {
-							return d.text;
-						});
-
-					// Change the circle fill depending on whether it has children and is collapsed
-					treeNode.select("circle.nodeCircle")
-						.attr("r", 4.5)
-						.style("fill", function(d) {
-							if (d._children)
-							{
-								if (d._children)
-								{
-									if(theName.includes("Input")){return '#ea9999'}
-									else if(theName.includes("Output")){return '#d6ea99'}
-									else {return "lightsteelblue"}
-								}
-								else {return "#fff"}
-							}
-							else{return "#fff";}
-						})					
-								
-					// UPDATE		
-					// Transition nodes to their new position.
-					var nodeUpdate = treeNode.transition()
-						.duration(duration)
-						.attr("transform", function(d) {
-							return "translate(" + d.y + "," + d.x + ")";
-						});
-
-					// Fade the text in
-					nodeUpdate.select("text")
-						.style("fill-opacity", 1);
-					
-					nodeEnter.append("svg:title").text("Click left to expand, click right to inspect")
-					
-					// Remove any exiting nodes
-					var nodeExit = treeNode.exit().transition()
-					  .duration(duration)
-					  .attr("transform", function(d) {
-						  return "translate(" + source.y + "," + source.x + ")";
-					  })
-					  .remove();
-
-					// Update the links…
-					var link = svgGroup.selectAll("path.treeLink")
-						.data(links, function(d) {
-							return d.target.id;
-						});
-
-					// Enter any new links at the parent's previous position.
-					link.enter().insert("path", "g")
-						.attr("class", "treeLink")
-						.attr("d", function(d) {
-							var o = {
-								x: source.x0,
-								y: source.y0
-							};
-							return diagonal({
-								source: o,
-								target: o
-							});
-						});
-
-					// Transition links to their new position.
-					link.transition()
-						.duration(duration)
-						.attr("d", diagonal);
-
-					// Transition exiting nodes to the parent's new position.
-					link.exit().transition()
-						.duration(duration)
-						.attr("d", function(d) {
-							var o = {
-								x: source.x,
-								y: source.y
-							};
-							return diagonal({
-								source: o,
-								target: o
-							});
-						})
-						.remove();
-					
-					// Stash the old positions for transition.
-					nodes.forEach(function(d) {						
-						d.x0 = d.x;
-						d.y0 = d.y;
-					});
-				}
-			}
-
-			
-			
-            //aigner: Here the data is read and the sankey diagram is created
-			//#####################################################################//
-			var graphs,	currentGraph, varCategories;
-			function startSankeyDiagram(data, graphID) 
-			{
-				graphs =  data.graphs;
-				for (var i=0;i<graphs.length;i++)
-				{
-					if (graphs[i].id==graphID)
-					{
-						currentGraph = graphs[i]
-					}
-				}
-				varCategories =  data.categories;
-				
-                //Highlight function, that shows usage of a node in the XDSM
-                function highlight(data)
-                {
-                    var xPath = data.xPath;
-                    var allLinks = d3.selectAll(".link");
-                    var allLinks_tmp = allLinks[0];
-                    allLinks_tmp.forEach(function(p) {
-                        var firstElement_tmp = p.__data__.name.split("/")[1]
-                        var xPath_fromFirst = "/"+firstElement_tmp+xPath.split(firstElement_tmp)[1]
-                        var p_name_list = p.__data__.name.split(",")
-                        var highlight_on = false
-                        p_name_list.forEach(function(p_name) 
-                        {
-                            if (include(p_name+"__",xPath_fromFirst+"__") || include(p_name,xPath_fromFirst+"/"))
-                            {
-                                highlight_on = true;
-                            }
-                        })
-                        if (highlight_on)
-                        {
-                            d3.select(p).style("opacity", .8);			
-                        }
-                        else
-                        {
-                            d3.select(p).style("opacity", 0);			
-                        }
-                    });
-                }
-                
-                function showVariableTable(aVariable)
-                {											
-                    var headLine = "Node Information (" + aVariable.name + ")";
-                    var data = [];
-                    // render the table(s)
-                    data.push({ "name" : "Name", "value" : "\""+aVariable.name+"\"" })
-                    data.push({ "name" : "xPath", "value" : aVariable.xPath })
-                    if (aVariable.type){data.push({ "name" : "Type", "value" : aVariable.type })}
-                    if (aVariable.level){data.push({ "name" : "Level", "value" : aVariable.level })}
-                    if (aVariable.children || aVariable._children)
-                    {
-                        var childrenNum=0;
-                        if (aVariable.children){childrenNum=childrenNum+aVariable.children.length}
-                        if (aVariable._children){childrenNum=childrenNum+aVariable._children.length}
-                        data.push({ "name" : "Number of children", "value" : childrenNum })
-                    }
-                    if (aVariable.dimension){data.push({ "name" : "Dimension", "value" : aVariable.dimension })}
-                    else if(aVariable.dimension===null){data.push({ "name" : "Dimension", "value" : "undefined" })}
-                    if (aVariable.value){data.push({ "name" : "Value(s)", "value" : aVariable.value })}
-                    
-                    var d3_body = d3.select("body");
-                    
-                    var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                    panel_div.append("div").attr("class","panel-heading")
-                        .append("div").attr("class","panel_title").append("h4").text(headLine)
-                    var listGroup = panel_div.append("div").attr("class","panel-body")
-                        .append("table").attr("id","myTable")
-                        .append("tbody")
-                        
-                    data.forEach(function(listElement)
-                    {
-                        var row = listGroup.append("tr")
-                        row.append("td").text(listElement.name)
-                        row.append("td").text(listElement.value)
-                        
-                    })
-                    $('.myPanel').lobiPanel({
-                        reload: false,
-                        editTitle: false,
-                        expand: false,
-                        unpin: false,
-                        resize: "none",
-                        minWidth: 200,
-                        minHeight: 200,
-                        maxWidth: 1100,
-                        maxHeight: 1200,
-                    });
-                    $('.myPanel').lobiPanel('unpin');
-                }
-                
-                //menu --> functions for right click options
-                var nodeMenu = [
-                {
-                    title: 'Show node information',
-                    onMouseDown: function(elm, d, i) {
-                        showVariableTable(d);
-                    },
-                    onMouseUp: function(elm, d, i) {},
-                    onMouseOver: function(elm, d, i) {},
-                    childrenItems: []
-                },
-                {
-                    title: 'Show usage of node in diagram',
-                    onMouseDown: function(elm, d, i) {
-                        d3.selectAll(".treeFrame").attr("fill-opacity", .5);
-                        d3.selectAll(".nodeText").style("fill-opacity", 0.5);					
-                        highlight(d);
-                    },
-                    onMouseUp: function(elm, d, i) {				
-                        d3.selectAll(".link").style("opacity",.6)
-                        d3.selectAll(".treeFrame").attr("fill-opacity", .8);
-                        d3.selectAll(".nodeText").style("fill-opacity", 1);					
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: []
-                },
-                {
-                    title: 'Copy x-path to clipboard',
-                    onMouseDown: function(elm, d, i) {
-                        window.prompt("Copy to clipboard: Ctrl+C, Enter", d.xPath);
-                        d3.select('.d3-context-menu').style('display', 'none');
-                    },
-                    onMouseUp: function(elm, d, i) {
-                    },
-                    onMouseOver: function(elm, d, i) {
-                    },
-                    childrenItems: []
-                }
-                ]
-				
-				var graph = currentGraph.xdsm;
-				var theNodes = graph.nodes
-				var theLinks = graph.edges
-				theLinks.forEach(function (link) {
-				  link.source = link.from;
-				  link.target = link.to;
-				  link.value = link.name.split(",").length
-				});
-                
-				
-				//################################################################################################//	
-				var headerDiv = sankeyDiagramDiv.append("div").attr("class","panel panel-primary")
-				headerDiv.append("div").attr("class","panel-heading text-center")
-						.append("h3")
-						.attr("class","panel-title")
-						.style("font-family","Arial")
-						.style("font-size","20pt")
-						.text("Sankey Diagram")
-				var name_tmp="";
-				if (currentGraph.name){name_tmp=currentGraph.name}
-				else{name_tmp="Graph " + currentGraph.id}
-				headerDiv.append("div").attr("class","panel-body")
-					.style("font-family","Arial")
-					.style("font-size","16pt")
-					.text("Graph name: " + name_tmp)
-				headerDiv.append("div").attr("class","panel-body")
-					.style("font-family","Arial")
-					.style("font-size","16pt")
-					.text("Graph description: " + currentGraph.description)
-				//################################################################################################//	
-				
-				//aigner: Tree option menu to select which kind of tree view the user wants to see
-				//#####################################################################//
-				function showFullTree(categoryID, categoryDescr)
-				{
-					var name_tmp = "Full data model tree view; Categorization: " + categoryDescr;
-					var emptyArray="";
-					var allLinks = d3.selectAll(".link");
-					var theSchema = currentGraph.variableSchemes[categoryID];
-					createTreeLayout(name_tmp,theSchema,emptyArray,allLinks,nodeMenu);
-				}
-				
-				var childrenItems = [];
-				for (var j=0; j< varCategories.length; j++)
-				{
-					childrenItems.push({title: 'according to ' + varCategories[j].description,
-								   varCategory: varCategories[j].name,
-								   description: varCategories[j].description,
-								   onMouseClick: function(elm, d, i) {showFullTree(d.varCategory,d.description)},
-								   onMouseOver: function(elm,d,i){}})
-				}
-				var treeOptionMenu = [
-				{
-					title: 'Show variable tree...',
-					onMouseDown: function(elm, d, i) {
-					},
-					onMouseUp: function(elm, d, i) {
-					},
-					onMouseOver: function(elm, d, i) {
-					},
-					childrenItems: childrenItems
-				}
-				]
-				//#####################################################################//                
-                
-                function showList(aTitle,aList,aMenu)
-                {
-                    if (aList.length != 0)
-                    {
-                        var d3_body = d3.select("body");
-                        
-                        var panel_div = d3_body.append("div").attr("class", "myPanel panel-default")
-                        panel_div.append("div").attr("class","panel-heading")
-                            .append("div").attr("class","panel_title").append("h4").text(aTitle)
-                        panel_div.append("input")
-                            .attr("id","myInput")
-                            .attr("placeholder","Filter search...")
-                            .attr("title","Type in a name")
-                            .attr("onkeyup","filterSearch()")
-                        var listGroup = panel_div.append("div").attr("class","panel-body")
-                            .append("table").attr("id","myTable")
-                            .append("tbody")
-                            
-                        var tr = listGroup
-                            .selectAll('tr')
-                            .data(aList).enter()
-                                .append('tr')
-                        var td = tr.append("td").html(function(d) { 
-                            if (d.xPath){return d.xPath;} 
-                            else {return d.name;} 
-                        })
-                        tr.on('contextmenu', d3.contextMenu(aMenu));
-                        $('.myPanel').lobiPanel({
-                            reload: false,
-                            editTitle: false,
-                            expand: false,
-                            unpin: false,
-                            resize: "none",
-                            minWidth: 200,
-                            minHeight: 200,
-                            maxWidth: 1100,
-                            maxHeight: 1200,
-                        });
-                        $('.myPanel').lobiPanel('unpin');
-                        $('.myPanel').lobiPanel('height','5000');
-                    }
-                }
-				
-				//aigner: Data Model Tree View Button
-				//####################################################################################################################
-				var dataModelDiv = d3.select(".sankeyDiagramDiv").append("div").attr("class","dataModelDiv").attr("transform","translate(10,0)")
-				var ul = dataModelDiv.append("ul")
-				var dropdown1 = ul.append("li").on("mouseover", function(){d3.select(this).style("cursor", "default")})
-				dropdown1.append("img").attr("src",fileReference.AGILE_Icon)
-					.attr("align","left")
-					.style("margin-left","6px")
-					.style("margin-right","-10px")
-					.style("margin-top","10px")
-					.style("margin-bottom","0px")
-					.attr("height","20")
-					.attr("width","20")
-				dropdown1.append("a").text("Data Model Tree")
-				var links = dropdown1.append("ul");
-                var xOffset_ul = dropdown1[0][0].offsetLeft+dropdown1[0][0].offsetWidth-40;
-                links.style("left", String(xOffset_ul)+"px")
-				for (var j=0; j< varCategories.length; j++)
-				{
-					//console.log(varCategories[j])
-					var linkLi = links.append("li");
-					var linkA = linkLi.append("a")
-						.attr("id",j)
-						.text(varCategories[j].description)
-						.on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-						.on("click", function()
-						{		
-							showFullTree(varCategories[this.id].name,varCategories[this.id].description)
-						})
-				}
-				//aigner: Set width of the div, so the VISTOMS dropdown (in the top of the page) still works
-				//dataModelDiv.style("width", String(dropdown1.node().getBoundingClientRect().width+20)+"px")
-				//####################################################################################################################
-                
-                //aigner: Data Model List View Button
-				//####################################################################################################################
-				var ul_list = dataModelDiv.append("ul")
-				var dropdownList = ul_list.append("li").on("mouseover", function(){d3.select(this).style("cursor", "default")})
-				dropdownList.append("img").attr("src",fileReference.AGILE_Icon)
-					.attr("align","left")
-					.style("margin-left","6px")
-					.style("margin-right","-10px")
-					.style("margin-top","10px")
-					.style("margin-bottom","0px")
-					.attr("height","20")
-					.attr("width","20")
-				dropdownList.append("a").text("Data Model List")
-				var linksList = dropdownList.append("ul");
-                var xOffset_ul = dropdownList[0][0].offsetLeft+dropdownList[0][0].offsetWidth-40;
-                linksList.style("left", String(xOffset_ul)+"px")
-				for (var j=0; j< varCategories.length; j++)
-				{
-					//console.log(varCategories[j])
-					var linkLi = linksList.append("li");
-					var linkA = linkLi.append("a")
-						.attr("id",j)
-						.text(varCategories[j].description)
-						.on("mouseover", function(){d3.select(this).style("cursor", "pointer")})
-						.on("click", function()
-						{	
-                            var variables = JSON.parse(JSON.stringify(currentGraph.variableSchemes[varCategories[this.id].name]));
-                            variables.forEach(function(variable)
-                            {
-                                variable.name = variable.xPath
-                                //work around because nodeMenu expexts the data, to have a "data" object inside
-                                variable.data = variable
-                                variable.data.name = variable.xPath.split("/")[variable.xPath.split("/").length-1]
-                            })
-                            var title = "List view: full variable set categorized according to " + varCategories[this.id].description
-                            showList(title,variables,nodeMenu)
-						})
-				}
-				//aigner: Set width of the div, so the VISTOMS dropdown (in the top of the page) still works
-				//####################################################################################################################
-				
-				d3.select(".dataModelDiv").moveToBack()
-				headerDiv.moveToBack()
-                d3.select(".addButtonDiv").moveToBack()
-				d3.select(".navigationBarDiv").moveToBack()
-				d3.select(".visPackDiv").moveToBack()
-				
-				
-				biHiSankey
-				  .nodes(theNodes)
-				  .links(theLinks)
-				  .initializeNodes(function (node) {
-					node.state = node.parent ? "contained" : "collapsed";
-				  })
-				  .layout(LAYOUT_INTERATIONS);
-
-				disableUserInterractions(2 * TRANSITION_DURATION);
-				
-				update();
-			};
-			//#####################################################################//
-			startSankeyDiagram(data,graphID);
-			
-			},{"d3":1}]},{},[2]);
-		}
-		</script>
-    </body>
-</html>
diff --git a/kadmos/vistoms/templates/acknowledgements.html b/kadmos/vistoms/templates/acknowledgements.html
index 6168877a0..0d10fc79b 100644
--- a/kadmos/vistoms/templates/acknowledgements.html
+++ b/kadmos/vistoms/templates/acknowledgements.html
@@ -2,8 +2,10 @@
 {% block content %}
 <div class="container">
     <h1>Acknowledgements</h1>
-    <p>The development of KADMOS/VISTOMS interface and this website have been performed in the framework of the <a href="http://agile-project.eu/">AGILE project</a> (Aircraft 3rd Generation MDO for Innovative Collaboration of Heterogeneous Teams of Experts) and has received funding from the European Union Horizon 2020 Programme (H2020-MG-2014-2015) under grant agreement no. 636202. The authors are grateful to the partners of the AGILE consortium for their contribution and feedback.</p>
-    <p>With special thanks to Maaike de Wit and Lukas Müller for the creation of this website interface.</p>
+    <p>The software and technologies used on this website have been developed by Benedikt Aigner (RWTH Aachen) and Imco van Gent (TU Delft).</p>
+    <p>The development of the KADMOS/VISTOMS interface and this website have been performed in the framework of the <a href="http://agile-project.eu/">AGILE project</a> (Aircraft 3rd Generation MDO for Innovative Collaboration of Heterogeneous Teams of Experts) and has received funding from the European Union Horizon 2020 Programme (H2020-MG-2014-2015) under grant agreement no. 636202. The authors are grateful to the partners of the AGILE consortium for their contribution and feedback.</p>
+    <p>With special thanks to Lukas Müller and Maaike de Wit for the creation of the first version of this website interface.</p>
+    <p>With special thanks to Melvin van Gent for his help and advice on web development.</p>
     <img src="{{url_for('static', filename='agile_logo.png')}}" class="img-responsive" alt="AGILE logo">
     <img src="{{url_for('static', filename='agile_partners.png')}}" class="img-responsive" alt="AGILE partners">
     <p></p>
diff --git a/kadmos/vistoms/templates/index.html b/kadmos/vistoms/templates/index.html
index aec6f50c0..486cfcd90 100644
--- a/kadmos/vistoms/templates/index.html
+++ b/kadmos/vistoms/templates/index.html
@@ -3,19 +3,71 @@
 <div class="container">
     <h1>Welcome to the KADMOS / VISTOMS interface!</h1>
     {% include 'message.html' %}
-    <p>Click here to start a new KADMOS/VISTOMS session:</p>
     {% include 'error.html' %}
     <div class="panel-body blue list group">
-        <a href="/startnewvistoms" id="confirm" class="list-group-item">
-            Start new VISTOMS session
+        <a href="/start_vistoms_server_session" id="confirm" class="list-group-item">
+            Start/continue VISTOMS session
         </a>
     </div>
-    <p>Click here to start a polulated KADMOS/VISTOMS session with some examples:</p>
     {% include 'error.html' %}
-    <div class="panel-body blue list group">
-        <a href="/startpopulatedvistoms" id="confirm" class="list-group-item">
-            Start populated VISTOMS session
-        </a>
+    <p><br><br>Here you can download some example files to use in your session:</p>
+    <div class="row">
+    <div class="col-lg-4">
+        <div class="panel panel-default">
+            <div class="panel-heading">
+                <h3 class="panel-title">Sellar Problem</h3>
+            </div>
+            <div class="panel-body blue list group">
+                <a href="/downloads/sellar_problem_rcg.xml" class="list-group-item">
+                    Repository connectivity graph
+                </a>
+                <a href="/downloads/sellar_problem_fpg_mda.xml" class="list-group-item">
+                    Fundamental problem graph (MDA)
+                </a>
+                <a href="/downloads/sellar_problem_fpg_mdo.xml" class="list-group-item">
+                    Fundamental problem graph (MDO)
+                </a>
+                <a href="/downloads/sellar_problem_mdfgs.xml" class="list-group-item">
+                    XDSM (MDF with Gauss-Seidel)
+                </a>
+                <a href="/downloads/sellar_problem_mdfj.xml" class="list-group-item">
+                    XDSM (MDF with Jacobi)
+                </a>
+                <a href="/downloads/sellar_problem_idf.xml" class="list-group-item">
+                    XDSM (IDF)
+                </a>
+            </div>
+        </div>
+    </div>
+    <div class="col-lg-4">
+        <div class="panel panel-default">
+            <div class="panel-heading">
+                <h3 class="panel-title">Super-sonic business jet</h3>
+            </div>
+            <div class="panel-body blue list group">
+                <a href="/downloads/ssbj_rcg.xml" class="list-group-item">
+                    Repository connectivity graph
+                </a>
+                <a href="/downloads/ssbj_fpg_mda.xml" class="list-group-item">
+                    Fundamental problem graph (MDA)
+                </a>
+                <a href="/downloads/ssbj_fpg_mdo.xml" class="list-group-item">
+                    Fundamental problem graph (MDO)
+                </a>
+                <a href="/downloads/ssbj_mdags.xml" class="list-group-item">
+                    XDSM (MDA, Gauss-Seidel)
+                </a>
+                <a href="/downloads/ssbj_doegs.xml" class="list-group-item">
+                    XDSM (DOE, Jacobi)
+                </a>
+                <a href="/downloads/ssbj_mdfj.xml" class="list-group-item">
+                    XDSM (MDF, Jacobi)
+                </a>
+                <a href="/downloads/ssbj_co.xml" class="list-group-item">
+                    XDSM (Collaborative Optimization)
+                </a>
+            </div>
+        </div>
     </div>
 </div>
-{% endblock %}
\ No newline at end of file
+{% endblock %}
diff --git a/kadmos/vistoms/templates/info.html b/kadmos/vistoms/templates/info.html
index e8db2b599..979c6239b 100644
--- a/kadmos/vistoms/templates/info.html
+++ b/kadmos/vistoms/templates/info.html
@@ -2,14 +2,12 @@
 {% block content %}
 <div class="container">
     <h1>Information</h1>
-    <p>Please, refer to the following articles for more information on the KADMOS/VISTOMS interface [1][2][3][4][5][6].</p>
-    <p>References
-        <br>[1] Ciampa, P.D., Nagel, B., The AGILE Paradigm: the next generation of collaborative MDO, 18th AIAA/ISSMO Multidisciplinary Analysis and Optimization Conference, 2017
-        <br>[2] van Gent, I., Hoogreef, M.F.M., La Rocca, G., CMDOWS: A Proposed New Standard to Store and Exchange MDO Systems, CEAS Aeronautical Journal, 2018
-        <br>[3] van Gent, I. and Ciampa, P.D. and Aigner, B. and Jepsen, J. and La Rocca, G., Schut, E.J., Knowledge architecture supporting collaborative MDO in the AGILE paradigm, 18th AIAA/ISSMO Multidisciplinary Analysis and Optimization Conference, 2017
-        <br>[4] Aigner, B., van Gent, I., La Rocca, G., Stumpf, E., Veldhuis, L.L.M., Using graph-based algorithms and data-driven documents for formulation and visualization of large MDO systems, CEAS Aeronautical Journal, 2018
-        <br>[5] van Gent, I., La Rocca, G., Veldhuis, L.L.M., Composing MDAO symphonies: graph-based generation and manipulation of large multidisciplinary systems, 18th AIAA/ISSMO Multidisciplinary Analysis and Optimization Conference, 2017
-        <br>[6] van Gent, I., Lombardi, R., La Rocca, G., d'Ippolito, R., A Fully Automated Chain from MDAO Problem Formulation to Workflow Execution, Abstract submitted to EUROGEN 2017, 2017
+    <p>Please, refer to the following articles for more information on the KADMOS/VISTOMS interface:
+        <br>[1] Aigner, B., van Gent, I., La Rocca, G., Stumpf, E., Veldhuis, L.L.M., Using graph-based algorithms and data-driven documents for formulation and visualization of large MDO systems, CEAS Aeronautical Journal, 2018
+        <br>[2] van Gent, I., La Rocca, G., Veldhuis, L.L.M., Composing MDAO symphonies: graph-based generation and manipulation of large multidisciplinary systems, 18th AIAA/ISSMO Multidisciplinary Analysis and Optimization Conference, 2017
+        <br>[3] van Gent, I., Hoogreef, M.F.M., La Rocca, G., CMDOWS: A Proposed New Standard to Store and Exchange MDO Systems, CEAS Aeronautical Journal, 2018
+        <br>[4] van Gent, I. and Ciampa, P.D. and Aigner, B. and Jepsen, J. and La Rocca, G., Schut, E.J., Knowledge architecture supporting collaborative MDO in the AGILE paradigm, 18th AIAA/ISSMO Multidisciplinary Analysis and Optimization Conference, 2017
+        <br>[5] Ciampa, P.D., Nagel, B., The AGILE Paradigm: the next generation of collaborative MDO, 18th AIAA/ISSMO Multidisciplinary Analysis and Optimization Conference, 2017
     </p>
 </div>
 {% endblock %}
\ No newline at end of file
diff --git a/kadmos/vistoms/vistoms.py b/kadmos/vistoms/vistoms.py
index ddbef6888..754491c8f 100644
--- a/kadmos/vistoms/vistoms.py
+++ b/kadmos/vistoms/vistoms.py
@@ -7,6 +7,7 @@ import os
 import shutil
 import sys
 import tempfile
+import time
 import uuid
 import webbrowser
 import xml.etree.ElementTree as ET
@@ -16,7 +17,7 @@ from datetime import datetime
 from shutil import copyfile
 
 import networkx as nx
-from flask import Flask, render_template, request, jsonify, send_from_directory
+from flask import Flask, render_template, request, jsonify, send_from_directory, send_file
 from kadmos.cmdows.cmdows import find_cmdows_file
 from kadmos.graph import load, FundamentalProblemGraph, KadmosGraph, RepositoryConnectivityGraph
 from kadmos.graph.mixin_vistoms import retrieve_session_folder
@@ -24,7 +25,8 @@ from kadmos.graph.mixin_vistoms import retrieve_session_folder
 app = Flask(__name__)
 
 # Folder and file settings
-SESSIONS_CATALOG_FOLDER = ''
+SESSIONS_CATALOG_FOLDER = '/Users/imcovangent/Desktop/VISTOMS_interface_ses'
+SESSIONS_FOLDER_SERVER = '/Users/imcovangent/Desktop/VISTOMS_sessions'
 TEMP_FILE = 'tmp'
 
 
@@ -39,6 +41,18 @@ def interface(debug=True, tempdir=None):
     if tempdir:
         tempfile.tempdir = tempdir
 
+    # Index
+    @app.route("/")
+    def index(error=None, message=None, selection=False):
+        # Check if error or message is send
+        if request.values.get('error', False) and error is None:
+            error = request.values['error']
+        if request.values.get('message', False) and message is None:
+            message = request.values['message']
+        # Render index
+        return render_template('index.html', error=error, message=message, selection=selection, page='start')
+
+    # Start of a local VISTOMS session (used in KADMOS scripts and command line creation of VISTOMS)
     @app.route('/start_vistoms_local')
     def start_vistoms_local():
         """
@@ -63,6 +77,60 @@ def interface(debug=True, tempdir=None):
 
         return render_template('VISTOMS.html', new=0, interfaceMode='local', sessionId=session_id)
 
+    # Start of a server VISTOMS session (used on mdo-system-interface.agile-project.eu)
+    @app.route('/start_vistoms_server_session')
+    def start_vistoms_server_session():
+        """
+           Function opens local VISTOMS session instance when it is called from the VISTOMS web interface.
+        """
+
+        # Get directory with sessions
+        sessions_dir = SESSIONS_CATALOG_FOLDER
+
+        # Create directory if it does not exist
+        if not os.path.exists(SESSIONS_CATALOG_FOLDER):
+            os.makedirs(SESSIONS_CATALOG_FOLDER)
+
+        # Get random uuid for session
+        session_id = str(uuid.uuid4())
+
+        # Add the json file of the session to the sessions directory
+        session_details = dict(folder=os.path.join(SESSIONS_FOLDER_SERVER, session_id),
+                               creation_date=str(datetime.now()))
+        with open(os.path.join(sessions_dir, session_id + '.json'), 'w') as outfile:
+            json.dump(session_details, outfile)
+
+        os.makedirs(os.path.join(SESSIONS_FOLDER_SERVER, session_id))
+
+        # Wait for directory to exist
+        attempts = 0
+        while True:
+            if os.path.isdir(os.path.join(SESSIONS_FOLDER_SERVER, session_id)):
+                break
+            time.sleep(1)
+            attempts += 1
+            if attempts > 20:
+                raise ReferenceError('Could not create new session directory on server.')
+
+        return render_template('VISTOMS.html', new=0, interfaceMode='server', sessionId=session_id)
+
+    # Download an example file
+    @app.route('/downloads/<path:file_name>')
+    def download_file(file_name):
+        vistoms_folder = os.path.split(__file__)[0]
+        file_path = os.path.join(vistoms_folder, 'downloads', file_name)
+        return send_file(file_path, as_attachment=True)
+
+    # Info
+    @app.route('/info')
+    def info():
+        return render_template('info.html', page='info')
+
+    # Acknowledgements
+    @app.route('/acknowledgements')
+    def acknowledgements():
+        return render_template('acknowledgements.html', page='acknowledgements')
+
     @app.route('/kadmos_upload_file', methods=['GET', 'POST'])
     def kadmos_upload_file():
         """
@@ -472,7 +540,21 @@ def interface(debug=True, tempdir=None):
         try:
             # First determine session folder
             session_id = request.form['sessionId']
-            session_folder = retrieve_session_folder(SESSIONS_CATALOG_FOLDER, session_id)
+            try:
+                session_folder = retrieve_session_folder(SESSIONS_CATALOG_FOLDER, session_id, add_usage_stamp=True)
+            except:  # If a session is not found, then create an empty instance on the server.
+                # Get directory with sessions
+                sessions_dir = SESSIONS_CATALOG_FOLDER
+
+                # Add the json file of the session to the sessions directory
+                session_details = dict(folder=os.path.join(SESSIONS_FOLDER_SERVER, session_id),
+                                       creation_date=str(datetime.now()))
+                with open(os.path.join(sessions_dir, session_id + '.json'), 'w') as outfile:
+                    json.dump(session_details, outfile)
+
+                os.makedirs(os.path.join(SESSIONS_FOLDER_SERVER, session_id))
+
+                session_folder = retrieve_session_folder(SESSIONS_CATALOG_FOLDER, session_id, add_usage_stamp=True)
 
             # First of all, delete all graphs, that end with a _backup
             delete_backup_graphs(session_folder)
-- 
GitLab