# **TopoR Tutorial**

This document allows you to get started with ease by routing simple projects using TopoR autorouter. The tutorial includes step-by-step design guide that allow you to discover basic program features. If you have any questions while learning the tutorial, contact our support staff: <a href="mailto:support@toporouter.com">support@toporouter.com</a>. We will be happy to be of assistance and gladly answer all your questions. We use TopoR Lite and DipTrace CAD system, all projects are included into DipTrace examples. You can use another CAD system that can create DSN files and other layouts (there is no big difference). This version of tutorial was created with TopoR ver. 4.3.89.14 and DipTrace ver. 2.0.07

## I. Downloading and installing

First we should download and install TopoR Lite and DipTrace.

Notice that if you already have TopoR Demo, you should download TopoR Lite to be able to save files and export them back to CAD system. TopoR Demo allows to route larger projects to evaluate TopoR capabilities, but doesn't allow to save files.

Open <u>http://www.toporouter.com/download.php</u> and download TopoR Lite, then install it to your PC. Notice that during installation is also adds Visual C++ 2005 Redistributable package, please do not stop installation of that package.

Open <u>http://www.diptrace.com/download.php</u> and download DipTrace Freeware, install it to your system. You can also upgrade it to Non-Profit Lite version (500 pins) without charge by sending request about that to <u>support@diptrace.com</u> (say you got information about that upgrade from TopoR tutorial), however DipTrace Freeware can open files of unlimited size, so we can use it too.

# II. First project

## 2.1 Exporting DSN from DipTrace CAD system

Our first project will be simple PCB from DipTrace examples.

Run DipTrace PCB Layout from Start/All Programs/DipTrace and open C:/Program files/DipTrace/ Examples/PCB\_4.dip. You can see simple PCB that was routed manually.



We can configure net classes, etc. in DipTrace (those classes will be transferred to TopoR via DSN format), however we will do that in TopoR. In DipTrace select «View/Units/mm», then «Route/Unroute All» to unroute all traces and «Route/Route Setup» to set default trace properties. Set 0.4 mm for trace width and clearance, OK to apply settings. Select «Route / Electra/Specctra Intergration / Export Autorouter DSN» and save pcb4.dsn file. Minimize DipTrace.

#### 2.2 Importing DSN and configuring net classes

Run TopoR Lite from «Start/All Programs/TopoR Lite». Select «File/Import/Import PCB File», find your pcb4.dsn file and open it. Then OK in «Import» window and «Coach Message».

In Design Style Editing dialog box select «Net classes» in the left side and «Units/mm» in lower-right. As you can see there are 2 net classes: Default and Class 1 for GND net. These classes are imported from DipTrace. Change width for Class 1 to 0.6 mm — in the Top grid click on the width field for Rule 1 and change its content to 0.6. Also move VCC net to Class 1, move it from the left list of nets (Default class) to the right list (Class 1) — scroll left list to the bottom, find VCC, select it and press  $\ll >$  button.

| Design Style Editing                                          |               |           |            |           |           |          | X       |
|---------------------------------------------------------------|---------------|-----------|------------|-----------|-----------|----------|---------|
|                                                               |               |           |            |           |           |          |         |
| <ul> <li>Define designing style</li> <li>Padstacks</li> </ul> | Rule          | Width Min |            | Clearance |           | Via type | ADD     |
| Clearances                                                    |               |           |            | Desir     |           |          | DEL     |
| Net classes                                                   | Default       | 0.40      | 0.40       | 0.6       |           | 0        |         |
| Component classes                                             | Rule1         | 0.60      | 0.40       | 0.6       | 0         | 0        |         |
| Routing layers                                                |               |           |            |           |           |          |         |
| Component outlines                                            | Net class     |           | Rule       | Trait     |           | ADD      |         |
|                                                               | Default       |           | Default    | Normal    |           | _        |         |
|                                                               | Class1        |           | Rule1      | Normal    | l         | DEL      |         |
|                                                               | Classi        |           | NGIO1      | Horman    | -         |          |         |
|                                                               |               |           |            |           |           |          |         |
|                                                               | Default       |           |            |           | Cla       | 1        | ~       |
|                                                               |               | ~         |            |           |           |          | ×       |
|                                                               | P8<br>P9      | <u>^</u>  |            |           | GN<br>VCI |          |         |
|                                                               | RAW_DC        |           |            | >         | VC.       | 6        |         |
|                                                               | RESET<br>SER1 |           |            | <         |           |          |         |
| <u>Units</u>                                                  | SER2          |           |            |           |           |          |         |
|                                                               | SER3<br>SER4  | _         |            |           |           |          |         |
| mm 💌                                                          | SER4          | - [       | Select all | Sele      | ect all   |          |         |
|                                                               |               |           |            |           |           |          |         |
| Import                                                        |               | Check     | ОК         | Cancel    | Help      | Messa    | ages << |
|                                                               |               |           |            |           |           |          |         |
|                                                               |               |           |            |           |           |          |         |
|                                                               |               |           |            |           |           |          |         |
|                                                               |               |           |            |           |           |          |         |

Press OK to import design with these settings. Also OK it Catch message, you can also read catch messages to learn program features more in-depth and check «Do not show this message again».

#### **2.3 Preparing to route**

After import we can see components with outlines.

| 🐰 pcb4 - TopoR Lite 4.3 - [pcb4.fsx]                                                                                                           |                                       |
|------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| Eile Edit View Copper areas Iools Help                                                                                                         |                                       |
|                                                                                                                                                | ► = < 🔤 🛄 🗌 📑 🗗 🧔 🖓 🖓 🖓 🖓 🖓           |
|                                                                                                                                                | 🔍 - 📐 🚺 💁 🛇 - 🖿 - 🔄 - A 🛛 🖾 💷 📞 🌉 🚰 🗖 |
| ×                                                                                                                                              |                                       |
| P → pcb4                                                                                                                                       |                                       |
|                                                                                                                                                |                                       |
| Project Search                                                                                                                                 |                                       |
| x                                                                                                                                              |                                       |
|                                                                                                                                                |                                       |
|                                                                                                                                                |                                       |
|                                                                                                                                                |                                       |
|                                                                                                                                                |                                       |
|                                                                                                                                                |                                       |
|                                                                                                                                                |                                       |
|                                                                                                                                                |                                       |
|                                                                                                                                                |                                       |
|                                                                                                                                                |                                       |
|                                                                                                                                                |                                       |
|                                                                                                                                                |                                       |
| Warning 5034: Unfixed component 'J12' intercrossing with board outline of                                                                      | an the top side                       |
| Warning 5036: Unfixed components 'C2' and 'U9' intercross on the top sid     Warning 5036: Unfixed components 'C2' and VD2' intercross on thet | le of the board. (4)                  |
| Warning 5036: Unfixed components 'C4' and 'SW4' intercross on the<br>Warning 5036: Unfixed components 'VD1' and 'C3' intercross on the         | top side of the board.                |
|                                                                                                                                                | op and of the board.)                 |
| WIRES ROUTES EDITING: 0.00 mm, 0 via(s), 0 violation(s)                                                                                        | -11.34 : 45.37 [mm] Any 🛒             |

DipTrace makes rectangular outline based on component graphics for each component. For our design this caused intercrossing of some components (see warnings below). To use TopoR auto-placement and placement correction features we should fix such warnings. If you will not use automatic placement correction skip this step. Double click on the warning to highlight intercrossing components and then move them (to move component left click on it to select and then drag using left mouse button). Do not correct intercrossing with board outline warning as J12 is connector that has fixed position.

Next step is locking position of some components. If you don't lock components TopoR thinks that it is possible to correct their position after making traces. That may cause making more traces than possible in some areas. So select connectors and other components with fixed position (use Ctrl for multiple select) and press «F» key or « ) » button to lock them. The outline color for locked components will be different.

### 2.4 Autorouting

Now we are ready to auto-route our PCB.

Press « 🚳 » button to start autorouting. Ng auto-routing TopoR optimizes several auto-routing variants simultaneously, selects the bests and places them into the table. Please wait few minutes while it makes normal routing results and press « 🔳 » button to stop auto-routing.

You can also preview topology results — right click on it in the table and select «Show», to return to the results table press « 📰 » button. TopoR doesn't make traces when auto-route PCB, but only finds optimal design topology.



Place checkboxes for the results you like, then right click on the best one and choose «Open for Editing». On this step TopoR makes traces and places vias, for large designs it may take some time.

Traces may include arcs and lines or lines only (arcs are approximated). DipTrace supports arcs, so we can use them, press «  $\bigcirc$  » button to enable arc-like traces. To see another result select it in the project bar in the left side and press «  $\circlearrowright$  » button. If you already corrected existing topology, you can save it as fsx file.

## 2.5 Correcting results

Our routed design have some DRC errors, that we should fix or keep without changes if clearances are ok. It is possible to do that in two ways: allow TopoR to correct component positions or correct positions manually. It is also possible to route/correct traces manually (TopoR has specific tools to work with arc-like traces), however for our simple layout it is not necessary. For manual correction zoom-in places where you see white lines, see if the clearance is really non-acceptable and move components (left click to select and drag), traces will be recounted automatically. For automatic correction press « >> » button and select «Start components and vias automatic movement with wires refining». TopoR will try to remove all DRC errors and minimize trace lengths by moving all unlocked components and vias. After this procedure we can also move components if necessary. We will move components manually as our layout has only few errors.



## 2.6 Exporting SES-file back to CAD system

After completing correction we can export results as SES-file back to DipTrace or export gerber/drill files directly from TopoR. To export SES-file select File/Export/Specctra SES and save pcb4.ses Minimize TopoR and choose DipTrace PCB Layout on the Windows taskbar to show it. Select «Route / Electra/Specctra Integration / Import Autorouter SES» from the main menu and specify pcb4.ses. Now you can edit this file in DipTrace, export gerber/drill files etc.



# **III. Second project**

## 3.1 Preparing PCB in DipTrace CAD System

Our second project will be more complex board with power/gnd planes and BGA component. We will also try to edit it manually after auto-routing in TopoR.

Run DipTrace PCB Layout and open C:/Program files/DipTrace/Examples/arm.dip As you can see the file is already routed with TopoR, so please unroute using «Route/Unroute All» command from main menu. Then select Route/Route Setup and set trace width and clearance to 0.1 mm (View/Units if units are not mm). Small trace width and clearance are necessary to be able route BGA-pattern. Also change default via size through Layer/Via Properties, it should be outer diameter — 0.4 mm and hole diameter — 0.2 mm. Notice that our PCB has 2 signal (routing) layers — Top and Bottom and 2 plane layers — GND and PWR used for ground and power nets. In DipTrace you can add/change layers from the Layers menu if necessary.

Also we will add a few traces manually (let us assume that we need to route critical traces before autorouting). First please select Layer/Layer Setup from main menu and change color of the Top layer, currently it is red and the pads of the routed net will not be highlighted as pad highlight color (View/Colors) is the same. Then select Route/Tools/Route Manual from the main menu or Route Manual button on the route panel and make several traces for existing nets in DipTrace (left click on the first pad/trace, then define trace by points and left click on the second pad/trace).



Select «Route / Electra/Specctra Integration / Export Autorouter DSN» from main menu and save arm.dsn file, minimize DipTrace.

## 3.2 Importing DSN and preparing to route.

Now run TopoR, select «File/Import/Import PCB file» from main menu and then your arm.dsn. In the «Design Style Editing» dialog box we should specify that our VCC33 and GND nets are connected to inner plane layers to let auto-router only make vias for them.

Select «Net classes» in the left side, add class (Add button near the grid with «Net class», «Rule», «Trait» field), select new class and set change «Trait» to «Inner plane». Move GND and VCC33 from Default to CLASS1. Press OK to import DSN file.

| Design Style Editing                                                              |                                            |       |          |             |                 |          |
|-----------------------------------------------------------------------------------|--------------------------------------------|-------|----------|-------------|-----------------|----------|
| <ul> <li>Define designing style</li> <li>Padstacks</li> <li>Clearances</li> </ul> | Rule                                       | Width | Min      | Clearance   | Via type        | ADD      |
| Net classes                                                                       | Default                                    | 0.10  | 0.10     | 0.15        | 0               | DEL      |
| Component classes<br>⊟ Layer assignment<br>Routing layers                         |                                            |       |          |             |                 |          |
| Component outlines                                                                | Net class                                  | Ru    | le Trait |             | ADD             |          |
|                                                                                   | Default                                    | Defa  | ault     | Normal      | DEL             |          |
|                                                                                   | CLASS1                                     | Defa  | ault     | Inner plane |                 |          |
|                                                                                   |                                            |       |          |             |                 |          |
|                                                                                   | Default                                    | ~     |          |             | CLASS1          | *        |
|                                                                                   | A0<br>A1<br>A10<br>A11<br>A13<br>A14<br>A2 |       |          | >           | GND<br>VCC33    |          |
| mm                                                                                | A21<br>A22<br>A3                           | ► Se  | lect all | Select all  | כ               |          |
| Import                                                                            | (                                          | Check | OK       | Cancel H    | elp <u>M</u> es | sages << |
|                                                                                   |                                            |       |          |             |                 |          |

Now select routed traces using box selection and press «  $\mathfrak{Q}$  » button to lock them. Then select connectors and other components with fixed positions and press «F» or «  $\mathfrak{Q}$  » button to lock them.



The layout has two intercrossed components — U4 and U5. You should not fix this as only one of these components will be placed to the PCB.

We wil also enable tear-drops for this layout, select «Tools/Options» from main menu, then Show/Pads in the left listbox and check «Make tear-drops» box, press Apply.

| Options                                                                                                                                                                 |                                              | $\overline{\mathbf{X}}$                                                                                          |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| Language<br>Show<br>Components<br>Pads<br>Vias & junctions<br>Wires<br>Routing layers<br>Violations<br>Selection<br>Fonts<br>Autoplacement<br>Autorouting<br>Automoving | Make tear-drops<br>Smooth narrowing of wires | Axis<br>Text<br>Show through pins:<br>Show top layer pads:<br>Show bottom layer pads:<br>Show bottom layer pads: |
| <u>R</u> estore default                                                                                                                                                 |                                              | Apply OK Cancel                                                                                                  |

You can also disable or enable special BGA-component routing in this dialog-box, See «Autorouting» options. Choose OK to close the dialog box.

#### 3.3 Auto-routing

Press « 🚳 » button to run auto-router, wait 5-6 to get optimal results with minimum 4-5 depth (first digit in «Round» field) and stop auto-router using « 🔳 » button.

Check the results you like, right click on one of them and select «Open for Editing».

| 🞇 arm - TopoR Lite 4.3 - [arm.fsx]                 |    |                     |       |                   |                 |      |        |            |                             |         |
|----------------------------------------------------|----|---------------------|-------|-------------------|-----------------|------|--------|------------|-----------------------------|---------|
| Eile View Iools Help                               |    |                     |       |                   |                 |      |        |            |                             |         |
| ▷ ■ □ □ 11 ■ 12 ● 12 ●  □ □ □ □ □ □ □ □ 12 ● 2 € 1 |    |                     |       |                   |                 |      |        |            | ) <b>t</b> 2 ( <sup>»</sup> |         |
| 000000000                                          | te | <b>U</b> - <b>P</b> | V     | 12·0·             | <b>b • 61 •</b> | a 🗉  | 4      | 0 % 📕      | ) <b>P</b> F 🔥              |         |
| ×                                                  |    | Name                | Lengt | h of netlines, mm | 🔸 Length,       | Vias | Errors | Shrinkages | Elapsed                     | Round   |
|                                                    |    | 2673-435s.fsb       |       | 1961.78           | 2673.22         | 435  | 15     | 0          | 19:59                       | 7.1.30  |
|                                                    |    | 2781-275s.fsb       |       | 2026.19           | 2781.21         | 275  | 0      | 0          | 1:59                        | 2.2.15  |
| ESX arm                                            |    | 2873-253s.fsb       |       | 2038.66           | 2872.93         | 253  | 0      | 0          | 7:10                        | 10.1.36 |
|                                                    |    | 2904-251 s.fsb      |       | 2040.07           | 2903.82         | 251  | 0      | 0          | 7:44                        | 11.1.36 |
|                                                    |    | 2944-249s.fsb       |       | 2040.10           | 2943.92         | 249  | 0      | 0          | 7:09                        | 10.1.31 |
|                                                    |    | 2993-247s.fsb       |       | 2049.79           | 2993.35         | 247  | 0      | 0          | 8:07                        | 11.1.47 |
|                                                    |    | 3055-245s.fsb       |       | 2054.26           | 3054.69         | 245  | 0      | 0          | 7:08                        | 10.1.28 |
|                                                    |    |                     |       | 2060.61           | 3203.55         | 241  | 0      | 0          | 15:40                       | 11.1.74 |
|                                                    |    | Add to project      |       | 2096.77           | 3453.46         | 237  | 0      | 0          | 18:19                       | 7.1.61  |
| Project Search                                     |    | Delete              |       |                   |                 |      |        |            |                             |         |
|                                                    |    | Start up            |       |                   |                 |      |        |            |                             |         |
|                                                    |    | Show                |       |                   |                 |      |        |            |                             |         |
|                                                    |    | Open for editing    |       |                   |                 |      |        |            |                             |         |
|                                                    |    | Mark all records    |       |                   |                 |      |        |            |                             |         |
|                                                    |    |                     |       |                   |                 |      |        |            |                             |         |

In our case routing comes without DRC errors, so we don't need to move components, etc. However if your variant have errors you can move components/vias to fix them.



#### 3.4 Manual editing traces

TopoR has specific features to edit arc-like traces manually. Editing such traces in DipTrace or other CAD program without specific tools of topology editing and automatic trace making based on topology feature is complex task. For simple layouts manual editing is not necessary, however we will learn how to do it as you may need it for more complex layouts.

Scroll your design to some place where you want to edit traces. BTW use mouse scroll for zooming and right mouse button for panning. We will scroll our layout to the bottom-left area (C16 component). Press «  $\mathbf{M}$  » button to switch to manual editing mode, arc traces will be converted to polylines without arcs.



Now select the part of trace — hold down Ctrl key and left click on the parts of trace, you can also box selection to select several parts of the trace.



Press cut-off button ( 🔂 ) to convert all selected segment into one — usually this is necessary to simplify editing. Move center point of this segment to another location to change topology. Now do the same with few other traces. Use « 🚂- » button to change layers of selected segments. Also you can move vias and components in this mode. In our case we only play with this feature, however usually it is used to fix errors. Our final picture after moving several traces will look as follows:



Press «  $\mathcal{U}$  » button to return to freestyle editing mode and make arc-like traces based on our modified topology.



### 3.5 Exporting back to DipTrace and adding planes.

Select File/Export/Specctra SES from main menu and save arm.ses file, then minimize TopoR and select DipTrace PCB Layout on the task bar. Choose Route / Electra/Specctra Integration / Import Autorouter SES and then your arm.ses file.

Next step will be placing copper pours to plane layers and connecting them to ground and vcc vias. Select «GND» layer in the «Current Signal/Plane Layer» box.



Then «Objects/Place Copper Pour» from main menu of button on the objects panel, place few points, right click and Enter. In the copper pour placement dialog box select «Connectivity» tab and «Connect to Net : GND» - it should be already set as we place copper pour to the plane layer with gnd net in properties. Define thermal connections, it is usually «Direct» for vias. Then select «Border» tab and check «Depending on Board» to make copper pour border based on board outline, define clearance between copper pour and board outline. Press OK.



The same for VCC layer. We can also define different thermal settings for pads of P2 connector, right click on one of the pads, select «Thermal Settings», then unchekc «Use copper pour settings» and select different thermal type. Update copper pours (right click on the copper pour border and Update). To ensure all connections are ok use Verification/Check Net Connectivity feature.

That's all for now.

Thank you for learning this quick tutorial. If you like TopoR and want to learn it more in-depth please use user manual that is installed together with TopoR.

Join our group at Yahoo! to communicate with other TopoR users, suggest new features and get support from the developer: <u>http://groups.yahoo.com/group/topor</u>

Order TopoR online at http://www.toporouter.com/order.php

Links:

Other TopoR tutorials: <u>http://www.toporouter.com/tutorials.php</u> DipTrace web-site: <u>http://www.diptrace.com</u> DipTrace tutorial: <u>http://www.diptrace.com/books/tutorial.pdf</u>