Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sensorsini/reneta
SystemVerilog codes for RENETA, the Delta RNN training accelerator, and the training codes (Python)
https://github.com/sensorsini/reneta
Last synced: about 2 months ago
JSON representation
SystemVerilog codes for RENETA, the Delta RNN training accelerator, and the training codes (Python)
- Host: GitHub
- URL: https://github.com/sensorsini/reneta
- Owner: SensorsINI
- License: mit
- Created: 2024-01-31T20:04:55.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2024-03-23T10:04:04.000Z (10 months ago)
- Last Synced: 2024-06-19T03:42:43.452Z (7 months ago)
- Language: SystemVerilog
- Size: 1.69 MB
- Stars: 1
- Watchers: 4
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# RENETA - Recurrent Neural Network Training Accelerator with Temporal Sparsity
This repo mainly contains:
- Source codes (SystemVerilog) for RENETA, the Delta RNN training accelerator
- Training codes (Python) for the Delta RNN training algorithm, published at NeurIPS Workshop MLNCP 2023 and AAAI 2024# Project Structure
```
.
└── DeltaRNN_IL # Pytorch codes for training experiments, based on this repo https://github.com/gaochangw/DeltaRNN
├── project.py # A class defining all major training functions and stores hyperparameters
└── main.py # Main
└── DTv1_perf_estm # Pytorch codes for generating data for the performance estimation in the testbench
└── gen_rnd_data_rnn.py # Generate random input of specified sparsity for the testbench
└── HDL # HDL codes for RENETA accelerator
├── dtv1.sv # Top module, DTV1 is the internal code of RENETA
├── dtv1_bram_sdp.sv # Simple Dual-Port (1R1W) BRAM
├── dtv1_bram_sp.sv # Single Port BRAM
├── dtv1_ccm.sv # CCM (Compute Core Module)
├── dtv1_dmx.sv # IPM - Data Channel Multiplexer
├── dtv1_drg.sv # IPM - DRAM Request Generator
├── dtv1_fifo.sv # General parameterized FIFO
├── dtv1_macc_fp.sv # PE array (Floating-Point)
├── dtv1_macc_fxp.sv # PE array (Fixed-Point)
├── dtv1_tb.sv # Testbench for simulation
├── dtv1_pkg.sv # Package for common data types
├── dtv1_smem_fifo.sv # SMEM - FIFO
├── dtv1_smem.sv # SMEM (Shared Memory)
├── dtv1_spm.sv # Sparse Data Descriptor Memory
├── dtv1_srg0.sv # IPM - SMEM Request Generator CH0
└── dtv1_srg.sv # IPM - SMEM Request Generator CH1-2
├── DTv1_BD.pptx # Block diagrams of RENETA
└── DTv1_ISA.xlsx # Description of RENETA ISA
```# Reference
If you find this repository helpful, please cite our work.
- [AAAI 2024] Exploiting Symmetric Temporally Sparse BPTT for Efficient RNN Training
```
@inproceedings{
Chen2024AAAI,
title={Exploiting Symmetric Temporally Sparse {BPTT} for Efficient {RNN} Training},
author={Xi Chen and Chang Gao and Zuowen Wang and Longbiao Cheng and Sheng Zhou and Shih-Chii Liu and Tobi Delbruck},
booktitle={The 38th Annual AAAI Conference on Artificial Intelligence},
year={2024},
}
```
- [NeurIPS Workshop MLNCP 2023] Exploiting Symmetric Temporally Sparse BPTT for Efficient RNN Training
```
@inproceedings{
Chen2023MLNCP,
title={Exploiting Symmetric Temporally Sparse {BPTT} for Efficient {RNN} Training},
author={Xi Chen and Chang Gao and Zuowen Wang and Longbiao Cheng and Sheng Zhou and Shih-Chii Liu and Tobi Delbruck},
booktitle={Machine Learning with New Compute Paradigms},
year={2023},
url={https://openreview.net/forum?id=2zXPCHKt6C}
}
```