# Table of Contents
1. [Installation](#org648fc4e)
2. [Usage](#org4d8ab18)
1. [Defining Custom Metrics](#org023397d)
2. [Examples](#orge369aa6)
1. [neorv32 (VHDL)](#orgcb021dc)
1. [neorv32 with boolean (VHDL)](#neorv32boolean)
2. [corundum (VERILOG)](#org9b66d30)
3. [CICERO (VERILOG/SYSTEM-VERILOG)](#cicero)
4. [cv32e40p (SYSTEM-VERILOG)](#orgbda061b)
3. [RAW'22 Experiments](#raw22experiments)
4. [Associated Publication](#paper_ref)
DoVado is a RTL design automation and exploration CLI tool.
<a id="org648fc4e"></a>
# Installation
DoVado needs python 3.6 or higher. Install it through pip, on many Linux systems use pip3 to force python 3 installation. Dovado has been tested on Vivado 2018.3.
pip3 install --user --no-cache dovado-rtl
<a id="org4d8ab18"></a>
# Usage
Dovado has two modes:
- points: design automation mode in which a file containing parameter values must be given and a file containing all the evaluations is returned for some given metrics,
- space: design exploration mode in which parameters and their ranges must be given together with some target metrics and the pareto set of design points with respect to the given metrics is returned.
<table border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<caption class="t-above"><span class="table-number">Table 1:</span> dovado general parameters</caption>
<colgroup>
<col class="org-left" />
<col class="org-left" />
<col class="org-left" />
</colgroup>
<thead>
<tr>
<th scope="col" class="org-left">parameter</th>
<th scope="col" class="org-left">description</th>
<th scope="col" class="org-left">mandatory</th>
</tr>
</thead>
<tbody>
<tr>
<td class="org-left">–file-path</td>
<td class="org-left">path to the target file</td>
<td class="org-left">yes</td>
</tr>
<tr>
<td class="org-left">–board</td>
<td class="org-left">vivado descriptor of a board</td>
<td class="org-left">yes</td>
</tr>
<tr>
<td class="org-left">–parameters</td>
<td class="org-left">parameters to use either for points/space (integers and booleans supported)</td>
<td class="org-left">yes</td>
</tr>
<tr>
<td class="org-left">–clock-port</td>
<td class="org-left">RTL identifier of the clock port</td>
<td class="org-left">yes</td>
</tr>
<tr>
<td class="org-left">–implementation</td>
<td class="org-left">switch to evaluate designs after implementation (default is after synthesis)</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–incremental</td>
<td class="org-left">switch to use incremental synthesis/implementation</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–directives</td>
<td class="org-left">list of directives to pass to synthesis, place and route (default is RuntimeOptimized for all three)</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–target-clock</td>
<td class="org-left">clock (Mhz) to give as a constraint to Vivado (default=1000)</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–metrics</td>
<td class="org-left">list of metrics to target using their integer identifier (default mode is interactive, you will be asked after first synthesis/implementation)</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left"> </td>
<td class="org-left"> </td>
<td class="org-left"> </td>
</tr>
</tbody>
</table>
After those parameters specify points/space both these modes take an argument:
- points argument: specify the path to the csv file containing the design points to be analyzed. The csv file must contain on each line the value for each of the parameters stated through –parameters in the same order,
- space argument: a list of ranges stated as 1 2 3 4 where this way we would be defining two ranges (1, 2) for the first parameter and (3, 4) for the second parameter
No further parameters can be passed to points
<table border="2" cellspacing="0" cellpadding="6" rules="groups" frame="hsides">
<colgroup>
<col class="org-left" />
<col class="org-left" />
<col class="org-left" />
</colgroup>
<thead>
<tr>
<th scope="col" class="org-left">parameter</th>
<th scope="col" class="org-left">description</th>
<th scope="col" class="org-left">mandatory</th>
</tr>
</thead>
<tbody>
<tr>
<td class="org-left">–power-of-2</td>
<td class="org-left">list of ’y/n’ to state whether a parameter must be explored stepping power of 2s</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–many-objective</td>
<td class="org-left"> replace default ga implementation (NSGA-II) with AGEMOEA which is a variant better suited for many objective (e.g. >4) optimization</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–param-initial-values</td>
<td class="org-left">parameter values which are guaranteed to be synthesizable to retrieve metric mapping</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–optimization-runtime</td>
<td class="org-left">set as a termination condition a timeout as hh:mm:ss</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–read-design-values</td>
<td class="org-left">read design values from a csv</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–disable-approximate</td>
<td class="org-left">disable approximation</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–estimation-model</td>
<td class="org-left">choose Hoeffding Adaptive Tree (default) or Kernel Ridge regressor or Shadow to not use the controller but log anyways</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–controller-model</td>
<td class="org-left">choose Mab or Distance-based (default) controller</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–disable-controller-mab-weight</td>
<td class="org-left">disable loss weighting in distance controller</td>
<td class="org-left">no</td>
</tr>
<tr>
<td class="org-left">–n-controllers</td>
<td class="org-left">set the number of voting controllers (default is 500, too high for many applications)</td>
<td class="org-left">no</td>
</tr>
</tbody>
</table>
Directory structure is vital for the functioning of the tool:
- VHDL: if a package is used the corresponding folder must be named exactly as the package; if one wants to analyse a module in a project with multiple packages each file belonging to a given package must reside in a subfolder with the same name as the package it belongs to:
- package-name (top folder must have the name of the top package if it exists or any name if it does not exist)
- file-1 (belonging to package-name)
- file-2 (belonging to package-name)
- subpackage1-name
- file-1 (belonging to subpackage-name)
- file-2 (belonging to subpackage-name)
- …
- subpackage2-name
- …
- …
- VERILOG/SYSTEM-VERILOG: include directives are not supported all files must be in the same folder, no subfolders allowed; no import package allowed.
In order to inspect the tool's work you have several files at hand:
- `dovado_work/point_evaluation.csv` which has one design evaluation per line, mapped with the points you give dovado; written online during tool's execution in points mode
- `dovado_work/space_exploration.csv` which has all the design points explored together with the design values; written online during tool's execution both in points mode and in space mode
- `dovado_work/design_space.csv` and `dovado_work/objective_space.csv` are written at the end of the design exploration process (space mode) and contain respectively the pareto set of design parameters and the corresponding evaluations
<a id="org023397d"></a>
## Defining Custom Metrics
Procedure:
1. Create a folder named `custom_metrics` in the same folder where you are running dovado
mkdir custom_metrics
2. Create the **python** file which will contain your custom metric
touch test_metric.py
3. Write your metric function, any function you need to carry out the computation and any import for the libraries
# here any import works
# e.g. import numpy as np
import numpy as np
def test_metric(**kwargs) -> float:
# only one metric per file is admitted
# if you want another custom metric create a new file
print(kwargs)
return float(__helper_function(kwargs["frequency"]))
def __helper_function(a):
# Care the underscores '__' are mandatory for helper functions
# This function won't show as a metric is here only for helping purposes
return a + 1000
4. Run dovado without metric selected:
dovado --file-path <path to "neorv32/rtl/neorv32/neorv32_top.vhd"> --board xc7k70tfbv676-1 --parameters MEM_INT_IMEM_SIZE --parameters MEM_INT_DMEM_SIZE --clock-port clk_i space 16384 131072 8129 65536 --power-of-2 y --power-of-2 y
5. Select your metrics, you will now find your custom metrics after all utilisation metrics provided by your board of choice:
![img](./readme_resources/metrics_selection.png)
General advice:
- the function must return float (**highly recommended** to annotate the return type)
- all helper functions must start with double underscore “\_\_”
- relative imports are not supported, use only absolute imports
- all subfolders of `custom_metrics` are ignored.
- from the \*\*kwargs you can access all the other board metrics, the frequency and all the parameters you are using for explorationo by using either “frequency”, the name you find above or the parameter name in dovado's call e.g:
kwargs["frequency"]
kwargs["Slice LUTs*"]
kwargs["MEM_INT_IMEM_SIZE"]
<a id="orge369aa6"></a>
## Examples
<a id="orgcb021dc"></a>
### neorv32 (VHDL)
[**neorv32**](https://github.com/stnolting/neorv32) is an embedded RISC-V core.
git clone https://github.com/stnolting/neorv32
cd neorv32/rtl
mkdir neorv32
cp core/* neorv32/
cp core/mem/neorv32_*.default.vhd neorv32/
sed -i "s/CLOCK_FREQUENCY\s*: natural;\s*-- clock frequency of clk_i in Hz/CLOCK_FREQUENCY :natural:=100000000; -- clock frequency of clk_i in Hz/" neorv32/neorv32_top.vhd
Changing the name of the core folder, which contains all vhdl files, to the name of the package which is used along the files is mandatory to make dovado get ’use’ directives right.
Exploring the parameter space of the top module:
dovado --file-path <path to "neorv32/rtl/neorv32/neorv32_top.vhd"> --board xc7k70tfbv676-1 --parameters MEM_INT_IMEM_SIZE --parameters MEM_INT_DMEM_SIZE --clock-port clk_i --metrics 0 --metrics 1 --metrics 4 --metrics 9 space 16384 131072 8129 65536 --power-of-2 y --power-of-2 y
Above we are optimizing two memory parameters (MEM<sub>INT</sub><sub>IMEM</sub><sub>SIZE</sub>, MEM<sub>INT</sub><sub>DMEM</sub><sub>SIZE</sub>) with clk<sub>i</sub> as the clock port with metrics chosen:
- frequency (0)
- LUT occupation (1)
- REGISTER occupation (4)
- BRAM occupation (9)
Ranges are specified after space and we also specify that we want to search only among power of 2’s solutions.
<a id="neorv32boolean"></a>
### neorv32 boolean (VHDL)
Here an example of **exploring boolean parameters**, the trick here is to explore them as normal parameters but use as range [0, 1] obviously they can be mixed up with non-boolean parameters during exploration:
dovado --file-path <path to "neorv32/rtl/neorv32/neorv32_top.vhd"> --board xc7k70tfbv676-1 --parameters BOOTLOADER_EN --parameters CPU_EXTENSION_RISCV_A --parameters CPU_EXTENSION_RISCV_B --parameters CPU_EXTENSION_RISCV_C --clock-port clk_i --metrics 0 --metrics 1 --metrics 4 --metrics 9 space 0 1 0 1 0 1 0 1 --disable-approximate
<a id="org9b66d30"></a>
### corundum (VERILOG)
[**corundum**](https://ieeexplore.ieee.org/abstract/document/9114811) is an open-source 100Gbps-NIC.
git clone https://github.com/corundum/corundum
cd corundum/
Exploring the parameter space of the top module:
dovado --file-path <path to "corundum/fpga/common/rtl/cpl_queue_manager.v"> --board xc7k70tfbv676-1 --target-clock 100000 --parameters OP_TABLE_SIZE --parameters QUEUE_INDEX_WIDTH --parameters PIPELINE --clock-port clk --metrics 0 --metrics 1 --metrics 4 --metrics 9 space 8 64 4 11 2 32 --disable-approximate
Using **approximation** parameters:
dovado --file-path <path to "corundum/fpga/common/rtl/cpl_queue_manager.v"> --board xc7k70tfbv676-1 --target-clock 100000 --parameters OP_TABLE_SIZE --parameters QUEUE_INDEX_WIDTH --parameters PIPELINE --clock-port clk --metrics 0 --metrics 1 --metrics 4 --metrics 9 space 8 64 4 11 2 32
<a id="cicero"></a>
### CICERO (VERILOG/SYSTEM-VERILOG)
[**CICERO**](https://dl.acm.org/doi/abs/10.1145/3476982) is a Domain-Specific Architecture (DSA) for Regular Expression matching.
We take off-the-shelf DSA and apply a DSE to maximize Frequency and custom metrics, and minimize LUTs usage according to some metrics.
The custom metrics employed are performance of the multi-engine architecture and $I cache size by changing Core#, Internal Parallelism, $I lines.
git clone https://github.com/necst/cicero -b feature/dse
mkdir custom_metrics
cp cicero/hdl_src/cicero_core/custom_metrics/avg_perf.py custom_metrics/
cp cicero/hdl_src/cicero_core/custom_metrics/isize.py custom_metrics/
For the **exact** version run:
dovado --file-path cicero/hdl_src/cicero_core/cicero_core.v --board xcku060-ffva1156-2-i --parameters BB_N --parameters CC_ID_BITS --parameters PC_WIDTH --clock-port s00_axi_aclk --metrics 0 --metrics 1 --metrics 37 --metrics 38 space 2 72 1 3 9 10 --many-objective --disable-approximate
For the **approximated** version run:
dovado --file-path cicero/hdl_src/cicero_core/cicero_core.v --board xcku060-ffva1156-2-i --parameters BB_N --parameters CC_ID_BITS --parameters PC_WIDTH --clock-port s00_axi_aclk --metrics 0 --metrics 1 --metrics 37 --metrics 38 space 2 72 1 3 9 10 --many-objective
<a id="orgbda061b"></a>
### cv32e40p (SYSTEM-VERILOG)
Vivado does not support for 2018.3 release a complex SystemVerilog top-module with a hierarchy.
Therefore, we use a simpler module for showcasing purposes.
git clone https://github.com/openhwgroup/cv32e40p
cd rtl
mkdir testing
cp cv32e40p_fifo.sv testing/
In this project an include directory is used but dovado does not currently support it thus we create a subfolder, name may be whatever, where to isolate the module we are interested in studying. This workaround is only possible if the module one wants to study works standalone without include directives.
dovado --file-path <path to "cv32e40p/rtl/testing/cv32e40p_fifo.sv"> --board xc7k70tfbv676-1 --target-clock 100000 --parameters DEPTH --parameters DATA_WIDTH --clock-port clk_i --metrics 0 --metrics 1 --metrics 4 --metrics 9 space 2 4096 2 64 --power-of-2 y --power-of-2 y --disable-approximate
<a id="raw22experiments"></a>
# RAW'22 Experiments
We combined Dovado with [Movado](https://github.com/DPaletti/movado) capabilities and run DSEs for different purposes and showcasing Movado approximation capabilities.
We explore [**corundum**](https://ieeexplore.ieee.org/abstract/document/9114811) with the [corresponding section commands](#org9b66d30) .
Then we explore the RISCV extensions of [**neorv32**](https://github.com/stnolting/neorv32), modelling the combination of such extensions with the following **custom metric** (already written in `custom_metrics/extension_score.py`):
```
def extension_score(**kwargs) -> float:
print("kwargs:")
print(kwargs)
return float(__helper_function([int(kwargs["CPU_EXTENSION_RISCV_A"]), int(kwargs["CPU_EXTENSION_RISCV_C"]), int(kwargs["CPU_EXTENSION_RISCV_E"]), int(kwargs["CPU_EXTENSION_RISCV_M"]), int(kwargs["CPU_EXTENSION_RISCV_U"]), int(kwargs["CPU_EXTENSION_RISCV_Zfinx"]), int(kwargs["CPU_EXTENSION_RISCV_Zicsr"]), int(kwargs["CPU_EXTENSION_RISCV_Zifencei"])]))
def __helper_function(variants):
print(variants)
return sum(variants) * -1000.00
```
and run with
dovado --file-path neorv32/rtl/neorv32/neorv32_ProcessorTop_Minimal.vhd --board xa7a12tcpg238-2I --parameters CPU_EXTENSION_RISCV_A --parameters CPU_EXTENSION_RISCV_C --parameters CPU_EXTENSION_RISCV_E --parameters CPU_EXTENSION_RISCV_M --parameters CPU_EXTENSION_RISCV_U --parameters CPU_EXTENSION_RISCV_Zfinx --parameters CPU_EXTENSION_RISCV_Zicsr --parameters CPU_EXTENSION_RISCV_Zifencei --clock-port clk_i space 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 --disable-approximate
You will be prompted to choose the objective metrics to optimize, where you will be able to select the custom metric. Please remove the final `--disable-approximate` to run the exact version.
We then explore two DSA for Regular Expressions. We scale up [**TiReX**](https://ieeexplore.ieee.org/abstract/document/8425395) single core with its internal parallelism, but the project is not open-sourced, hence not replicable here. We then scale out [**CICERO**](https://dl.acm.org/doi/abs/10.1145/3476982) engines number according to the [corresponding examples section](#cicero) procedures.
<a id="paper_ref"></a>
# Associated Publication
If you find this repository useful, please use the following citation:
Dovado with custom metrics and Movado:
```
@inproceedings{paletti2021online,
title={Online Learning RTL Synthesis for Automated Design Space Exploration},
author={Paletti, Daniele and Peverelli, Francesco and Conficconi, Davide and Santambrogio, Marco D},
booktitle={2022 IEEE International Parallel and Distributed Processing Symposium Workshops (IPDPSW)},
year={2022},
organization={IEEE}
}
```
Original Dovado Publication:
```
@inproceedings{paletti2021dovado,
title={Dovado: An Open-Source Design Space Exploration Framework},
author={Paletti, Daniele and Conficconi, Davide and Santambrogio, Marco D},
booktitle={2021 IEEE International Parallel and Distributed Processing Symposium Workshops (IPDPSW)},
pages={128--135},
year={2021},
organization={IEEE}
}
```
Raw data
{
"_id": null,
"home_page": "https://github.com/DPaletti/dovado",
"name": "dovado-rtl",
"maintainer": "",
"docs_url": null,
"requires_python": ">=3.9,<4.0",
"maintainer_email": "",
"keywords": "Xilinx,Vivado,TCL,VHDL,Verilog,RTL,Design Space,Genetic Algorithm",
"author": "Daniele Paletti",
"author_email": "danielepaletti98@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/b4/c9/7f1c99a3728e91deb0bef69b1cbbc16965eea39fd674f86ed7667829cd00/dovado_rtl-0.10.11.tar.gz",
"platform": null,
"description": "\n# Table of Contents\n\n1. [Installation](#org648fc4e)\n2. [Usage](#org4d8ab18)\n 1. [Defining Custom Metrics](#org023397d)\n 2. [Examples](#orge369aa6)\n 1. [neorv32 (VHDL)](#orgcb021dc)\n 1. [neorv32 with boolean (VHDL)](#neorv32boolean)\n 2. [corundum (VERILOG)](#org9b66d30)\n 3. [CICERO (VERILOG/SYSTEM-VERILOG)](#cicero)\n 4. [cv32e40p (SYSTEM-VERILOG)](#orgbda061b)\n3. [RAW'22 Experiments](#raw22experiments)\n4. [Associated Publication](#paper_ref)\nDoVado is a RTL design automation and exploration CLI tool.\n\n\n<a id=\"org648fc4e\"></a>\n\n# Installation\n\nDoVado needs python 3.6 or higher. Install it through pip, on many Linux systems use pip3 to force python 3 installation. Dovado has been tested on Vivado 2018.3.\n\n pip3 install --user --no-cache dovado-rtl\n\n\n<a id=\"org4d8ab18\"></a>\n\n# Usage\n\nDovado has two modes:\n\n- points: design automation mode in which a file containing parameter values must be given and a file containing all the evaluations is returned for some given metrics,\n- space: design exploration mode in which parameters and their ranges must be given together with some target metrics and the pareto set of design points with respect to the given metrics is returned.\n\n<table border=\"2\" cellspacing=\"0\" cellpadding=\"6\" rules=\"groups\" frame=\"hsides\">\n<caption class=\"t-above\"><span class=\"table-number\">Table 1:</span> dovado general parameters</caption>\n\n<colgroup>\n<col class=\"org-left\" />\n\n<col class=\"org-left\" />\n\n<col class=\"org-left\" />\n</colgroup>\n<thead>\n<tr>\n<th scope=\"col\" class=\"org-left\">parameter</th>\n<th scope=\"col\" class=\"org-left\">description</th>\n<th scope=\"col\" class=\"org-left\">mandatory</th>\n</tr>\n</thead>\n\n<tbody>\n<tr>\n<td class=\"org-left\">–file-path</td>\n<td class=\"org-left\">path to the target file</td>\n<td class=\"org-left\">yes</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–board</td>\n<td class=\"org-left\">vivado descriptor of a board</td>\n<td class=\"org-left\">yes</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–parameters</td>\n<td class=\"org-left\">parameters to use either for points/space (integers and booleans supported)</td>\n<td class=\"org-left\">yes</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–clock-port</td>\n<td class=\"org-left\">RTL identifier of the clock port</td>\n<td class=\"org-left\">yes</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–implementation</td>\n<td class=\"org-left\">switch to evaluate designs after implementation (default is after synthesis)</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–incremental</td>\n<td class=\"org-left\">switch to use incremental synthesis/implementation</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–directives</td>\n<td class=\"org-left\">list of directives to pass to synthesis, place and route (default is RuntimeOptimized for all three)</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–target-clock</td>\n<td class=\"org-left\">clock (Mhz) to give as a constraint to Vivado (default=1000)</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–metrics</td>\n<td class=\"org-left\">list of metrics to target using their integer identifier (default mode is interactive, you will be asked after first synthesis/implementation)</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\"> </td>\n<td class=\"org-left\"> </td>\n<td class=\"org-left\"> </td>\n</tr>\n</tbody>\n</table>\n\nAfter those parameters specify points/space both these modes take an argument:\n\n- points argument: specify the path to the csv file containing the design points to be analyzed. The csv file must contain on each line the value for each of the parameters stated through –parameters in the same order,\n- space argument: a list of ranges stated as 1 2 3 4 where this way we would be defining two ranges (1, 2) for the first parameter and (3, 4) for the second parameter\n\nNo further parameters can be passed to points\n\n<table border=\"2\" cellspacing=\"0\" cellpadding=\"6\" rules=\"groups\" frame=\"hsides\">\n\n\n<colgroup>\n<col class=\"org-left\" />\n\n<col class=\"org-left\" />\n\n<col class=\"org-left\" />\n</colgroup>\n<thead>\n<tr>\n<th scope=\"col\" class=\"org-left\">parameter</th>\n<th scope=\"col\" class=\"org-left\">description</th>\n<th scope=\"col\" class=\"org-left\">mandatory</th>\n</tr>\n</thead>\n\n<tbody>\n<tr>\n<td class=\"org-left\">–power-of-2</td>\n<td class=\"org-left\">list of ’y/n’ to state whether a parameter must be explored stepping power of 2s</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–many-objective</td>\n<td class=\"org-left\"> replace default ga implementation (NSGA-II) with AGEMOEA which is a variant better suited for many objective (e.g. >4) optimization</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–param-initial-values</td>\n<td class=\"org-left\">parameter values which are guaranteed to be synthesizable to retrieve metric mapping</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–optimization-runtime</td>\n<td class=\"org-left\">set as a termination condition a timeout as hh:mm:ss</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–read-design-values</td>\n<td class=\"org-left\">read design values from a csv</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–disable-approximate</td>\n<td class=\"org-left\">disable approximation</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–estimation-model</td>\n<td class=\"org-left\">choose Hoeffding Adaptive Tree (default) or Kernel Ridge regressor or Shadow to not use the controller but log anyways</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–controller-model</td>\n<td class=\"org-left\">choose Mab or Distance-based (default) controller</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–disable-controller-mab-weight</td>\n<td class=\"org-left\">disable loss weighting in distance controller</td>\n<td class=\"org-left\">no</td>\n</tr>\n\n\n<tr>\n<td class=\"org-left\">–n-controllers</td>\n<td class=\"org-left\">set the number of voting controllers (default is 500, too high for many applications)</td>\n<td class=\"org-left\">no</td>\n</tr>\n</tbody>\n</table>\n\nDirectory structure is vital for the functioning of the tool:\n\n- VHDL: if a package is used the corresponding folder must be named exactly as the package; if one wants to analyse a module in a project with multiple packages each file belonging to a given package must reside in a subfolder with the same name as the package it belongs to:\n - package-name (top folder must have the name of the top package if it exists or any name if it does not exist)\n - file-1 (belonging to package-name)\n - file-2 (belonging to package-name)\n - subpackage1-name\n - file-1 (belonging to subpackage-name)\n - file-2 (belonging to subpackage-name)\n - …\n - subpackage2-name\n - …\n - …\n- VERILOG/SYSTEM-VERILOG: include directives are not supported all files must be in the same folder, no subfolders allowed; no import package allowed.\n\nIn order to inspect the tool's work you have several files at hand:\n- `dovado_work/point_evaluation.csv` which has one design evaluation per line, mapped with the points you give dovado; written online during tool's execution in points mode\n- `dovado_work/space_exploration.csv` which has all the design points explored together with the design values; written online during tool's execution both in points mode and in space mode\n- `dovado_work/design_space.csv` and `dovado_work/objective_space.csv` are written at the end of the design exploration process (space mode) and contain respectively the pareto set of design parameters and the corresponding evaluations\n\n<a id=\"org023397d\"></a>\n\n## Defining Custom Metrics\n\nProcedure:\n\n1. Create a folder named `custom_metrics` in the same folder where you are running dovado\n \n mkdir custom_metrics\n2. Create the **python** file which will contain your custom metric\n \n touch test_metric.py\n3. Write your metric function, any function you need to carry out the computation and any import for the libraries\n \n # here any import works\n # e.g. import numpy as np\n import numpy as np\n \n \n def test_metric(**kwargs) -> float:\n # only one metric per file is admitted\n # if you want another custom metric create a new file\n print(kwargs)\n return float(__helper_function(kwargs[\"frequency\"]))\n \n \n def __helper_function(a):\n # Care the underscores '__' are mandatory for helper functions\n # This function won't show as a metric is here only for helping purposes\n return a + 1000\n4. Run dovado without metric selected:\n \n dovado --file-path <path to \"neorv32/rtl/neorv32/neorv32_top.vhd\"> --board xc7k70tfbv676-1 --parameters MEM_INT_IMEM_SIZE --parameters MEM_INT_DMEM_SIZE --clock-port clk_i space 16384 131072 8129 65536 --power-of-2 y --power-of-2 y\n5. Select your metrics, you will now find your custom metrics after all utilisation metrics provided by your board of choice:\n ![img](./readme_resources/metrics_selection.png)\n\nGeneral advice:\n\n- the function must return float (**highly recommended** to annotate the return type)\n- all helper functions must start with double underscore “\\_\\_”\n- relative imports are not supported, use only absolute imports\n- all subfolders of `custom_metrics` are ignored.\n- from the \\*\\*kwargs you can access all the other board metrics, the frequency and all the parameters you are using for explorationo by using either “frequency”, the name you find above or the parameter name in dovado's call e.g:\n \n kwargs[\"frequency\"]\n kwargs[\"Slice LUTs*\"]\n kwargs[\"MEM_INT_IMEM_SIZE\"]\n\n\n<a id=\"orge369aa6\"></a>\n\n## Examples\n\n\n<a id=\"orgcb021dc\"></a>\n\n### neorv32 (VHDL)\n[**neorv32**](https://github.com/stnolting/neorv32) is an embedded RISC-V core.\n\n git clone https://github.com/stnolting/neorv32\n cd neorv32/rtl\n mkdir neorv32\n cp core/* neorv32/\n cp core/mem/neorv32_*.default.vhd neorv32/\n sed -i \"s/CLOCK_FREQUENCY\\s*: natural;\\s*-- clock frequency of clk_i in Hz/CLOCK_FREQUENCY :natural:=100000000; -- clock frequency of clk_i in Hz/\" neorv32/neorv32_top.vhd\n\nChanging the name of the core folder, which contains all vhdl files, to the name of the package which is used along the files is mandatory to make dovado get ’use’ directives right.\nExploring the parameter space of the top module:\n\n dovado --file-path <path to \"neorv32/rtl/neorv32/neorv32_top.vhd\"> --board xc7k70tfbv676-1 --parameters MEM_INT_IMEM_SIZE --parameters MEM_INT_DMEM_SIZE --clock-port clk_i --metrics 0 --metrics 1 --metrics 4 --metrics 9 space 16384 131072 8129 65536 --power-of-2 y --power-of-2 y\n\nAbove we are optimizing two memory parameters (MEM<sub>INT</sub><sub>IMEM</sub><sub>SIZE</sub>, MEM<sub>INT</sub><sub>DMEM</sub><sub>SIZE</sub>) with clk<sub>i</sub> as the clock port with metrics chosen:\n\n- frequency (0)\n- LUT occupation (1)\n- REGISTER occupation (4)\n- BRAM occupation (9)\n\nRanges are specified after space and we also specify that we want to search only among power of 2’s solutions.\n\n<a id=\"neorv32boolean\"></a>\n### neorv32 boolean (VHDL)\n\nHere an example of **exploring boolean parameters**, the trick here is to explore them as normal parameters but use as range [0, 1] obviously they can be mixed up with non-boolean parameters during exploration:\n\n dovado --file-path <path to \"neorv32/rtl/neorv32/neorv32_top.vhd\"> --board xc7k70tfbv676-1 --parameters BOOTLOADER_EN --parameters CPU_EXTENSION_RISCV_A --parameters CPU_EXTENSION_RISCV_B --parameters CPU_EXTENSION_RISCV_C --clock-port clk_i --metrics 0 --metrics 1 --metrics 4 --metrics 9 space 0 1 0 1 0 1 0 1 --disable-approximate\n\n\n<a id=\"org9b66d30\"></a>\n\n### corundum (VERILOG)\n[**corundum**](https://ieeexplore.ieee.org/abstract/document/9114811) is an open-source 100Gbps-NIC.\n\n git clone https://github.com/corundum/corundum\n cd corundum/\n\nExploring the parameter space of the top module:\n\n dovado --file-path <path to \"corundum/fpga/common/rtl/cpl_queue_manager.v\"> --board xc7k70tfbv676-1 --target-clock 100000 --parameters OP_TABLE_SIZE --parameters QUEUE_INDEX_WIDTH --parameters PIPELINE --clock-port clk --metrics 0 --metrics 1 --metrics 4 --metrics 9 space 8 64 4 11 2 32 --disable-approximate\n\nUsing **approximation** parameters:\n\n dovado --file-path <path to \"corundum/fpga/common/rtl/cpl_queue_manager.v\"> --board xc7k70tfbv676-1 --target-clock 100000 --parameters OP_TABLE_SIZE --parameters QUEUE_INDEX_WIDTH --parameters PIPELINE --clock-port clk --metrics 0 --metrics 1 --metrics 4 --metrics 9 space 8 64 4 11 2 32\n\n<a id=\"cicero\"></a>\n\n### CICERO (VERILOG/SYSTEM-VERILOG)\n\n[**CICERO**](https://dl.acm.org/doi/abs/10.1145/3476982) is a Domain-Specific Architecture (DSA) for Regular Expression matching.\nWe take off-the-shelf DSA and apply a DSE to maximize Frequency and custom metrics, and minimize LUTs usage according to some metrics.\nThe custom metrics employed are performance of the multi-engine architecture and $I cache size by changing Core#, Internal Parallelism, $I lines.\n\n git clone https://github.com/necst/cicero -b feature/dse\n mkdir custom_metrics\n cp cicero/hdl_src/cicero_core/custom_metrics/avg_perf.py custom_metrics/\n cp cicero/hdl_src/cicero_core/custom_metrics/isize.py custom_metrics/\n\n\nFor the **exact** version run:\n\n dovado --file-path cicero/hdl_src/cicero_core/cicero_core.v --board xcku060-ffva1156-2-i --parameters BB_N --parameters CC_ID_BITS --parameters PC_WIDTH --clock-port s00_axi_aclk --metrics 0 --metrics 1 --metrics 37 --metrics 38 space 2 72 1 3 9 10 --many-objective --disable-approximate\n\nFor the **approximated** version run:\n\n dovado --file-path cicero/hdl_src/cicero_core/cicero_core.v --board xcku060-ffva1156-2-i --parameters BB_N --parameters CC_ID_BITS --parameters PC_WIDTH --clock-port s00_axi_aclk --metrics 0 --metrics 1 --metrics 37 --metrics 38 space 2 72 1 3 9 10 --many-objective \n\n\n<a id=\"orgbda061b\"></a>\n\n### cv32e40p (SYSTEM-VERILOG)\n\nVivado does not support for 2018.3 release a complex SystemVerilog top-module with a hierarchy. \nTherefore, we use a simpler module for showcasing purposes.\n\n git clone https://github.com/openhwgroup/cv32e40p\n cd rtl\n mkdir testing\n cp cv32e40p_fifo.sv testing/\n\nIn this project an include directory is used but dovado does not currently support it thus we create a subfolder, name may be whatever, where to isolate the module we are interested in studying. This workaround is only possible if the module one wants to study works standalone without include directives.\n\n dovado --file-path <path to \"cv32e40p/rtl/testing/cv32e40p_fifo.sv\"> --board xc7k70tfbv676-1 --target-clock 100000 --parameters DEPTH --parameters DATA_WIDTH --clock-port clk_i --metrics 0 --metrics 1 --metrics 4 --metrics 9 space 2 4096 2 64 --power-of-2 y --power-of-2 y --disable-approximate\n\n<a id=\"raw22experiments\"></a>\n\n# RAW'22 Experiments\n\nWe combined Dovado with [Movado](https://github.com/DPaletti/movado) capabilities and run DSEs for different purposes and showcasing Movado approximation capabilities.\nWe explore [**corundum**](https://ieeexplore.ieee.org/abstract/document/9114811) with the [corresponding section commands](#org9b66d30) .\n\nThen we explore the RISCV extensions of [**neorv32**](https://github.com/stnolting/neorv32), modelling the combination of such extensions with the following **custom metric** (already written in `custom_metrics/extension_score.py`):\n\n```\ndef extension_score(**kwargs) -> float:\n\tprint(\"kwargs:\")\n\tprint(kwargs)\n\treturn float(__helper_function([int(kwargs[\"CPU_EXTENSION_RISCV_A\"]), int(kwargs[\"CPU_EXTENSION_RISCV_C\"]), int(kwargs[\"CPU_EXTENSION_RISCV_E\"]), int(kwargs[\"CPU_EXTENSION_RISCV_M\"]), int(kwargs[\"CPU_EXTENSION_RISCV_U\"]), int(kwargs[\"CPU_EXTENSION_RISCV_Zfinx\"]), int(kwargs[\"CPU_EXTENSION_RISCV_Zicsr\"]), int(kwargs[\"CPU_EXTENSION_RISCV_Zifencei\"])]))\n\ndef __helper_function(variants):\n\tprint(variants)\n\treturn sum(variants) * -1000.00\n```\n\nand run with \n\n dovado --file-path neorv32/rtl/neorv32/neorv32_ProcessorTop_Minimal.vhd --board xa7a12tcpg238-2I --parameters CPU_EXTENSION_RISCV_A --parameters CPU_EXTENSION_RISCV_C --parameters CPU_EXTENSION_RISCV_E --parameters CPU_EXTENSION_RISCV_M --parameters CPU_EXTENSION_RISCV_U --parameters CPU_EXTENSION_RISCV_Zfinx --parameters CPU_EXTENSION_RISCV_Zicsr --parameters CPU_EXTENSION_RISCV_Zifencei --clock-port clk_i space 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 --disable-approximate\n\nYou will be prompted to choose the objective metrics to optimize, where you will be able to select the custom metric. Please remove the final `--disable-approximate` to run the exact version.\n\n\nWe then explore two DSA for Regular Expressions. We scale up [**TiReX**](https://ieeexplore.ieee.org/abstract/document/8425395) single core with its internal parallelism, but the project is not open-sourced, hence not replicable here. We then scale out [**CICERO**](https://dl.acm.org/doi/abs/10.1145/3476982) engines number according to the [corresponding examples section](#cicero) procedures.\n\n<a id=\"paper_ref\"></a>\n# Associated Publication\n\nIf you find this repository useful, please use the following citation:\n\nDovado with custom metrics and Movado:\n```\n@inproceedings{paletti2021online,\n title={Online Learning RTL Synthesis for Automated Design Space Exploration},\n author={Paletti, Daniele and Peverelli, Francesco and Conficconi, Davide and Santambrogio, Marco D},\n booktitle={2022 IEEE International Parallel and Distributed Processing Symposium Workshops (IPDPSW)},\n year={2022},\n organization={IEEE}\n}\n```\n\nOriginal Dovado Publication:\n```\n@inproceedings{paletti2021dovado,\n title={Dovado: An Open-Source Design Space Exploration Framework},\n author={Paletti, Daniele and Conficconi, Davide and Santambrogio, Marco D},\n booktitle={2021 IEEE International Parallel and Distributed Processing Symposium Workshops (IPDPSW)},\n pages={128--135},\n year={2021},\n organization={IEEE}\n}\n```\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "RTL Design Space Exploration on top of Vivado",
"version": "0.10.11",
"split_keywords": [
"xilinx",
"vivado",
"tcl",
"vhdl",
"verilog",
"rtl",
"design space",
"genetic algorithm"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "72054cc70cb410f05f744bdd2a68043415e8b5e59916e6e21ba1d4e926ac4d61",
"md5": "c1b1d564aa718823081a17306258124c",
"sha256": "8a79fc505c678ad036dfd996301c9ab195feb2df4ec1964905320f3b9531456a"
},
"downloads": -1,
"filename": "dovado_rtl-0.10.11-py3-none-any.whl",
"has_sig": false,
"md5_digest": "c1b1d564aa718823081a17306258124c",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.9,<4.0",
"size": 1200085,
"upload_time": "2023-04-28T08:23:21",
"upload_time_iso_8601": "2023-04-28T08:23:21.463137Z",
"url": "https://files.pythonhosted.org/packages/72/05/4cc70cb410f05f744bdd2a68043415e8b5e59916e6e21ba1d4e926ac4d61/dovado_rtl-0.10.11-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "b4c97f1c99a3728e91deb0bef69b1cbbc16965eea39fd674f86ed7667829cd00",
"md5": "99ebb1320a3bc4bac5eac312e2e9905e",
"sha256": "5d1ffffd5238314a065dd4eda3d37183339779ff7742c60d1a3a643a2e032373"
},
"downloads": -1,
"filename": "dovado_rtl-0.10.11.tar.gz",
"has_sig": false,
"md5_digest": "99ebb1320a3bc4bac5eac312e2e9905e",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.9,<4.0",
"size": 1153464,
"upload_time": "2023-04-28T08:23:25",
"upload_time_iso_8601": "2023-04-28T08:23:25.441838Z",
"url": "https://files.pythonhosted.org/packages/b4/c9/7f1c99a3728e91deb0bef69b1cbbc16965eea39fd674f86ed7667829cd00/dovado_rtl-0.10.11.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-04-28 08:23:25",
"github": true,
"gitlab": false,
"bitbucket": false,
"github_user": "DPaletti",
"github_project": "dovado",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "dovado-rtl"
}