2017-07-15 10:35:02 -05:00
<!DOCTYPE html>
<!-- [if IE 8]><html class="no - js lt - ie9" lang="en" > <![endif] -->
<!-- [if gt IE 8]><! --> < html class = "no-js" lang = "en" > <!-- <![endif] -->
< head >
< meta charset = "utf-8" >
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
< title > Python Interface for Hurricane / Coriolis — Coriolis 2 documentation< / title >
< link rel = "stylesheet" href = "../_static/SoC.css" type = "text/css" / >
2017-10-30 09:33:37 -05:00
< link rel = "index" title = "Index"
href="../genindex.html"/>
< link rel = "search" title = "Search" href = "../search.html" / >
2017-07-15 10:35:02 -05:00
< link rel = "top" title = "Coriolis 2 documentation" href = "../index.html" / >
< link rel = "up" title = "Coriolis User’ s Guide" href = "index.html" / >
Validating channel routing mode (two metals) on SNX.
* New: In Hurricane::Entity, add an id counter limit and a memory size
limit. The two limits are checked only when a new Entity object is
created. This should help avoiding massive memory links.
* New: In CRL Core, add a "crlcore.groundName" and a "crlcore.powerName"
parameter to specify the name of the ground/power signals to be
created if they are missing in a Cell. For Alliance libraries it
would be "vss" & "vdd" (default values), but for real technologies,
it is often "gnd!" & "vdd!".
The Blif parser is modificated to make use of it.
* Bug: In AnabaticEngine::unify(), set the resulting unified segment in
the center of the GCells common side. Gcells under a segment are
found by using the edge that cover the segment axis. When we have
a "bend" GCell stack and the axis is wrong, they could be ommited.
This was causing deleted segments to be not removed from some
Edges, then core dump.
* Change: In Anabatic::AutoSegment::create(), smarter choosing of the
reference contact, select the fixed or terminal one instead of
always the source one.
* New: In Anabatic::Edge::isEnding(), new function to check if a
segment going through an Edge is starting/ending in either source
or target GCell of the edge (active only when running in channel
mode).
* New: In Anabatic::Edge::add(), a segment takes part in the occupancy
only if it is not ending in either source or target (channel mode
only). The occupancy due to terminal is pre-computed in Katana.
* New: In Anabatic::Edge::ripup(), in channel mode, never ripup a
segment which is ending in either source or target (we *have* to
access this edge to connect to the terminal).
* Bug: In Anabatic::GCell::hcut() and vcut(), force the update of
the Edge which is on the side that will get splitted by the cut.
It's capacity will be reduced to it must be updated.
* Change: In Anabatic::GCell::updateGContacts() add a flag to conditionnally
update horizontals or verticals only. We may require only a partial
update when resizing the GCell in only one direction.
This, again, related to the fact that we compute the GCells under
a segment thanks to it's axis position, so we need to be very careful
when modificating axis.
* Change: In Katana::Block::resizeChannels(), only update GContact vertical
position. Do not disturb X positions of segments.
* Bug: In Katana::GlobalRoute::DigitalDistance, in channel mode, some
Edges can have a zero capacity, but still be reachable if the net has
a terminal in either source or target. Look for this case and return
a distance of zero instead of "unreachable". This was causing the
global routing not to complete in channel mode.
For computing the edge distance, makes the vertical edges much more
long (10 times) than the horizontal ones as the vertical capacity is
very limited. Hard coded for now, should make it a parameter in the
future.
* Change: In KatanaEngine::annotateGlobalGraph(), decrease the capacity
of edges with reserveCapacity for each terminal inside a GCell.
Both north and south edges are decreased as we a terminal will
block both north and south edges.
As a counterpart, the Edge capacity is not decreased when the
global router connect to a terminal.
* Change: In Katana::RoutingEvent::revalidate(), when in repair stage,
do not expand the slack for horizontal segments in channel mode.
So they may not overlap the standard cell row.
* Bug: In Stratus documentation, do not use the french option in babel,
the documentation is in english!
* New: In Documentation, added Hurricane/Python tutorial, part for drawing
layout.
2018-03-16 10:20:04 -05:00
< link rel = "next" title = "Hurricane Python Tutorial" href = "../PythonTutorial/index.html" / >
2017-07-15 10:35:02 -05:00
< link rel = "prev" title = "CGT - The Graphical Interface" href = "ViewerTools.html" / >
< script src = "_static/js/modernizr.min.js" > < / script >
< / head >
< body class = "wy-body-for-nav" role = "document" >
< div class = "wy-grid-for-nav" >
< nav data-toggle = "wy-nav-shift" class = "wy-nav-side" >
< div class = "wy-side-nav-search" >
< a href = "../index.html" class = "icon icon-home" > Coriolis
< / a >
< div role = "search" >
< form id = "rtd-search-form" class = "wy-form" action = "../search.html" method = "get" >
< input type = "text" name = "q" placeholder = "Search docs" / >
< input type = "hidden" name = "check_keywords" value = "yes" / >
< input type = "hidden" name = "area" value = "default" / >
< / form >
< / div >
< / div >
< div class = "wy-menu wy-menu-vertical" data-spy = "affix" role = "navigation" aria-label = "main navigation" >
< ul class = "current" >
< li class = "toctree-l1 current" > < a class = "reference internal" href = "index.html" > Coriolis User’ s Guide< / a > < ul class = "current" >
< li class = "toctree-l2" > < a class = "reference internal" href = "LicenseCredits.html" > Credits & License< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "Releases.html" > Release Notes< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "Releases.html#release-1-0-1475" > Release 1.0.1475< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "Releases.html#release-1-0-1963" > Release 1.0.1963< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "Releases.html#release-1-0-2049" > Release 1.0.2049< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "Releases.html#release-v2-0-1" > Release v2.0.1< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "Releases.html#release-v2-1" > Release v2.1< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "Releases.html#release-v2-2" > < strong > Release v2.2< / strong > < / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "Installation.html" > Installation< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "Installation.html#fixed-directory-tree" > Fixed Directory Tree< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "Installation.html#building-coriolis" > Building Coriolis< / a > < ul >
< li class = "toctree-l4" > < a class = "reference internal" href = "Installation.html#building-the-devel-branch" > Building the Devel Branch< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "Installation.html#additionnal-requirement-under-macos" > Additionnal Requirement under < span class = "sc" > MacOS< / span > < / a > < / li >
< / ul >
< / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "Installation.html#packaging-coriolis" > Packaging Coriolis< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "Installation.html#hooking-up-into-alliance" > Hooking up into < span class = "sc" > Alliance< / span > < / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "Installation.html#setting-up-the-environment-coriolisenv-py" > Setting up the Environment (coriolisEnv.py)< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "Configuration.html" > Coriolis Configuration & Initialisation< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "Configuration.html#general-software-architecture" > General Software Architecture< / a > < / li >
2017-11-17 05:04:33 -06:00
< li class = "toctree-l3" > < a class = "reference internal" href = "Configuration.html#first-stage-technology-selection" > First Stage: Technology Selection< / a > < / li >
2017-07-15 10:35:02 -05:00
< li class = "toctree-l3" > < a class = "reference internal" href = "Configuration.html#second-stage-technology-configuration-loading" > Second Stage: Technology Configuration Loading< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "Configuration.html#configuration-helpers" > Configuration Helpers< / a > < ul >
< li class = "toctree-l4" > < a class = "reference internal" href = "Configuration.html#alliance-helper" > < span class = "sc" > Alliance< / span > Helper< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "Configuration.html#tools-configuration-helpers" > Tools Configuration Helpers< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "Configuration.html#hacking-the-configuration-files" > Hacking the Configuration Files< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "ViewerTools.html" > CGT - The Graphical Interface< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "ViewerTools.html#viewer-tools" > Viewer & Tools< / a > < ul >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#stratus-netlist-capture" > < span class = "sc" > Stratus< / span > Netlist Capture< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#the-hurricane-data-base" > The < span class = "sc" > Hurricane< / span > Data-Base< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#synthetizing-and-loading-a-design" > Synthetizing and loading a design< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#etesian-placer" > Etesian – Placer< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#knik-global-router" > Knik – Global Router< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#kite-detailed-router" > Kite – Detailed Router< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#executing-python-scripts-in-cgt" > Executing Python Scripts in Cgt< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#printing-snapshots" > Printing & Snapshots< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#memento-of-shortcuts-in-graphic-mode" > Memento of Shortcuts in Graphic Mode< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#cgt-command-line-options" > Cgt Command Line Options< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#miscellaneous-settings" > Miscellaneous Settings< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "ViewerTools.html#the-controller" > The Controller< / a > < ul >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#the-look-tab" > The Look Tab< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#the-filter-tab" > The Filter Tab< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#the-layers-go-tab" > The Layers& Go Tab< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#the-netlist-tab" > The Netlist Tab< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#the-selection-tab" > The Selection Tab< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#the-inspector-tab" > The Inspector Tab< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "ViewerTools.html#the-settings-tab" > The Settings Tab< / a > < / li >
< / ul >
< / li >
< / ul >
< / li >
2017-10-30 09:33:37 -05:00
< li class = "toctree-l2 current" > < a class = "current reference internal" href = "#" > Python Interface for < span class = "sc" > Hurricane< / span > / < span class = "sc" > Coriolis< / span > < / a > < ul >
2017-07-15 10:35:02 -05:00
< li class = "toctree-l3" > < a class = "reference internal" href = "#plugins" > Plugins< / a > < ul >
< li class = "toctree-l4" > < a class = "reference internal" href = "#chip-placement" > Chip Placement< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "#clock-tree" > Clock Tree< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "#recursive-save-rsave" > Recursive-Save (RSave)< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "#a-simple-example-am2901" > A Simple Example: AM2901< / a > < / li >
< / ul >
< / li >
< / ul >
< / li >
Validating channel routing mode (two metals) on SNX.
* New: In Hurricane::Entity, add an id counter limit and a memory size
limit. The two limits are checked only when a new Entity object is
created. This should help avoiding massive memory links.
* New: In CRL Core, add a "crlcore.groundName" and a "crlcore.powerName"
parameter to specify the name of the ground/power signals to be
created if they are missing in a Cell. For Alliance libraries it
would be "vss" & "vdd" (default values), but for real technologies,
it is often "gnd!" & "vdd!".
The Blif parser is modificated to make use of it.
* Bug: In AnabaticEngine::unify(), set the resulting unified segment in
the center of the GCells common side. Gcells under a segment are
found by using the edge that cover the segment axis. When we have
a "bend" GCell stack and the axis is wrong, they could be ommited.
This was causing deleted segments to be not removed from some
Edges, then core dump.
* Change: In Anabatic::AutoSegment::create(), smarter choosing of the
reference contact, select the fixed or terminal one instead of
always the source one.
* New: In Anabatic::Edge::isEnding(), new function to check if a
segment going through an Edge is starting/ending in either source
or target GCell of the edge (active only when running in channel
mode).
* New: In Anabatic::Edge::add(), a segment takes part in the occupancy
only if it is not ending in either source or target (channel mode
only). The occupancy due to terminal is pre-computed in Katana.
* New: In Anabatic::Edge::ripup(), in channel mode, never ripup a
segment which is ending in either source or target (we *have* to
access this edge to connect to the terminal).
* Bug: In Anabatic::GCell::hcut() and vcut(), force the update of
the Edge which is on the side that will get splitted by the cut.
It's capacity will be reduced to it must be updated.
* Change: In Anabatic::GCell::updateGContacts() add a flag to conditionnally
update horizontals or verticals only. We may require only a partial
update when resizing the GCell in only one direction.
This, again, related to the fact that we compute the GCells under
a segment thanks to it's axis position, so we need to be very careful
when modificating axis.
* Change: In Katana::Block::resizeChannels(), only update GContact vertical
position. Do not disturb X positions of segments.
* Bug: In Katana::GlobalRoute::DigitalDistance, in channel mode, some
Edges can have a zero capacity, but still be reachable if the net has
a terminal in either source or target. Look for this case and return
a distance of zero instead of "unreachable". This was causing the
global routing not to complete in channel mode.
For computing the edge distance, makes the vertical edges much more
long (10 times) than the horizontal ones as the vertical capacity is
very limited. Hard coded for now, should make it a parameter in the
future.
* Change: In KatanaEngine::annotateGlobalGraph(), decrease the capacity
of edges with reserveCapacity for each terminal inside a GCell.
Both north and south edges are decreased as we a terminal will
block both north and south edges.
As a counterpart, the Edge capacity is not decreased when the
global router connect to a terminal.
* Change: In Katana::RoutingEvent::revalidate(), when in repair stage,
do not expand the slack for horizontal segments in channel mode.
So they may not overlap the standard cell row.
* Bug: In Stratus documentation, do not use the french option in babel,
the documentation is in english!
* New: In Documentation, added Hurricane/Python tutorial, part for drawing
layout.
2018-03-16 10:20:04 -05:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../PythonTutorial/index.html" > Hurricane Python Tutorial< / a > < ul >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonTutorial/Introduction.html" > 1. Introduction< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/Introduction.html#generalities" > 1.1 Generalities< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/Introduction.html#various-kinds-of-constructors" > 1.2 Various Kinds of Constructors< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonTutorial/Environment.html" > 2. Setting up the Environment< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/Environment.html#setting-up-the-pathes" > 2.1 Setting up the Pathes< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/Environment.html#user-s-configurations-file" > 2.2 User’ s Configurations File< / a > < ul >
< li class = "toctree-l4" > < a class = "reference internal" href = "../PythonTutorial/Environment.html#the-techno-py-file" > 2.2.1 The < span class = "cb" > techno.py< / span > File< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "../PythonTutorial/Environment.html#the-settings-py-file" > 2.2.2 The < span class = "cb" > settings.py< / span > File< / a > < / li >
< / ul >
< / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonTutorial/CellNetComponent.html" > 3. Creating Cell, Net and Component< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/CellNetComponent.html#the-allianceframework-crl-core" > 3.1 The AllianceFramework (CRL Core)< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/CellNetComponent.html#session-mechanism-hurricane" > 3.2 Session Mechanism (Hurricane)< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/CellNetComponent.html#creating-a-new-cell-crl-core" > 3.3 Creating a new Cell (CRL Core)< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/CellNetComponent.html#the-dbu-measurement-unit" > 3.4 The DbU Measurement Unit< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/CellNetComponent.html#setting-up-the-abutment-box" > 3.5 Setting up the Abutment Box< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/CellNetComponent.html#adding-nets-and-components" > 3.6 Adding Nets and Components< / a > < ul >
< li class = "toctree-l4" > < a class = "reference internal" href = "../PythonTutorial/CellNetComponent.html#getting-a-layer" > 3.6.1 Getting a Layer< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "../PythonTutorial/CellNetComponent.html#creating-a-net" > 3.6.2 Creating a Net< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "../PythonTutorial/CellNetComponent.html#creating-a-component" > 3.6.3 Creating a Component< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/CellNetComponent.html#saving-to-disk-crl-core" > 3.7 Saving to Disk (CRL Core)< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonTutorial/Collections.html" > 4. Manipulating Cells, Nets and Components< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/Collections.html#hurricane-collections" > 4.1 Hurricane Collections< / a > < ul >
< li class = "toctree-l4" > < a class = "reference internal" href = "../PythonTutorial/Collections.html#restrictions-about-using-collections" > 4.1.1 Restrictions about using Collections< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/Collections.html#loading-a-cell-with-allianceframework" > 4.2 Loading a Cell with AllianceFramework< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonTutorial/CgtScript.html" > 5. Make a script runnable through < span class = "cb" > cgt< / span > < / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonTutorial/CgtScript.html#using-breakpoints" > 5.1 Using Breakpoints< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonTutorial/CgtScript.html#the-complete-example-file" > 6. The Complete Example File< / a > < / li >
< / ul >
< / li >
2017-07-15 10:35:02 -05:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../Stratus/Stratus.html" > Stratus Reference< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../DpGen/DpGen.html" > DpGen Reference< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../Patterns/Patterns.html" > Patterns Reference< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../Hurricane/Hurricane.html" > Hurricane Reference< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../Viewer/Viewer.html" > Viewer Reference< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../CrlCore/CrlCore.html" > CRL Core Reference< / a > < / li >
2017-07-17 12:12:18 -05:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../Katabatic/Katabatic.html" > Katabatic Reference< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../Kite/Kite.html" > Kite Reference< / a > < / li >
2017-07-15 10:35:02 -05:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../Unicorn/Unicorn.html" > Unicorn Reference< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../PythonCpp/index.html" > Hurricane Python/C++ API Tutorial< / a > < ul >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonCpp/Introduction.html" > 1. Introduction< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/Introduction.html#first-a-disclaimer" > 1.1 First, A Disclaimer< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/Introduction.html#about-technical-choices" > 1.2 About Technical Choices< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/Introduction.html#botched-design" > 1.3 Botched Design< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonCpp/Configuration.html" > 2. Basic File Structure and CMake configuration< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonCpp/DBoStandalone.html" > 3. Case 1 - DBo Derived, Standalone< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/DBoStandalone.html#class-associated-header-file" > 3.1 Class Associated Header File< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/DBoStandalone.html#class-associated-file" > 3.2 Class Associated File< / a > < ul >
< li class = "toctree-l4" > < a class = "reference internal" href = "../PythonCpp/DBoStandalone.html#head-of-the-file" > 3.2.1 Head of the file< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "../PythonCpp/DBoStandalone.html#the-python-module-part" > 3.2.2 The Python Module Part< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "../PythonCpp/DBoStandalone.html#python-type-linking" > 3.2.3 Python Type Linking< / a > < / li >
< li class = "toctree-l4" > < a class = "reference internal" href = "../PythonCpp/DBoStandalone.html#the-shared-library-part" > 3.2.4 The Shared Library Part< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/DBoStandalone.html#python-module-c-namespace" > 3.3 Python Module (C++ namespace)< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonCpp/DBoHierarchy.html" > 4. Case 2 - Hierarchy of DBo Derived Classes< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/DBoHierarchy.html#base-class-header" > 4.1 Base Class Header< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/DBoHierarchy.html#base-class-file" > 4.2 Base Class File< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/DBoHierarchy.html#intermediate-class-header" > 4.3 Intermediate Class Header< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/DBoHierarchy.html#intermediate-class-file" > 4.4 Intermediate Class File< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/DBoHierarchy.html#terminal-class-header" > 4.5 Terminal Class Header< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/DBoHierarchy.html#terminal-class-file" > 4.6 Terminal Class File< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/DBoHierarchy.html#python-module" > 4.8 Python Module< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonCpp/NonDBo.html" > 5. Case 3 - Non-DBo Standalone Classe< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/NonDBo.html#class-header" > 5.1 Class Header< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/NonDBo.html#class-file" > 5.2 Class File< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../PythonCpp/NonDBo.html#id1" > 5.2 Class File< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonCpp/DbU.html" > 6. Encapsulating DbU< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../PythonCpp/Name.html" > 7. No C++ Hurricane::Name encapsulation< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../RDS/index.html" > Symbolic to Real Conversion in Alliance< / a > < ul >
< li class = "toctree-l2" > < a class = "reference internal" href = "../RDS/RDSpage.html" > Symbolic Layout< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../RDS/RDSpage.html#symbolic-components" > Symbolic Components< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../RDS/RDSpage.html#symbolic-segments" > Symbolic Segments< / a > < / li >
< / ul >
< / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "../RDS/RDSpage.html#the-rds-file" > The RDS File< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../RDS/RDSpage.html#physical-grid-lambda-value" > Physical Grid & Lambda Value< / a > < / li >
2017-10-30 09:33:37 -05:00
< li class = "toctree-l3" > < a class = "reference internal" href = "../RDS/RDSpage.html#the-mbk-to-rds-segment-table" > The < code class = "docutils literal" > < span class = "pre" > MBK_TO_RDS_SEGMENT< / span > < / code > table< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../RDS/RDSpage.html#the-mbk-to-rds-via-table" > The < code class = "docutils literal" > < span class = "pre" > MBK_TO_RDS_VIA< / span > < / code > table< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../RDS/RDSpage.html#the-mbk-to-rds-bigvia-hole-table" > The < code class = "docutils literal" > < span class = "pre" > MBK_TO_RDS_BIGVIA_HOLE< / span > < / code > table< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../RDS/RDSpage.html#the-mbk-to-rds-bigvia-metal-table" > The < code class = "docutils literal" > < span class = "pre" > MBK_TO_RDS_BIGVIA_METAL< / span > < / code > table< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../RDS/RDSpage.html#the-mbk-wiresetting-table" > The < code class = "docutils literal" > < span class = "pre" > MBK_WIRESETTING< / span > < / code > table< / a > < / li >
2017-07-15 10:35:02 -05:00
< / ul >
< / li >
< / ul >
< / li >
2017-11-17 05:04:33 -06:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../lefapi/lefapi.html" > LEF API Reference< / a > < ul >
< li class = "toctree-l2" > < a class = "reference internal" href = "../lefapi/lefapi.html#implementation-notes" > Implementation Notes< / a > < ul >
< li class = "toctree-l3" > < a class = "reference internal" href = "../lefapi/lefapi.html#understanding-units" > Understanding Units< / a > < / li >
< li class = "toctree-l3" > < a class = "reference internal" href = "../lefapi/lefapi.html#callback-calling-order" > Callback Calling Order< / a > < / li >
< / ul >
< / li >
< / ul >
< / li >
2017-10-30 09:33:37 -05:00
< li class = "toctree-l1" > < a class = "reference internal" href = "../defapi/defapi.html" > DEF API Reference< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../lefdef/lefdef.html" > LEF/DEF Language Reference< / a > < / li >
2017-07-15 10:35:02 -05:00
< / ul >
< / div >
< / nav >
< section data-toggle = "wy-nav-shift" class = "wy-nav-content-wrap" >
< nav class = "wy-nav-top" role = "navigation" aria-label = "top navigation" >
< i data-toggle = "wy-nav-top" class = "fa fa-bars" > < / i >
< a href = "../index.html" > Coriolis< / a >
< / nav >
< div class = "wy-nav-content" >
< div class = "rst-content" >
< div role = "navigation" aria-label = "breadcrumbs navigation" >
< ul class = "wy-breadcrumbs" >
< li > < a href = "../index.html" > Docs< / a > » < / li >
< li > < a href = "index.html" > Coriolis User’ s Guide< / a > » < / li >
< li > Python Interface for < span class = "sc" > Hurricane< / span > / < span class = "sc" > Coriolis< / span > < / li >
< li class = "wy-breadcrumbs-aside" >
< / li >
< / ul >
< hr / >
< / div >
< div role = "main" class = "document" >
< div class = "section" id = "python-interface-for-hurricane-coriolis" >
< span id = "python-interface-to-coriolis" > < / span > < h1 > Python Interface for < span class = "sc" > Hurricane< / span > / < span class = "sc" > Coriolis< / span > < a class = "headerlink" href = "#python-interface-for-hurricane-coriolis" title = "Permalink to this headline" > ¶< / a > < / h1 >
< p > The (almost) complete interface of < span class = "sc" > Hurricane< / span > is exported as a < span class = "sc" > Python< / span > module
and some part of the other components of < span class = "sc" > Coriolis< / span > (each one in a separate
module). The interface has been made to mirror as closely as possible the
C++ one, so the C++ doxygen documentation could be used to write code with
either languages.< / p >
< p > < a class = "reference external" href = "file:../../../index.html" > Summary of the C++ Documentation< / a > < / p >
< p > A script could be run directly in text mode from the command line or through
2017-10-30 09:33:37 -05:00
the graphical interface (see < a class = "reference internal" href = "ViewerTools.html#python-scripts-in-cgt" > < span class = "std std-ref" > Executing Python Scripts in Cgt< / span > < / a > ).< / p >
2017-07-15 10:35:02 -05:00
< p > Asides for this requirement, the python script can contain anything valid
in < span class = "sc" > Python< / span > , so don’ t hesitate to use any package or extention.< / p >
< p > Small example of Python/Stratus script:< / p >
2017-10-30 09:33:37 -05:00
< div class = "highlight-default" > < div class = "highlight" > < pre > < span > < / span > < span class = "kn" > from< / span > < span class = "nn" > Hurricane< / span > < span class = "k" > import< / span > < span class = "o" > *< / span >
< span class = "kn" > from< / span > < span class = "nn" > Stratus< / span > < span class = "k" > import< / span > < span class = "o" > *< / span >
< span class = "k" > def< / span > < span class = "nf" > doSomething< / span > < span class = "p" > ():< / span >
< span class = "c1" > # ...< / span >
< span class = "k" > return< / span >
< span class = "k" > def< / span > < span class = "nf" > ScriptMain< / span > < span class = "p" > (< / span > < span class = "o" > **< / span > < span class = "n" > kw< / span > < span class = "p" > ):< / span >
< span class = "n" > editor< / span > < span class = "o" > =< / span > < span class = "kc" > None< / span >
< span class = "k" > if< / span > < span class = "n" > kw< / span > < span class = "o" > .< / span > < span class = "n" > has_key< / span > < span class = "p" > (< / span > < span class = "s1" > ' editor' < / span > < span class = "p" > )< / span > < span class = "ow" > and< / span > < span class = "n" > kw< / span > < span class = "p" > [< / span > < span class = "s1" > ' editor' < / span > < span class = "p" > ]:< / span >
< span class = "n" > editor< / span > < span class = "o" > =< / span > < span class = "n" > kw< / span > < span class = "p" > [< / span > < span class = "s1" > ' editor' < / span > < span class = "p" > ]< / span >
< span class = "n" > stratus< / span > < span class = "o" > .< / span > < span class = "n" > setEditor< / span > < span class = "p" > (< / span > < span class = "n" > editor< / span > < span class = "p" > )< / span >
< span class = "n" > doSomething< / span > < span class = "p" > ()< / span >
< span class = "k" > return< / span >
< span class = "k" > if< / span > < span class = "n" > __name__< / span > < span class = "o" > ==< / span > < span class = "s2" > " __main__" < / span > < span class = "p" > :< / span >
< span class = "n" > kw< / span > < span class = "o" > =< / span > < span class = "p" > {}< / span >
< span class = "n" > success< / span > < span class = "o" > =< / span > < span class = "n" > ScriptMain< / span > < span class = "p" > (< / span > < span class = "o" > **< / span > < span class = "n" > kw< / span > < span class = "p" > )< / span >
< span class = "n" > shellSuccess< / span > < span class = "o" > =< / span > < span class = "mi" > 0< / span >
< span class = "k" > if< / span > < span class = "ow" > not< / span > < span class = "n" > success< / span > < span class = "p" > :< / span > < span class = "n" > shellSuccess< / span > < span class = "o" > =< / span > < span class = "mi" > 1< / span >
< span class = "n" > sys< / span > < span class = "o" > .< / span > < span class = "n" > exit< / span > < span class = "p" > (< / span > < span class = "n" > shellSuccess< / span > < span class = "p" > )< / span >
< span class = "n" > ScriptMain< / span > < span class = "p" > ()< / span >
< / pre > < / div >
2017-07-15 10:35:02 -05:00
< / div >
< p > This typical script can be executed in two ways:< / p >
< ol class = "arabic" >
< li > < p class = "first" > Run directly as a < span class = "sc" > Python< / span > script, thanks to the< / p >
2017-10-30 09:33:37 -05:00
< div class = "highlight-default" > < div class = "highlight" > < pre > < span > < / span > < span class = "k" > if< / span > < span class = "n" > __name__< / span > < span class = "o" > ==< / span > < span class = "s2" > " __main__" < / span > < span class = "p" > :< / span >
< / pre > < / div >
2017-07-15 10:35:02 -05:00
< / div >
< p > part (this is standart < span class = "sc" > Python< / span > ). It is a simple adapter that will
calls < span class = "cb" > ScriptMain()< / span > .< / p >
< / li >
< li > < p class = "first" > Through < span class = "cb" > cgt< / span > , either in text or graphical mode. In that case, the
< span class = "cb" > ScriptMain()< / span > is directly called trough a sub-interpreter.
2017-10-30 09:33:37 -05:00
The arguments of the script are passed through the < code class = "docutils literal" > < span class = "pre" > **kw< / span > < / code > dictionnary.< / p >
2017-07-15 10:35:02 -05:00
< table border = "1" class = "docutils" >
< colgroup >
< col width = "32%" / >
< col width = "68%" / >
< / colgroup >
< thead valign = "bottom" >
< tr class = "row-odd" > < th class = "head" colspan = "2" > **kw Dictionnary< / th >
< / tr >
< tr class = "row-even" > < th class = "head" > Parameter Key/Name< / th >
< th class = "head" > Contents type< / th >
< / tr >
< / thead >
< tbody valign = "top" >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td > < code class = "docutils literal" > < span class = "pre" > 'cell'< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > A Hurricane cell on which to work. Depending
2017-10-30 09:33:37 -05:00
on the context, it may be < code class = "docutils literal" > < span class = "pre" > None< / span > < / code > .
2017-07-15 10:35:02 -05:00
For example, when run from < span class = "cb" > cgt< / span > , it the cell
currently loaded in the viewer, if any.< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-even" > < td > < code class = "docutils literal" > < span class = "pre" > 'editor'< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > The viewer from which the script is run, when
lauched through < span class = "cb" > cgt< / span > .< / td >
< / tr >
< / tbody >
< / table >
< / li >
< / ol >
< div class = "section" id = "plugins" >
< h2 > Plugins< a class = "headerlink" href = "#plugins" title = "Permalink to this headline" > ¶< / a > < / h2 >
< p > Plugins are < span class = "sc" > Python< / span > scripts specially crafted to integrate with < span class = "cb" > cgt< / span > .
Their entry point is a < span class = "cb" > ScriptMain()< / span > method as described in
< a class = "reference internal" href = "#python-interface-to-coriolis" > Python Interface to Coriolis< / a > . They can be called by user scripts
through this method.< / p >
< div class = "section" id = "chip-placement" >
< h3 > Chip Placement< a class = "headerlink" href = "#chip-placement" title = "Permalink to this headline" > ¶< / a > < / h3 >
< p > Automatically perform the placement of a complete chip. This plugin, as well
as the other P& R tools expect a specific top-level hierarchy for the design.
The top-level hierarchy must contains the instances of all the I/O pads and
< strong > exactly one< / strong > instance of the chip’ s core model.< / p >
2017-10-30 09:33:37 -05:00
< p > < a class = "reference internal" href = "../_images/chip-structure-1.png" > < img alt = "Chip Top Structure" class = "align-middle" src = "../_images/chip-structure-1.png" style = "width: 90%;" / > < / a > < / p >
2017-07-15 10:35:02 -05:00
< p > The designer must provide a configuration file that define the rules for the
placement of the top-level hierarchy (that is, the pads and the core).
2017-10-30 09:33:37 -05:00
This file must be named after the chip’ s name, by appending < code class = "docutils literal" > < span class = "pre" > _chip.py< / span > < / code >
2017-07-15 10:35:02 -05:00
(obviously, it is a < span class = "sc" > Python< / span > file). For instance if the chip netlist file
2017-10-30 09:33:37 -05:00
is called < code class = "docutils literal" > < span class = "pre" > amd2901_crl.vst< / span > < / code > , then the configuration file must be named
< code class = "docutils literal" > < span class = "pre" > amd2901_crl_chip.vst< / span > < / code > .< / p >
< p > Example of chip placement configuration file (for < code class = "docutils literal" > < span class = "pre" > AM2901< / span > < / code > ):< / p >
< div class = "highlight-default" > < div class = "highlight" > < pre > < span > < / span > < span class = "n" > chip< / span > < span class = "o" > =< / span > \
< span class = "p" > {< / span > < span class = "s1" > ' pads.south' < / span > < span class = "p" > :< / span > < span class = "p" > [< / span > < span class = "s1" > ' p_a3' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_a2' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_a1' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_r0' < / span >
< span class = "p" > ,< / span > < span class = "s1" > ' p_vddick0' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_vssick0' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_a0' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_i6' < / span >
< span class = "p" > ,< / span > < span class = "s1" > ' p_i8' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_i7' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_r3' < / span > < span class = "p" > ]< / span >
< span class = "p" > ,< / span > < span class = "s1" > ' pads.east' < / span > < span class = "p" > :< / span > < span class = "p" > [< / span > < span class = "s1" > ' p_zero' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_i0' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_i1' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_i2' < / span >
< span class = "p" > ,< / span > < span class = "s1" > ' p_vddeck0' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_vsseck0' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_q3' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_b0' < / span >
< span class = "p" > ,< / span > < span class = "s1" > ' p_b1' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_b2' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_b3' < / span > < span class = "p" > ]< / span >
< span class = "p" > ,< / span > < span class = "s1" > ' pads.north' < / span > < span class = "p" > :< / span > < span class = "p" > [< / span > < span class = "s1" > ' p_noe' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_y3' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_y2' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_y1' < / span >
< span class = "p" > ,< / span > < span class = "s1" > ' p_y0' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_vddeck1' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_vsseck1' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_np' < / span >
< span class = "p" > ,< / span > < span class = "s1" > ' p_ovr' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_cout' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_ng' < / span > < span class = "p" > ]< / span >
< span class = "p" > ,< / span > < span class = "s1" > ' pads.west' < / span > < span class = "p" > :< / span > < span class = "p" > [< / span > < span class = "s1" > ' p_cin' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_i4' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_i5' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_i3' < / span >
< span class = "p" > ,< / span > < span class = "s1" > ' p_ck' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_d0' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_d1' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_d2' < / span >
< span class = "p" > ,< / span > < span class = "s1" > ' p_d3' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_q0' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' p_f3' < / span > < span class = "p" > ]< / span >
< span class = "p" > ,< / span > < span class = "s1" > ' core.size' < / span > < span class = "p" > :< / span > < span class = "p" > (< / span > < span class = "mi" > 1500< / span > < span class = "p" > ,< / span > < span class = "mi" > 1500< / span > < span class = "p" > )< / span >
< span class = "p" > ,< / span > < span class = "s1" > ' chip.size' < / span > < span class = "p" > :< / span > < span class = "p" > (< / span > < span class = "mi" > 3000< / span > < span class = "p" > ,< / span > < span class = "mi" > 3000< / span > < span class = "p" > )< / span >
< span class = "p" > ,< / span > < span class = "s1" > ' chip.clockTree' < / span > < span class = "p" > :< / span > < span class = "kc" > True< / span >
2017-07-15 10:35:02 -05:00
< span class = "p" > }< / span >
< / pre > < / div >
< / div >
2017-10-30 09:33:37 -05:00
< p > The file must contain < em > one dictionnary< / em > named < code class = "docutils literal" > < span class = "pre" > chip< / span > < / code > .< / p >
2017-07-15 10:35:02 -05:00
< table border = "1" class = "docutils" >
< colgroup >
< col width = "29%" / >
< col width = "71%" / >
< / colgroup >
< thead valign = "bottom" >
< tr class = "row-odd" > < th class = "head" colspan = "2" > Chip Dictionnary< / th >
< / tr >
< tr class = "row-even" > < th class = "head" > Parameter Key/Name< / th >
< th class = "head" > Value/Contents type< / th >
< / tr >
< / thead >
< tbody valign = "top" >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td > < code class = "docutils literal" > < span class = "pre" > 'pad.south'< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > Ordered list (left to right) of pad instances names
to put on the south side of the chip< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-even" > < td > < code class = "docutils literal" > < span class = "pre" > 'pad.east'< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > Ordered list (down to up) of pad instances names
to put on the east side of the chip< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td > < code class = "docutils literal" > < span class = "pre" > 'pad.north'< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > Ordered list (left to right) of pad instances names
to put on the north side of the chip< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-even" > < td > < code class = "docutils literal" > < span class = "pre" > 'pad.west'< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > Ordered list (down to up) of pad instances names
to put on the west side of the chip< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td > < code class = "docutils literal" > < span class = "pre" > 'core.size'< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > The size of the core (to be used by the placer)< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-even" > < td > < code class = "docutils literal" > < span class = "pre" > 'chip.size'< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > The size of the whole chip. The sides must be great
enough to accomodate all the pads< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td > < code class = "docutils literal" > < span class = "pre" > 'chip.clockTree'< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > Whether to generate a clock tree or not. This calls
the ClockTree plugin< / td >
< / tr >
< / tbody >
< / table >
2017-10-30 09:33:37 -05:00
< p > Configuration parameters, defaults are defined in < code class = "docutils literal" > < span class = "pre" > etc/coriolis2/< STECHNO> /plugins.conf< / span > < / code > .< / p >
2017-07-15 10:35:02 -05:00
< table border = "1" class = "docutils" >
< colgroup >
< col width = "43%" / >
< col width = "22%" / >
< col width = "35%" / >
< / colgroup >
< thead valign = "bottom" >
< tr class = "row-odd" > < th class = "head" > Parameter Identifier< / th >
< th class = "head" > Type< / th >
< th class = "head" > Default< / th >
< / tr >
< / thead >
< tbody valign = "top" >
< tr class = "row-even" > < td colspan = "3" > < strong > Chip Plugin Parameters< / strong > < / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > chip.block.rails.count< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeInt< / td >
< td > < span class = "cb" > 5< / span > < / td >
< / tr >
< tr class = "row-even" > < td colspan = "2" > The minimum number of rails around the core
block. Must be odd and suppérior to 5.
One rail for the clock and at least two pairs
of power/grounds< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > chip.block.rails.hWidth< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeInt< / td >
< td > < span class = "cb" > 12< / span > < / td >
< / tr >
< tr class = "row-even" > < td colspan = "2" > The horizontal with of the rails< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > chip.block.rails.vWidth< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeInt< / td >
< td > < span class = "cb" > 12< / span > < / td >
< / tr >
< tr class = "row-even" > < td colspan = "2" > The vertical with of the rails< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > chip.block.rails.hSpacing< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeInt< / td >
< td > < span class = "cb" > 6< / span > < / td >
< / tr >
< tr class = "row-even" > < td colspan = "2" > The spacing, < em > edge to edge< / em > of two adjacent
horizontal rails< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > chip.block.rails.vSpacing< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeInt< / td >
< td > < span class = "cb" > 6< / span > < / td >
< / tr >
< tr class = "row-even" > < td colspan = "2" > The spacing, < em > edge to edge< / em > of two adjacent
vertical rails< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > chip.pad.pck< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeString< / td >
< td > < span class = "cb" > pck_px< / span > < / td >
< / tr >
< tr class = "row-even" > < td colspan = "2" > The model name of the pad connected to the
chip external clock< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > chip.pad.pvddeck< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeString< / td >
< td > < span class = "cb" > pvddeck_px< / span > < / td >
< / tr >
< tr class = "row-even" > < td colspan = "2" > The model name of the pad connected to the
2017-10-30 09:33:37 -05:00
< code class = "docutils literal" > < span class = "pre" > vdde< / span > < / code > (external power) and suppling it to
2017-07-15 10:35:02 -05:00
the core< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > chip.pad.pvsseck< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeString< / td >
< td > < span class = "cb" > pvsseck_px< / span > < / td >
< / tr >
< tr class = "row-even" > < td colspan = "2" > The model name of the pad connected to the
2017-10-30 09:33:37 -05:00
< code class = "docutils literal" > < span class = "pre" > vsse< / span > < / code > (external ground) and suppling it to
2017-07-15 10:35:02 -05:00
the core< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > chip.pad.pvddick< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeString< / td >
< td > < span class = "cb" > pvddick_px< / span > < / td >
< / tr >
< tr class = "row-even" > < td colspan = "2" > The model name of the pad connected to the
2017-10-30 09:33:37 -05:00
< code class = "docutils literal" > < span class = "pre" > vddi< / span > < / code > (internal power) and suppling it to
2017-07-15 10:35:02 -05:00
the core< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > chip.pad.pvssick< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeString< / td >
< td > < span class = "cb" > pvssick_px< / span > < / td >
< / tr >
< tr class = "row-even" > < td colspan = "2" > The model name of the pad connected to the
2017-10-30 09:33:37 -05:00
< code class = "docutils literal" > < span class = "pre" > vssi< / span > < / code > (internal ground) and suppling it to
2017-07-15 10:35:02 -05:00
the core< / td >
< / tr >
< / tbody >
< / table >
< div class = "admonition note" >
< p class = "first admonition-title" > Note< / p >
< p class = "last" > If no clock tree is generated, then the clock rail is < em > not< / em > created.
2017-10-30 09:33:37 -05:00
So even if the requested number of rails < code class = "docutils literal" > < span class = "pre" > chip.block.rails.count< / span > < / code > is, say 5,
only four rails (2* < code class = "docutils literal" > < span class = "pre" > power< / span > < / code > , 2* < code class = "docutils literal" > < span class = "pre" > ground< / span > < / code > ) will be generateds.< / p >
2017-07-15 10:35:02 -05:00
< / div >
< / div >
< div class = "section" id = "clock-tree" >
< h3 > Clock Tree< a class = "headerlink" href = "#clock-tree" title = "Permalink to this headline" > ¶< / a > < / h3 >
< p > Insert a clock tree into a block. The clock tree uses the H strategy.
The clock net is splitted into sub-nets, one for each branch of the
tree.< / p >
< ul >
< li > < p class = "first" > On < strong > chips< / strong > design, the sub-nets are createds in the model of the
core block (then trans-hierarchically flattened to be shown at
chip level).< / p >
< / li >
< li > < p class = "first" > On < strong > blocks< / strong > , the sub nets are created directly in the top block.< / p >
< / li >
< li > < p class = "first" > The sub-nets are named according to a simple geometrical scheme.
2017-10-30 09:33:37 -05:00
A common prefix < code class = "docutils literal" > < span class = "pre" > ck_htree< / span > < / code > , then one postfix by level telling
2017-07-15 10:35:02 -05:00
on which quarter of plane the sub-clock is located:< / p >
< ol class = "arabic simple" >
2017-10-30 09:33:37 -05:00
< li > < code class = "docutils literal" > < span class = "pre" > _bl< / span > < / code > : bottom left plane quarter.< / li >
< li > < code class = "docutils literal" > < span class = "pre" > _br< / span > < / code > : bottom right plane quarter.< / li >
< li > < code class = "docutils literal" > < span class = "pre" > _tl< / span > < / code > : top left plane quarter.< / li >
< li > < code class = "docutils literal" > < span class = "pre" > _tr< / span > < / code > : top right plane quarter.< / li >
2017-07-15 10:35:02 -05:00
< / ol >
2017-10-30 09:33:37 -05:00
< p > We can have < code class = "docutils literal" > < span class = "pre" > ck_htree_bl< / span > < / code > , < code class = "docutils literal" > < span class = "pre" > ck_htree_bl_bl< / span > < / code > , < code class = "docutils literal" > < span class = "pre" > ch_htree_bl_tl< / span > < / code > and so on.< / p >
2017-07-15 10:35:02 -05:00
< / li >
< / ul >
< p > The clock tree plugin works in four steps:< / p >
< ol class = "arabic simple" >
< li > Build the clock tree: creates the top-block abutment box, compute the
levels of H tree neededs and place the clock buffers.< / li >
< li > Once the clock buffers are placed, calls the placer (< span class = "sc" > Etesian< / span > ) to place
the ordinary standart cells, whithout disturbing clock H-tree buffers.< / li >
< li > At this point we know the exact positions of all the DFFs, so we can
connect them to the nearest H-tree leaf clock signal.< / li >
< li > Leaf clock signals that are not connecteds to any DFFs are removed.< / li >
< / ol >
< p > Netlist reorganisation:< / p >
< ul class = "simple" >
< li > Obviously the top block or chip core model netlist is modificated to
contains all the clock sub-nets. The interface is < em > not< / em > changed.< / li >
< li > If the top block contains instances of other models < em > and< / em > those models
contains DFFs that get re-connecteds to the clock sub-nets (from the
top level). Change both the model netlist and interface to propagate
the relevant clock sub-nets to the instanciated model. The new model
2017-10-30 09:33:37 -05:00
with the added clock signal is renamed with a < code class = "docutils literal" > < span class = "pre" > _clocked< / span > < / code > suffix.
For example, the sub-block model < code class = "docutils literal" > < span class = "pre" > ram.vst< / span > < / code > will become < code class = "docutils literal" > < span class = "pre" > ram_clocked.vst< / span > < / code > .< / li >
2017-07-15 10:35:02 -05:00
< / ul >
< div class = "admonition note" >
< p class = "first admonition-title" > Note< / p >
< p class = "last" > If you are to re-run the clock tree plugin on a netlist, be careful
2017-10-30 09:33:37 -05:00
to erase any previously generated < code class = "docutils literal" > < span class = "pre" > _clocked< / span > < / code > file (both netlist and
layout: < code class = "docutils literal" > < span class = "pre" > rm< / span > < span class = "pre" > *.clocked.{ap,vst}< / span > < / code > ). And restart < span class = "cb" > cgt< / span > to clear it’ s
2017-07-15 10:35:02 -05:00
memory cache.< / p >
< / div >
2017-10-30 09:33:37 -05:00
< p > Configuration parameters, defaults are defined in < code class = "docutils literal" > < span class = "pre" > etc/coriolis2/< STECHNO> /plugins.conf< / span > < / code > .< / p >
2017-07-15 10:35:02 -05:00
< table border = "1" class = "docutils" >
< colgroup >
< col width = "43%" / >
< col width = "22%" / >
< col width = "35%" / >
< / colgroup >
< thead valign = "bottom" >
< tr class = "row-odd" > < th class = "head" > Parameter Identifier< / th >
< th class = "head" > Type< / th >
< th class = "head" > Default< / th >
< / tr >
< / thead >
< tbody valign = "top" >
< tr class = "row-even" > < td colspan = "3" > < strong > ClockTree Plugin Parameters< / strong > < / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > clockTree.minimumSide< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeInt< / td >
< td > < span class = "cb" > 300< / span > < / td >
< / tr >
< tr class = "row-even" > < td colspan = "2" > The minimum size below which the clock tree
will stop to perform quadri-partitions< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > clockTree.buffer< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeString< / td >
< td > < span class = "cb" > buf_x2< / span > < / td >
< / tr >
< tr class = "row-even" > < td colspan = "2" > The buffer model to use to drive sub-nets< / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-odd" > < td rowspan = "2" > < code class = "docutils literal" > < span class = "pre" > clockTree.placerEngine< / span > < / code > < / td >
2017-07-15 10:35:02 -05:00
< td > TypeString< / td >
< td > < span class = "cb" > Etesian< / span > < / td >
< / tr >
2017-10-30 09:33:37 -05:00
< tr class = "row-even" > < td colspan = "2" > The placer to use. Other value is < code class = "docutils literal" > < span class = "pre" > Mauka< / span > < / code >
2017-07-15 10:35:02 -05:00
the simulated annealing placer which will go
into retirement very soon< / td >
< / tr >
< / tbody >
< / table >
< / div >
< div class = "section" id = "recursive-save-rsave" >
< h3 > Recursive-Save (RSave)< a class = "headerlink" href = "#recursive-save-rsave" title = "Permalink to this headline" > ¶< / a > < / h3 >
< p > Perform a recursive top down save of all the models from the top cell
loaded in < span class = "cb" > cgt< / span > . Force a write of any non-terminal model. This plugin is used
by the clock tree plugin after the netlist clock sub-nets creation.< / p >
< / div >
< / div >
< div class = "section" id = "a-simple-example-am2901" >
< h2 > A Simple Example: AM2901< a class = "headerlink" href = "#a-simple-example-am2901" title = "Permalink to this headline" > ¶< / a > < / h2 >
< p > To illustrate the capabilities of < span class = "sc" > Coriolis< / span > tools and < span class = "sc" > Python< / span > scripting, a small
example, derived from the < span class = "sc" > Alliance< / span > < span class = "cb" > AM2901< / span > is supplied.< / p >
< p > This example contains only the synthetized netlists and the < span class = "cb" > doChip.py< / span > script
which perform the whole P& R of the design.< / p >
< p > You can generate the chip using one of the following method:< / p >
< ol class = "arabic" >
< li > < p class = "first" > < strong > Command line mode:< / strong > directly run the script:< / p >
2017-10-30 09:33:37 -05:00
< div class = "highlight-default" > < div class = "highlight" > < pre > < span > < / span > < span class = "n" > dummy< / span > < span class = "nd" > @lepka< / span > < span class = "p" > :< / span > < span class = "n" > AM2901< / span > < span class = "o" > > < / span > < span class = "o" > ./< / span > < span class = "n" > doChip< / span > < span class = "o" > -< / span > < span class = "n" > V< / span > < span class = "o" > --< / span > < span class = "n" > cell< / span > < span class = "o" > =< / span > < span class = "n" > amd2901< / span >
< / pre > < / div >
2017-07-15 10:35:02 -05:00
< / div >
< / li >
2017-10-30 09:33:37 -05:00
< li > < p class = "first" > < strong > Graphic mode:< / strong > launch < span class = "cb" > cgt< / span > , load chip netlist < code class = "docutils literal" > < span class = "pre" > amd2901< / span > < / code > (the top cell)
2017-07-15 10:35:02 -05:00
then run the < span class = "sc" > Python< / span > script < span class = "cb" > doChip.py< / span > .< / p >
< / li >
< / ol >
< div class = "admonition note" >
< p class = "first admonition-title" > Note< / p >
< p > Between two consecutive run, be sure to erase the netlist/layout generateds:< / p >
2017-10-30 09:33:37 -05:00
< div class = "last highlight-default" > < div class = "highlight" > < pre > < span > < / span > < span class = "n" > dummy< / span > < span class = "nd" > @lepka< / span > < span class = "p" > :< / span > < span class = "n" > AM2901< / span > < span class = "o" > > < / span > < span class = "n" > rm< / span > < span class = "o" > *< / span > < span class = "n" > clocked< / span > < span class = "o" > *.< / span > < span class = "n" > vst< / span > < span class = "o" > *.< / span > < span class = "n" > ap< / span >
< / pre > < / div >
2017-07-15 10:35:02 -05:00
< / div >
< / div >
< / div >
< / div >
< / div >
< footer >
< div class = "rst-footer-buttons" role = "navigation" aria-label = "footer navigation" >
Validating channel routing mode (two metals) on SNX.
* New: In Hurricane::Entity, add an id counter limit and a memory size
limit. The two limits are checked only when a new Entity object is
created. This should help avoiding massive memory links.
* New: In CRL Core, add a "crlcore.groundName" and a "crlcore.powerName"
parameter to specify the name of the ground/power signals to be
created if they are missing in a Cell. For Alliance libraries it
would be "vss" & "vdd" (default values), but for real technologies,
it is often "gnd!" & "vdd!".
The Blif parser is modificated to make use of it.
* Bug: In AnabaticEngine::unify(), set the resulting unified segment in
the center of the GCells common side. Gcells under a segment are
found by using the edge that cover the segment axis. When we have
a "bend" GCell stack and the axis is wrong, they could be ommited.
This was causing deleted segments to be not removed from some
Edges, then core dump.
* Change: In Anabatic::AutoSegment::create(), smarter choosing of the
reference contact, select the fixed or terminal one instead of
always the source one.
* New: In Anabatic::Edge::isEnding(), new function to check if a
segment going through an Edge is starting/ending in either source
or target GCell of the edge (active only when running in channel
mode).
* New: In Anabatic::Edge::add(), a segment takes part in the occupancy
only if it is not ending in either source or target (channel mode
only). The occupancy due to terminal is pre-computed in Katana.
* New: In Anabatic::Edge::ripup(), in channel mode, never ripup a
segment which is ending in either source or target (we *have* to
access this edge to connect to the terminal).
* Bug: In Anabatic::GCell::hcut() and vcut(), force the update of
the Edge which is on the side that will get splitted by the cut.
It's capacity will be reduced to it must be updated.
* Change: In Anabatic::GCell::updateGContacts() add a flag to conditionnally
update horizontals or verticals only. We may require only a partial
update when resizing the GCell in only one direction.
This, again, related to the fact that we compute the GCells under
a segment thanks to it's axis position, so we need to be very careful
when modificating axis.
* Change: In Katana::Block::resizeChannels(), only update GContact vertical
position. Do not disturb X positions of segments.
* Bug: In Katana::GlobalRoute::DigitalDistance, in channel mode, some
Edges can have a zero capacity, but still be reachable if the net has
a terminal in either source or target. Look for this case and return
a distance of zero instead of "unreachable". This was causing the
global routing not to complete in channel mode.
For computing the edge distance, makes the vertical edges much more
long (10 times) than the horizontal ones as the vertical capacity is
very limited. Hard coded for now, should make it a parameter in the
future.
* Change: In KatanaEngine::annotateGlobalGraph(), decrease the capacity
of edges with reserveCapacity for each terminal inside a GCell.
Both north and south edges are decreased as we a terminal will
block both north and south edges.
As a counterpart, the Edge capacity is not decreased when the
global router connect to a terminal.
* Change: In Katana::RoutingEvent::revalidate(), when in repair stage,
do not expand the slack for horizontal segments in channel mode.
So they may not overlap the standard cell row.
* Bug: In Stratus documentation, do not use the french option in babel,
the documentation is in english!
* New: In Documentation, added Hurricane/Python tutorial, part for drawing
layout.
2018-03-16 10:20:04 -05:00
< a href = "../PythonTutorial/index.html" class = "btn btn-neutral float-right" title = "Hurricane Python Tutorial" accesskey = "n" > Next < span class = "fa fa-arrow-circle-right" > < / span > < / a >
2017-07-15 10:35:02 -05:00
< a href = "ViewerTools.html" class = "btn btn-neutral" title = "CGT - The Graphical Interface" accesskey = "p" > < span class = "fa fa-arrow-circle-left" > < / span > Previous< / a >
< / div >
< hr / >
< div role = "contentinfo" >
< table class = "footer1" >
< tr >
< td class = "LFooter" > < small >
Generated by < a href = "http://sphinx-doc.org/" > Sphinx< / a >
Validating channel routing mode (two metals) on SNX.
* New: In Hurricane::Entity, add an id counter limit and a memory size
limit. The two limits are checked only when a new Entity object is
created. This should help avoiding massive memory links.
* New: In CRL Core, add a "crlcore.groundName" and a "crlcore.powerName"
parameter to specify the name of the ground/power signals to be
created if they are missing in a Cell. For Alliance libraries it
would be "vss" & "vdd" (default values), but for real technologies,
it is often "gnd!" & "vdd!".
The Blif parser is modificated to make use of it.
* Bug: In AnabaticEngine::unify(), set the resulting unified segment in
the center of the GCells common side. Gcells under a segment are
found by using the edge that cover the segment axis. When we have
a "bend" GCell stack and the axis is wrong, they could be ommited.
This was causing deleted segments to be not removed from some
Edges, then core dump.
* Change: In Anabatic::AutoSegment::create(), smarter choosing of the
reference contact, select the fixed or terminal one instead of
always the source one.
* New: In Anabatic::Edge::isEnding(), new function to check if a
segment going through an Edge is starting/ending in either source
or target GCell of the edge (active only when running in channel
mode).
* New: In Anabatic::Edge::add(), a segment takes part in the occupancy
only if it is not ending in either source or target (channel mode
only). The occupancy due to terminal is pre-computed in Katana.
* New: In Anabatic::Edge::ripup(), in channel mode, never ripup a
segment which is ending in either source or target (we *have* to
access this edge to connect to the terminal).
* Bug: In Anabatic::GCell::hcut() and vcut(), force the update of
the Edge which is on the side that will get splitted by the cut.
It's capacity will be reduced to it must be updated.
* Change: In Anabatic::GCell::updateGContacts() add a flag to conditionnally
update horizontals or verticals only. We may require only a partial
update when resizing the GCell in only one direction.
This, again, related to the fact that we compute the GCells under
a segment thanks to it's axis position, so we need to be very careful
when modificating axis.
* Change: In Katana::Block::resizeChannels(), only update GContact vertical
position. Do not disturb X positions of segments.
* Bug: In Katana::GlobalRoute::DigitalDistance, in channel mode, some
Edges can have a zero capacity, but still be reachable if the net has
a terminal in either source or target. Look for this case and return
a distance of zero instead of "unreachable". This was causing the
global routing not to complete in channel mode.
For computing the edge distance, makes the vertical edges much more
long (10 times) than the horizontal ones as the vertical capacity is
very limited. Hard coded for now, should make it a parameter in the
future.
* Change: In KatanaEngine::annotateGlobalGraph(), decrease the capacity
of edges with reserveCapacity for each terminal inside a GCell.
Both north and south edges are decreased as we a terminal will
block both north and south edges.
As a counterpart, the Edge capacity is not decreased when the
global router connect to a terminal.
* Change: In Katana::RoutingEvent::revalidate(), when in repair stage,
do not expand the slack for horizontal segments in channel mode.
So they may not overlap the standard cell row.
* Bug: In Stratus documentation, do not use the french option in babel,
the documentation is in english!
* New: In Documentation, added Hurricane/Python tutorial, part for drawing
layout.
2018-03-16 10:20:04 -05:00
using a < a href = "https://readthedocs.org" > RTD< / a > theme on Mar 16, 2018.
2017-07-15 10:35:02 -05:00
< / small > < / td >
< td class = "RFooter" > < / td >
< / tr >
< / table >
< table class = "footer2" >
< tr >
< td class = "LFooter" > Coriolis 2 Documentation< / td >
< td class = "RFooter" > < small >
2018-01-06 10:55:44 -06:00
© Copyright 2000-2018, UPMC.
2017-07-15 10:35:02 -05:00
< / small > < / td >
< / tr >
< / table >
< / div >
< / footer >
< / div >
< / div >
< / section >
< / div >
< script type = "text/javascript" >
var DOCUMENTATION_OPTIONS = {
URL_ROOT:'../',
VERSION:'2',
COLLAPSE_INDEX:false,
FILE_SUFFIX:'.html',
HAS_SOURCE: true
};
< / script >
< script type = "text/javascript" src = "../_static/jquery.js" > < / script >
< script type = "text/javascript" src = "../_static/underscore.js" > < / script >
< script type = "text/javascript" src = "../_static/doctools.js" > < / script >
< script type = "text/javascript" src = "../_static/js/theme.js" > < / script >
< script type = "text/javascript" >
jQuery(function () {
SphinxRtdTheme.StickyNav.enable();
});
< / script >
< / body >
< / html >