

Program Manual



# Topology Description Generator Quick Start Guide

V.1.0 2020/1/30

Please download the latest version at https://unit.aist.go.jp/esprit/cppc/

Contact: cppc-secretariat-ml@aist.go.jp

\* Please note that we do not accept questions or inquiries regarding how to use the TDG.



Disclaimer of Warranties:

**Topology Description Generator** is provided AS IS, with all faults, without any warranty of any kind.

License:

**Topology Description Generator** is licensed under the Apache License Version 2.0 (http://www.apache.org/licenses/LICENSE-2.0).

© 2020 CPPC

All rights reserved. No part of this publication may be reproduced, by any means whatsoever, without the prior written permission of CPPC.



# **1. PREPARING YOUR SOFTWARE ENVIRONMENT**

- Install the KiCAD software: <u>https://kicad-pcb.org/</u>
- Install Python 3.6: <u>https://www.python.org/</u>
- Download and uncompress TDG, as shown below.

| ¥TDG                         |                                    |
|------------------------------|------------------------------------|
| +doc                         |                                    |
| CPP-TPDG_manual.v.           | .1.pdf                             |
| LICENSE-2.0.txt              |                                    |
|                              |                                    |
| +KiCADLibrary                |                                    |
| OptNetModel100GHz.           | v1.lib                             |
| OptNetModel12.5GHz           | .v1.lib                            |
| OptNetModel50GHz.v           | 1.lib                              |
|                              |                                    |
| +SampleTopology              |                                    |
| +OptNetSampleModel           | 100GHz                             |
| Dnode1.sch                   | OptNetSampleModel100GHz.kicad_pcb  |
| Dnode2.sch                   | OptNetSampleModel100GHz.pro        |
| Dnode3.sch                   | OptNetSampleModel100GHz.sch        |
| Dnode4.sch                   | sym-lib-table                      |
| OptNetSampleMode             | el100GHz.pdf                       |
| OptNetSampleMode             | el100GHz.xml                       |
| OptNetSampleMode             | el100GHz_tpl.xml                   |
|                              |                                    |
| +OptNetSampleModel           | 12.5GHz                            |
| Dnode1.sch (                 | DptNetSampleModel12.5GHz.kicad_pcb |
| Dnode2.sch (                 | OptNetSampleModel12.5GHz.pro       |
| Dnode3.sch (                 | DptNetSampleModel12.5GHz.sch       |
| Dnode4.sch s                 | sym-lib-table                      |
| OptNetSampleMode             | el12.5GHz.pdf                      |
| OptNetSampleMode             | el12.xml                           |
| OptNetSampleMode             | el12_tpl.xml                       |
| <br>  V. OntNetSempleMedel/  |                                    |
|                              | DUGHZ                              |
| Driode T.Sch                 | DptNetSampleModel50GHz.kicau_pcb   |
| Driode2.sch                  |                                    |
| Drode3.sch                   |                                    |
| DIIOde4.scii s               | Synt-lib-lable                     |
|                              |                                    |
|                              |                                    |
|                              |                                    |
| fSiC<br>AdditionalInfaELEY28 | 3 vml                              |
|                              | yml                                |
|                              | vml                                |
| xml2topology2 pv             |                                    |
|                              |                                    |



# 2. STARTING UP A SAMPLE PROJECT

 Open "\TDG\SampleTopology\OptNetSampleModel100GHz\ OptNetSampleModel100GHz.pro"

| 📧 Dnode1.sch                      | 2019/12/19 1 |
|-----------------------------------|--------------|
| 📧 Dnode2.sch                      | 2019/12/19 1 |
| 📧 Dnode3.sch                      | 2019/12/19 1 |
| 👪 Dnode4.sch                      | 2019/12/19 1 |
| OptNetSampleModel100GHz.bak       | 2019/12/19 1 |
| OptNetSampleModel100GHz.kicad_pcb | 2019/12/19 1 |
| 😎 OptNetSampleModel100GHz.pdf     | 2019/12/19 1 |
| OptNetSampleModel100GHz.pro       | 2019/12/19 1 |
| OptNetSampleModel100GHz.sch       | 2019/12/19 1 |
| OptNetSampleModel100GHz.xml       | 2019/12/19 1 |
| OptNetSampleModel100GHz_tpl.xml   | 2019/12/19 1 |
| OptNetSampleModel100GHz-cache.lib | 2019/12/19 1 |
| sym-lib-table                     | 2019/12/19 1 |
|                                   |              |

- The KiCAD software is opened.
- · Click on "Preferences" and then on "Manage Symbol Libraries."

📓 KiCad (5.1.2)-2 D:¥D\_Document¥Model\_KAKEN¥201908Experiment¥OFC2020RTopo¥OFC2020RTopo3¥OFC20... — 🛛 🛛 🛛

| File View Tools Browse         | e Prefe    | rences Help                |                                                       |   |
|--------------------------------|------------|----------------------------|-------------------------------------------------------|---|
|                                | 1 🛓        | Configure Paths            |                                                       |   |
| OFC2020RTopo.pro               |            | Manage Symbol Libraries    |                                                       |   |
| OFC2020RTopo.I                 | <b>!</b> } | Manage Footprint Libraries |                                                       |   |
| OFC2020RTopo.                  | <u>한</u>   | Preferences                | Ctrl+,<br>OFC2020RTopo¥OFC2020RTopo3¥OFC2020RTopo pro | ~ |
| OFC2020RTopo3                  | 4          | Set Language               | >                                                     |   |
|                                |            |                            |                                                       |   |
|                                |            |                            |                                                       |   |
|                                |            |                            |                                                       |   |
|                                |            |                            |                                                       |   |
| < >                            |            |                            |                                                       | v |
| Edit the global and project sy | mbol lib   | rary tables                |                                                       |   |

 Add "\TDG\KiCADLibrary\OptNetModel100GHz.v1.lib" to the "Project Specific Libraries."



• Open "Schematic Layout Editor."



Now, you can edit and modify the topology according to your requirements.



# 3. EXPORTING THE TOPOLOGY DESCRIPTION

After editing the topology, you can export the complete information describing the topology.

• Click on "Generate netlist."

| ₹° E | schem | a — O | FC2020H | lopo.sch | n [/] — Da | ¥D_Do | cument | €Model | KAKEN | ¥20190 | 8Experi | ment | FOFC202 | 20RIop | a¥OFC2 | 020K lo | роз |  |   |   |     |             |        |      |
|------|-------|-------|---------|----------|------------|-------|--------|--------|-------|--------|---------|------|---------|--------|--------|---------|-----|--|---|---|-----|-------------|--------|------|
| File | Edit  | View  | Place   | Inspect  | t Tools    | Prefe | rences | Help   |       |        |         |      |         |        |        |         |     |  |   |   |     |             |        |      |
|      |       |       | I       | 1   💼    |            |       |        | G      | 0     | ⊕,     | Q       | Q    | Q       | E      | 5      |         |     |  | ð | 1 | M   | <b>\$</b>   |        | BACK |
|      | 1     |       |         |          |            |       |        |        |       |        |         |      |         |        |        |         |     |  |   |   | . L | Generate ne | uist . |      |
| Å    |       | 2     |         |          |            | - 0   |        |        | 2     |        |         | 3    |         |        |        |         |     |  |   |   |     |             |        |      |
| mm   | - 2   |       |         |          |            |       |        |        |       |        |         |      |         |        |        |         |     |  |   |   |     | 0 11 3      |        |      |

• Click on "Add Plugin..."

| Netlist                                                                                                                                                                                                                                   | × |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Pcbnew       OrcadPCB2       CadStar       Spice       Top. ●       ●         Options:        ✓       ✓       Generate Netlist         ✓       Default format       ✓       ✓       Close         Add Plugin       Remove Plugin.       ✓ | t |

 Enter the below command in the field "Netlist command:." python "\TDG\src\xml2topology2.py" –a "\TDG\src\AdditionalInfoWDM32.xml" –l "%I" "%O"

\*The folder path should be modified according to your system environment

- Enter some name in the field "Name:" for recognizing the added plugin, e.g., "TDGwithFBD"
- Click on "OK."
- Click the newly generated tub "TDGwithFBD" and then click the "Generate Netlist."

| Netlist         |                     |                      |   | ×                |
|-----------------|---------------------|----------------------|---|------------------|
| Spice<br>Option | Topology for PF2.0  | TDGwithFBD           | • | Generate Netlist |
| Def             | fault format        |                      |   | Close            |
| Netlist         | t command:          |                      |   | Add Plugin       |
| pythe           | on "¥TDG¥src¥xml2to | pology2.py" –a "¥TDG |   | Remove Plugin    |
| Title:          |                     |                      |   |                  |
| TDGv            | vithFBD             |                      |   |                  |
|                 |                     |                      |   |                  |



|                                       | 名前 ^                              | 東新日韓             | 通信               | サイブ    |  |
|---------------------------------------|-----------------------------------|------------------|------------------|--------|--|
| お気に入り                                 | 1742                              | ACRIMING.        | 14.75            | 212    |  |
| 🚺 ダウンロード                              | Inode1.sch                        | 2019/12/19 17:27 | KiCad Schematic  | 19 KB  |  |
| 📰 デスクトップ                              | Dnode2.sch                        | 2019/12/19 17:27 | KICad Schematic  | 21 KB  |  |
| 11 最近表示した場所                           | E Dnode3.sch                      | 2019/12/19 17:27 | KiCad Schematic  | 21 KB  |  |
| G OneDrive                            | IDnode4.sch                       | 2019/12/19 17:27 | KICad Schematic  | 30 KB  |  |
|                                       | OptNetSampleModel100GHz.bak       | 2019/12/19 15:45 | BAK ファイル         | 1 KB   |  |
|                                       | OptNetSampleModel100GHz.kicad_pcb | 2019/12/19 15:45 | KiCad Board      | 1 KB   |  |
| 51759                                 | 🔁 OptNetSampleModel100GHz.pdf     | 2019/12/19 17:32 | Adobe Acrobat    | 126 KB |  |
| ◎ ドキュメント                              | OptNetSampleModel100GHz.pro       | 2019/12/19 17:32 | KiCad Project    | 1 KB   |  |
| 1000000000000000000000000000000000000 | OptNetSampleModel100GHz.sch       | 2019/12/19 17:27 | KiCad Schematic  | 3 KB   |  |
| 😸 ビデオ                                 | OptNetSampleModel100GHz.xml       | 2019/12/19 17:28 | XML ドキュメント       | 94 KB  |  |
|                                       | OptNetSampleModel100GHz_tpl.xml   | 2019/12/19 17:28 | XML ドキュメント       | 123 KB |  |
|                                       | OptNetSampleModel100GHz-cache.lib | 2019/12/19 17:27 | VisualStudio.lib | 18 KB  |  |
|                                       | sym-lib-table                     | 2019/12/19 15:45 | ファイル             | 1 KB   |  |
| * 05 (0)                              |                                   |                  |                  |        |  |
| -                                     |                                   |                  |                  |        |  |
| ファイル名(N): OptN                        | etSampleModel100GHz               |                  |                  |        |  |
| イルの種類(T):全ての                          | )ファイル (*.*)                       |                  |                  |        |  |

• Save it with a file name, e.g., OptNetSampleModel100GHz.

• Two new files are generated. One is the OptNetSampleModel100GHz.xml, which describes the schematic circuit diagram content. The other is OptNetSampleModel100GHz\_tpl.xml, which describes the optical network topology description, including the channel table information.

| . • OptNetSampleModel100GHz • 4   | OptNetSampleMo   | odel100GHzの検索    | م  |
|-----------------------------------|------------------|------------------|----|
| 書き込む 新しいフォルダー                     |                  | :≕ ▼ 🗔           | 0  |
| 名前                                | 更新日時             | 種類               | サイ |
| 🕷 Dnode1.sch                      | 2019/12/19 17:27 | KiCad Schematic  |    |
| Inode2.sch                        | 2019/12/19 17:27 | KiCad Schematic  |    |
| 📧 Dnode3.sch                      | 2019/12/19 17:27 | KiCad Schematic  |    |
| 🗿 Dnode4.sch                      | 2019/12/19 17:27 | KiCad Schematic  |    |
| OptNetSampleModel100GHz.bak       | 2019/12/19 15:45 | BAK ファイル         |    |
| OptNetSampleModel100GHz.kicad_pcb | 2019/12/19 15:45 | KiCad Board      |    |
| 🗾 OptNetSampleModel100GHz.pdf     | 2019/12/19 17:32 | Adobe Acrobat    |    |
| OptNetSampleModel100GHz.pro       | 2019/12/19 17:32 | KiCad Project    |    |
| OptNetSampleModel100GHz.sch       | 2019/12/19 17:27 | KiCad Schematic  |    |
| OptNetSampleModel100GHz.xml       | 2019/12/19 17:28 | XML ドキュメント       |    |
| OptNetSampleModel100GHz_tpl.xml   | 2019/12/19 17:28 | XML ドキュメント       |    |
| OptNetSampleModel100GHz-cache.lib | 2019/12/19 17:27 | VisualStudio.lib |    |
| sym-lib-table                     | 2019/12/19 15:45 | ファイル             |    |

• The "OptNetSampleModel100GHz\_tpl.xml" is the topology description file that includes complete information for the topology. The data structure is shown below.



| </th <th>Pxml version="1.0" ?&gt;</th> | Pxml version="1.0" ?>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <t< td=""><td>opology&gt;</td></t<>    | opology>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| (1)                                    | <pre><design> <source/>D:\u00e4D_ocument\u00e4Model_KAKEN\u00e4TopoGenPublish\u00e4TDG\u00e4SampleTopology</design></pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| (2)                                    | <channelinfo><br/><channeltable id="WDM32" type="optical"><br/><channel no="1"><br/><doubleparam name="frequency" unit="THz">195.5</doubleparam><br/><doubleparam name="bandWidth" unit="GHz">100</doubleparam><br/></channel></channeltable></channelinfo>                                                                                                                                                                                                                                                                                                                                                  |
|                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| (3)                                    | <pre><components> <components> <components> <comp ref="N202"> <field name="idname">/TEST_WSS1X9_100GHz_N202</field> <field name="residence">/Dnode1/</field> <field name="residence">/Dnode1/</field> <field name="Controller">192.168.60.1</field> <field name="Controller">192.168.60.1</field> <field name="Controller">192.168.60.1</field> <field name="GLPK">(3)-a <field glpkchanneltableid="WDM32" glpktype="switching" name="GLPK">(3)-b <pre>set AvailableConnection := {i in InputPort, j in Channels, k in OutputPort,</pre></field></field></comp></components></components></components></pre> |
|                                        | <pre>c/componente&gt;</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| (4)<br></td <td><pre>  </pre></td>     | <pre>  </pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

(1) The *design* element describes the header information, such as the software version and the date of update.



- (2) The *channelInfo* element describes the wavelength channels supported by the network. Here, the 100 GHz-grid and 32 WDM channels are described.
- (3) The *components* element describes all instances of the optical components. The *comp* element describes each component instance.
  - (3)-a: The intermediate controller address to which the instance belongs
  - (3)-b: The switching functionalities of the component instance is described in GNU MathProg modeling language
  - (3)-c: Information for the intermediate controllers such as the corresponding operation program type invoked by the intermediate controller
  - (3)-d: The detailed port attributes of the component instance
- (4) The *nets* element describes all the fiber cablings (connections) among the optical ports of the component instances. The *net* element describes each cabling defined by a pair of optical ports.

By reading and analyzing the \_tpl.xml topology description file, we can perform optical path computation or optical node switching functionality analysis. Some studies using TDG have been published, as shown in Sec.4. TDG does not include tools for analyzing the topology description files currently; we plan to publish them in the future.



## 4. RELATED PUBLICATIONS

#### Journal:

• Kiyo Ishii, Atsuko Takefusa, Shu Namiki, Tomohiro Kudoh, "Optical Network Resource Management Supporting Physical Layer Reconfiguration," IEEE/OSA Journal of Lightwave Technology, Vol. 37, No. 21, pp. 5442-5454, Aug. 2019.

### Proceedings:

- Kiyo Ishii, Sugang Xu, Noboru Yoshikane, Atsuko Takefusa, Shigeyuki Yanagimachi, Takeshi Hoshida, Kohei Shiomoto, Tomohiro Kudoh, Takehiro Tsuritani, Yoshinari Awaji, Shu Namiki, "Automatic Resource Mapping Using Functional Block-Based Disaggregation Model for ROADM Networks," in Proc. OFC2020, SDN/NFV Demo-zone
- Kiyo Ishii, Shu Namiki, "Toward Automatized Handling of Future Agile Networks Employing Various Optical Switching Functionalities," in Proc. OECC/PSC2019
- Kiyo Ishii, Atsuko Takefusa, Shu Namiki, Tomohiro Kudoh, "Path Computation and Topology Description Scheme for Consistently Supporting Heterogeneous Optical Node Structures," in Proc. Advanced Photonics Congress, OSA, 2019
- Kiyo Ishii, Atsuko Takefusa, Shu Namiki, Tomohiro Kudoh, "Efficient Path Calculation Scheme for Advance Reservation of Hierarchical Optical Path Network Using Continuous Variables to Represent Switch States," in Proc. PSC2018





# ABOUT CPPC

Cyber Photonic Platform Consortium (CPPC) has been established on 2018/4/1 as one of the AIST consortia. The purpose of CPPC is driving the automation of the optical network layer leading to the creation of new markets, and pursuing sustainable development of the future information communication industry. For more information about CPPC, please visit <u>https://unit.aist.go.jp/esprit/cppc/</u>.

AIST developed this manual and TDG.