Skip to content

Latest commit

 

History

History

pollen_py

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

Proof-of-Concept Pollen Hardware Generator

This directory contains a proof-of-concept hardware accelerator generator for a simple GFA query. This section contains some guides for trying out this generator.

The Docker Image

Running the hardware generator is easy if you use our Docker image:

docker run -it --rm ghcr.io/cucapra/pollen:latest

If you prefer to install locally, we point you to the somewhat more involved instructions below.

Generating an Accelerator: Quick

If you want to compute the depth of all the nodes in the graph, the following command will generate and run a node depth accelerator:

exine depth -a -r <filename.og>

This will automatically generate a node depth accelerator whose dimensions match the input data, compute the node depth, and remove the accelerator once the computation is done.

To save the files generated from the previous command in <path>, use the --tmp-dir flag:

exine depth -a -r <filename.og> --tmpdir <path>

The node depth accelerator will be saved at <path>/<filename.futil> and the input data will be saved at <path>/<filename.data>.

Generating an Accelerator: Full Walkthrough

Take depth as an example. To generate and run a node depth accelerator for the graph k.og, first navigate to the root directory of this repository. Then run

make fetch
make test/k.og
exine depth -o depth.futil
exine depth -d test/k.og -o depth.data
exine depth -r depth.data --accelerator depth.futil

What just happened? Below, we walk through the five commands we issued above, pointing out the other options that we could have used.

First, make fetch downloads some GFA data files into the ./test directory.

Second, make test/*.og builds the odgi graph files from those GFA files.

Third, we generate the hardware accelerator and write it to a file named depth.futil. The commands to generate a node depth hardware accelerator in Calyx include:

  1. exine depth -o depth.futil
  2. exine depth -a <filename.og> -o depth.futil
  3. exine depth -n=MAX_NODES -e=MAX_STEPS -p=MAX_PATHS -o depth.futil

The commands use the hardware parameters as follows:

  1. Uses default hardware parameters.
  2. Automatically infers the hardware parameters from a .og file.
  3. Takes the hardware parameters as input.

Parameters that are specified manually take precedence over those that are inferred automatically, and it is legal to specify just a subset of parameters. For example, exine depth -a test/k.og -n=1 will infer MAX_STEPS and MAX_PATHS from test/k.og, but the resulting accelerator will only handle one node.

Fourth, we need to generate some input from our odgi file. This is what we will feed to the hardware accelerator. The following variations all accomplish this:

  1. exine depth -d <filename.og> -o depth.data
  2. exine depth -d <filename.og> -a <filename2.og> -o depth.data
  3. exine depth -d <filename.og> -n=MAX_NODES -e=MAX_STEPS -p=MAX_PATHS -o depth.data
  4. exine depth -d <filename.og> -a -o depth.data

The flags work as before, except that if no argument is passed to the -a flag, the dimensions are inferred from the input file. The dimensions of the input must be the same as that of the hardware accelerator.

Fifth, we run our hardware accelerator. The following code simulates the Calyx code for the hardware accelerator and outputs the node depth table:

exine depth -r depth.data -x depth.futil

Installing Locally

You will need Flit version 3.7.1 and Turnt version 1.11.0. We will guide you through the installation of our major dependencies, Calyx and odgi, and then show you how to install Pollen itself.

Calyx

Below we show you how to build Calyx from source and set it up for our use. If you are curious, this tracks the "installing from source" and "installing the command-line driver" sections of the Calyx documentation.

  1. git clone https://github.com/cucapra/calyx.git
  2. cd calyx
  3. cargo build
  4. flit -f fud/pyproject.toml install -s --deps production
  5. fud config --create global.root $(pwd)
  6. cargo build -p interp
  7. fud config stages.calyx.exec $(pwd)/target/debug/calyx
  8. fud config stages.interpreter.exec $(pwd)/target/debug/interp
  9. flit -f calyx-py/pyproject.toml install -s
  10. fud check

You will be warned that synth-verilog and vivado-hls were not installed correctly; this is fine for our purposes.

Odgi

We recommend that you build odgi from source, as described here. To check that this worked, run odgi from the command line.

Some parts of Pollen presently use odgi's Python bindings. You will need to edit your PYTHONPATH, as explained here, to enable this. To verify that this worked, open up a Python shell and try import odgi. If it succeeds quietly, great! If it segfaults, try the preload step explained here.

Pollen

Clone this repository:

git clone https://github.com/cucapra/pollen.git

And then install the Python tools using uv:

$ uv sync
$ source .venv/bin/activate