Open source software at SynSense: motivation, challenges and examples
Gregor Lenz
13. 12. 2022
SynSense
- Founded 2017 in Zurich
- Spin off from UZH/ETH
- Ning Qiao and Prof. Giacomo Indiveri
- Offices in Zurich, Chengdu, Shanghai
data:image/s3,"s3://crabby-images/4c6eb/4c6ebfecc480be3ff49b658a486777a46a9d1e09" alt=""
data:image/s3,"s3://crabby-images/4c6eb/4c6ebfecc480be3ff49b658a486777a46a9d1e09" alt=""
data:image/s3,"s3://crabby-images/4c6eb/4c6ebfecc480be3ff49b658a486777a46a9d1e09" alt=""
data:image/s3,"s3://crabby-images/4c6eb/4c6ebfecc480be3ff49b658a486777a46a9d1e09" alt=""
Core tech teams at SynSense
-
Hardware team: Circuit design for our chips
-
System-integration team: interface between hardware and higher-level software. Allows to configure chips
- Algorithms team: Train spiking neural networks for different tasks
Technical challenges
- Dataloading / dataset curation
- Training robust models
- Deployment to custom hardware
data:image/s3,"s3://crabby-images/305bd/305bdc36fbda5d8618cb619051b00d3c53c49a19" alt=""
Dataloading and datasets
data:image/s3,"s3://crabby-images/4ce1b/4ce1bc193e13c2658cb0023c24ec8d8430135ada" alt=""
SNN training and deployment for vision models
data:image/s3,"s3://crabby-images/a2535/a2535d2d40c5c56861cc9cfc18ca1389723d9ab0" alt=""
SNN training and deployment for audio models
data:image/s3,"s3://crabby-images/186f4/186f421bc406ef8743610e33afcb3489f990b88b" alt=""
Accelerated neuron models
rockpool.ai
sinabs.ai
tonic.readthedocs.io/
SynSense Github!
Why we write our own libraries
- We started in 2017
- The current list of features on top of PyTorch is not very long - manageable time effort
- Need high degree of control to move fast
- Features that we care about without the need for compromises
- Tailored to our hardware
Dataloading and datasets
- Dataloading is a serious bottleneck when training models
Dataloading and datasets
https://lenzgregor.com/posts/train-snns-fast/
data:image/s3,"s3://crabby-images/338c9/338c99ddb3dfaba8900d6d1a5cb6c677b81a49b7" alt=""
Dataloading and datasets
- Dataloading is a serious bottleneck when training models
- We create our own datasets - how to manage them?
- Event-based filtering / transformations
SNN training
- Anti-features: intricate neuron models, biologically-plausible learning rules
- Focus on training speed and robustness
SNN training
EXODUS: Stable and Efficient Training of Spiking Neural Networks
Bauer, Lenz, Haghighatshoar, Sheik, 2022
data:image/s3,"s3://crabby-images/a5cb8/a5cb8b98fb3a3e9064962326ee6bbf515a9aff39" alt=""
SNN training
Supervised training of spiking neural networks for robust deployment on mixed-signal neuromorphic processors
Büchel, Zendrikov, Solinas, Indiveri & Muir, 2021
data:image/s3,"s3://crabby-images/15811/15811149481d5c93192d073eb3b15fcacad4fdb3" alt=""
Model definition and deployment to Speck
import torch.nn as nn
import sinabs.layers as sl
model = nn.Sequential(
nn.Conv2d(2, 8, 3),
sl.IAF(),
nn.AvgPool2d(2),
nn.Conv2d(8, 16, 3),
sl.IAF(),
nn.AvgPool2d(2),
nn.Flatten(),
nn.Linear(128, 10),
sl.IAF(),
)
# training...
from sinabs.backend.dynapcnn import DynapcnnNetwork
dynapcnn_net = DynapcnnNetwork(
snn=model,
input_shape=(2, 30, 30)
)
dynapcnn_net.to("speck2b")
data:image/s3,"s3://crabby-images/4c6eb/4c6ebfecc480be3ff49b658a486777a46a9d1e09" alt=""
Bit-precise simulation of hardware
# model definition...
from rockpool.transform import quantize_methods as q
from rockpool.devices.xylo import config_from_specification, XyloSim
from rockpool.devices import xylo as x
# map the graph to Xylo HW architecture
spec = x.mapper(model.as_graph(), weight_dtype='float')
# quantize the parameters to Xylo HW constraints
spec.update(q.global_quantize(**spec))
xylo_conf, _, _ = config_from_specification(**spec)
XyloSim_model = XyloSim.from_confiq(xylo_conf)
data:image/s3,"s3://crabby-images/4c6eb/4c6ebfecc480be3ff49b658a486777a46a9d1e09" alt=""
Conclusions
- Our research progress is publicly available
- Neuron models are based on hardware capabilities, unfortunately no standardized neuron models
- We offer mature frameworks that are battle-tested and are open to contributions
Algorithms team
data:image/s3,"s3://crabby-images/ea4b4/ea4b4108eff70ce400533952fe26dfecb601d976" alt=""
data:image/s3,"s3://crabby-images/0d830/0d830badf729663a8e8cde197b668ce25008174c" alt=""
data:image/s3,"s3://crabby-images/4099f/4099faae69c7a389135379e8e4b764c99555aeda" alt=""
data:image/s3,"s3://crabby-images/941ac/941acc77cc24daedd7eeafabadb332f16a60a760" alt=""
data:image/s3,"s3://crabby-images/f37e4/f37e4138b8a59aa961d2013f13ad24b9dd80e1e1" alt=""
data:image/s3,"s3://crabby-images/80b11/80b11944578bcd31140c01a8757e9f4b73dcd729" alt=""
data:image/s3,"s3://crabby-images/bf9b1/bf9b1c71d259e110a62df4b17db34dcb2977cf02" alt=""
data:image/s3,"s3://crabby-images/4b2d0/4b2d084fbffdcdf5045bae4b66d12bf0fcb30872" alt=""
data:image/s3,"s3://crabby-images/c2257/c225789e2b41c28e7880897c749cbe979f3732ec" alt=""
data:image/s3,"s3://crabby-images/fa67c/fa67c4ffc5b59825ef4861fea73f28e3d6d3184d" alt=""
data:image/s3,"s3://crabby-images/408db/408db7c25f57631e937bdbd0418cd3895a779e7e" alt=""
data:image/s3,"s3://crabby-images/f8ddf/f8ddf4a149cb50ea088b8131e9c557697f84523c" alt=""
data:image/s3,"s3://crabby-images/68c1f/68c1f04fbac25c298bc0585ca13b04a178cdb56d" alt=""
data:image/s3,"s3://crabby-images/ba091/ba091dada16e039952c7ae36c4ee5eaf3b6309b2" alt=""
lenzgregor.com
Gregor Lenz
Open Neuromorphic 13.12.2022
By Gregor Lenz
Open Neuromorphic 13.12.2022
- 260