Skip to content

Commit

Permalink
Improve and clarify the docs
Browse files Browse the repository at this point in the history
  • Loading branch information
mole99 committed Mar 15, 2024
1 parent 0f93160 commit 34abbca
Show file tree
Hide file tree
Showing 18 changed files with 341 additions and 380 deletions.
4 changes: 4 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,10 @@ docs:
host-docs:
python3 -m http.server --directory ./docs/build/html

.PHONY: auto-docs
auto-docs:
sphinx-autobuild docs/source docs/build/html

.PHONY: clean
clean:
rm -rf build/
Expand Down
81 changes: 8 additions & 73 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -90,80 +90,14 @@ To host the docs, run:
make host-docs
```

> [!NOTE]
> The documentation can be viewed online at [cace.readthedocs.io](https://cace.readthedocs.io/).
## CACE GUI syntax

$ cace-gui [path/to/project.txt]

where optional file project.txt (normally <name_of_project>.txt
where <name_of_project> is the name of the circuit to be
characterized) is a circuit characterization description in the
file format described below. If a file is not specified, then
the GUI window will come up without content. Click on the button
with text "(no selection)" to find and select a characterization
file to load. The project file may also be in JSON format.

Normally, cace_gui.py is called from a project top level directory,
while the project.txt file is usually in a subdirectory called
cace/. The project.txt file may be the output file from a CACE
run, which will add results to all of the parameter entries.

There may be multiple characterization files in a single project
(repository), as a project may contain multiple subcircuits that
may need independent characterization or be able to be used as
standalone circuits, or a project may simply be a collection of
circuits (library) without a specific single top level.

## CACE command line syntax

$ cace <filename_in> <filename_out> [options]

where <filename_in> is a format 4.0 ASCII CACE file
and <filename_out> is the name of the file to write.

Options may be one of:

-source=schematic|layout|rcx|all|best
-param=<parameter_name>
-force
-json
-keep
-debug
-sequential
-summary

When run from the top level, this program parses the CACE
characterization file, runs simulations, and outputs a
modified file annotated with characterization results.
To automatically refresh the docs upon changes, run:

With option "-source", restrict characterization to the
specific netlist source, which is either schematic capture,
layout extracted, or full R-C parasitic extracted. If not
specified, then characterization is run on the full R-C
parasitic extracted layout netlist if available, and the
schematic captured netlist if not (option "best").

Option "-param=<parameter_name>" runs simulations on only
the named electrical or physical parameter.

Option "-force" forces new regeneration of all netlists.

Option "-json" generates an output file in JSON format.

Option "-keep" retains files generated for characterization.

Option "-noplot" will not generate any graphs.

Option "-debug" generates additional diagnostic output.

Option "-sequential" runs simulations sequentially.

Option "-nosim" does not re-run simulations if the output file exists.
(Warning---does not check if simulations are out of date).
```
make auto-docs
```

Option "-summary" prints a summary of results at the end.
> [!NOTE]
> The latest documentation can be viewed online at [cace.readthedocs.io](https://cace.readthedocs.io/).
## Examples

Expand All @@ -187,4 +121,5 @@ Example circuit repositories:

Each of these repositories contains a circuit designed with the SkyWater sky130 process open PDK, and contains schematics, layout, and CACE characterization.

NOTE: These repositories are a work in progress, and may not exist yet or may not have a characterization setup for CACE.
> [!NOTE]
> These repositories are a work in progress, and may not exist yet or may not have a characterization setup for CACE.
23 changes: 0 additions & 23 deletions docs/source/about.md

This file was deleted.

107 changes: 107 additions & 0 deletions docs/source/characterization.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,107 @@
# Characterization

## Selecting a datasheet

Start by selecting a datasheet. This step is only necessary if the application is started from the command line.

%If started from the project manager, then it can only be run if a datasheet exists for the project, in which case that datasheet is automatically loaded.

If running from the command line, there is a button at the top with the text `Datasheet:` and `(no selection)`. Push this button to get a file browser. Find a project datasheet, which is a text (`.txt`) file. A challenge datasheet should be found in the design folder for each accepted challenge.

%The project design folders are in the `design` subfolder in the user's home directory.

The challenge datasheet has the name of the project and the file extension `.txt`

When the JSON file is selected, a full display should be shown with each electrical parameter critical to the challenge, and its status.

## Characterization

The purpose of the characterization tool is to check the netlist against the official characterization specification for a circuit. The tool allows a quick check of the circuit design against the datasheet specification values, and presents a summary of results to the user. The purpose of these simulations is to see whether or not the design will pass or fail the specification. Details from these simulations are limited to the characterization values. They are not intended to replace the simulations done in the normal course of a circuit design.

The list of electrical parameters will vary by the type of design. However, each electrical paramater has a common set of properties that are listed in columns across the window. These are:

1. "Parameter" --- The name of the electrical or physical parameter.
2. "Testbench" --- The testbench corresponds to a netlist filename with the extension ".spice" (SPICE netlist) that can be found in the "cace" folder of the project (or the "testbench" path declared in the characterization file). The testbench netlists are in a special format that allows them to be altered by substitution for a specific measurement.
3. "Min" --- The minimum limit (if any) of the electrical parameter. After simulation, also shows the measured result of the circuit.
4. "Typ" --- The typical value (if any) of the electrical parameter. After simulation, also shows the measured result of the circuit.
5. "Max" --- The maximum limit (if any) of the electrical parameter. After simulation, also shows the measured result of the circuit.
6. "Status" --- Is one of "(not checked)" if the circuit has not yet been simulated, "(in progress)" if the simulation is ongoing; "pass" if the circuit has been simulated and passed the specification for the eletrical parameter, and "fail" if it failed the specification. If the status is "pass" or "fail", this entry is a button that can be pressed to see a detailed view of the results.
7. "Simulate" --- This is a button that will initiate an ngspice simulation of the electrical parameter.

At the bottom of the window is a space for program messages, warnings, and errors. Below that is a button bar with the following buttons:

- "Close" --- Quits the characterization tool. If new results have been simulated but not saved, the user will have to respond to a prompt.
- "Save" --- Saves the current characterization results. These results will be loaded the next time the characterization tool is run, unless there is a design netlist newer than the saved results.
- "Help" --- Activates this help window.
- "Settings" --- Controls global settings for CACE.

The available settings are:

- Print debug output ---
Produce additional output for diagnostic and debugging purposes.
- Force netlist regeneration ---
Require netlists to be regenerated for every simulation. Otherwise,
netlists are only regenerated when the source file (schematic or layout)
is found to post-date the netlist.
- Allow edit of all parameters ---
Allow the use of "Simulate-->Edit", which provides a method for in-app
editing and copying of parameters (note that the characterization file
itself may always be edited).
- Simulate single-threaded ---
Normally all simulations are done multi-threaded (with low priority).
Selecting this option forces simulations to run one at a time.
- Keep simulation files ---
Normally simulation files are removed after simulation and only the
results are kept. This option forces the files to remain after
simulation.
- Do not create plot files ---
Normally plot files are generated for each plot. If this option is
selected, plots may be viewed in-app but no file is generated.
- Log simulation output ---
Copy all simulation output into a log file.


At the top of the window is the name and location of the datasheet, and on the right is a button that indicates what the source of the netlist being simulated is. The netlist source can be one of the following choices:

- **Schematic Capture**: Simulations are done from schematic
- **Layout Extracted**: Simulations are done from layout without parasitics
- **R-C Extracted**: Simulations are done from layout with parasitics

Separate results are maintained for each of these source cases. Proper sign-off characterization of a circuit should be done with a netlist from an R-C extracted layout.

### Generating a netlist


Design your project schematic in a directory called "xschem" (or the path declared for "schematic" in the characterization file) using the xschem schematic tool. See the xschem user manual and tutorials for details. The netlist is generated automatically when running simulations in CACE.

### Simulation

To simulate a single electrical parameter, click the `Simulate` button for each electrical parameter. Pressing the button creates a drop-down menu with the choices:

Run
Stop
Edit
Copy

Left-click on the selection to initiate it.

- **Run:**
This will combine the design netlist with a testbench, simulate using ngspice, collate results, and display the resulting margin values. While ngspice is running, the `Simulate` button says `(in progress)`.

- **Stop:**
If a testbench is running, then selecting "Stop" will end the simulations.

- **Edit:**
This allows a testbench definition to be edited through the GUI, to modify the conditions of simulation. Note that the characterization definition file is text and can also be modified directly with an editor. Note that parameters are not editable by default. Go to "Settings" and select "Allow edit of all parameters" to allow parameters to be edited.

- **Copy:**
This creates a new parameter that is a copy of the one selected. The new parameter can then be edited to simulate under a different set of conditions. This can also be done by directly modifying the characterization definition file with a text editor.

### Results

Every electrical parameter is specified over a range of conditions. This results in a series of simulations, usually one simulation run per unique set of conditions. Each simulation typically provides one result value, and the set of all values from all simulated conditions is used to find the minimum, typical, and maximum results that are printed on the main characterization page.

When an electrical parameter has finished simulating, clicking on the "Status" entry will generate a window showing details of the simulation. The window has one line per unique set of conditions simulated. For each line, the result value is given in the leftmost column. The remaining columns show each variable condition, and the value it had for the given simulation. The top of the column shows the range of values for the given parameter. This graph allows the user to quickly determine what are the conditions under which a circuit may be failing, and the degree to which the value is out of range of the specification. Rows in which the result is outside of the specified limit are shown in red.

In the results window, click on the title `Results` to change the view from having results ordered highest to lowest, to lowest to highest. Click on the name (column header) of any condition or variable to change the tabular view to a graph showing results vs. the selected condition or variable.

4 changes: 2 additions & 2 deletions docs/source/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,6 @@

# -- Options for HTML output -------------------------------------------------
# https://www.sphinx-doc.org/en/master/usage/configuration.html#options-for-html-output

html_theme = 'alabaster'
html_title = "CACE Documentation"
html_theme = 'furo'
html_static_path = ['_static']
15 changes: 15 additions & 0 deletions docs/source/dev/codebase.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
# Codebase

TODO information about how the codebase is structured

```
├── cace
│   ├── cace_cli.py
│   ├── cace_gui.py
│   ├── common
│   ├── doc
│   ├── gui
│   ├── __init__.py
│   ├── __main__.py
│   └── __version__.py
```
3 changes: 3 additions & 0 deletions docs/source/dev/coding_style.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
# Coding Style

As coding style for the whole codebase of CACE, ["blue"](https://github.com/grantjenks/blue) is used. It is based on ["black"](https://github.com/psf/black) and allows us to automatically lint and format the whole codebase. Before you push new code, please format the codebase using "blue".
11 changes: 11 additions & 0 deletions docs/source/dev/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
# Development

If you want to start developing CACE, please read these pages.

```{toctree}
:glob:
:maxdepth: 2
coding_style
codebase
```
Loading

0 comments on commit 34abbca

Please sign in to comment.