- Using DAM
- What is DAM?
- What can I simulate with DAM?
- Contributing
- Publications
DAM is a Rust package, currently GitHub-only (awaiting a PR merge into one of the dependencies.).
To use DAM, add the following line into your Cargo.toml
under the [dependencies]
section:
dam = {git = "https://github.com/stanford-ppl/DAM-RS.git"}
To build the documentation for DAM, run the following command inside of this repository:
cargo +nightly doc
DAM is a framework for building high-performance parallel simulators for dataflow-like systems. DAM comprises of two main components: contexts and channels. Contexts represent the "nodes" in a computational graph, while channels encapsulate the communication between nodes (the "edges").
Context
is a trait, which only requires two components:
Context::run_falliable(&mut self) -> anyhow::Result<()>
, a function which encapsulates the entirety of the execution. This enables the use of near-arbitrary code within.- A constructor of any flavor, since
#[context_macro]
introduces aContextInfo
field used internally within DAM. This is intentional, as will be discussed later.
Communication channels are represented using Sender
/Receiver
pairs (or just a single Sender
when using void channels).
In order to keep track of time, users must call Sender::attach_sender(&dyn Context)
and Receiver::attach_receiver(&dyn Context)
during the initialization phase.
We find that the constructor of a Context is the most logical place to insert these calls.
DAM can simulate anything which can be described as things connected by channels, provided that the channels have non-zero latency. Examples include:
- Hardware:
- Modeling the Sambanova SN40L
- Programming Models:
If you are interested in contributing to DAM, feel free to shoot Nathan Zhang an email at stanfurd@stanford.edu
.
@inproceedings{dam,
author={Zhang, Nathan and Lacouture, Rubens and Sohn, Gina and Mure, Paul and Zhang, Qizheng and Kjolstad, Fredrik and Olukotun, Kunle},
booktitle={2024 ACM/IEEE 51st Annual International Symposium on Computer Architecture (ISCA)},
title={The Dataflow Abstract Machine Simulator Framework},
year={2024},
volume={},
number={},
pages={532-547},
keywords={Tensors;Machine learning algorithms;Dams;Large language models;Memory management;Machine learning;Parallel processing;Parallel Discrete Event Simulation;Dataflow Accelerators;Modeling},
doi={10.1109/ISCA59077.2024.00046}}
Citation
@misc{sohn2024implementingoptimizingscaleddotproduct,
title={Implementing and Optimizing the Scaled Dot-Product Attention on Streaming Dataflow},
author={Gina Sohn and Nathan Zhang and Kunle Olukotun},
year={2024},
eprint={2404.16629},
archivePrefix={arXiv},
primaryClass={cs.AR},
url={https://arxiv.org/abs/2404.16629},
}