Stochastic Computing Architectures: Modeling, Optimization, and Applications
Abstract
1. Introduction
1.1. Existing Surveys on SC
1.2. Motivation for This Survey
1.3. Contributions of This Survey
- Analyze the basic network topology and functional units of SC and NN, and summarize the existing limitations of SC.
- Analyze the common scenarios of SC-NN, such as network accelerator, image processing, and edge deployment.
- Summarize the hardware deployments of SC-NNs and comprehensively compare them.
- Explore the challenges and issues to be addressed for the future of SC.
2. Stochastic Computing
2.1. Origin of SC
2.2. Basic Unit of SC
2.2.1. SC Multiplier
2.2.2. SC Adder
2.2.3. SC Divider
2.2.4. Stochastic Number Generators (SNGs)
2.2.5. Correlation Strategy
2.3. Limitations of SC
3. SC-NN
3.1. SC Neuron
3.2. SC Activation Function Circuit
3.3. SC-NN Architecture
3.3.1. SC-ANN
3.3.2. SC-DNN
3.3.3. SC-CNN
3.3.4. SC-RNN
3.3.5. SC-SNN
4. Application of Stochastic Computing to Neural Networks
4.1. Network Accelerator
4.2. Image Processing
4.3. Edge Deployment
5. Network Accuracy and Hardware Energy Efficiency in SC-NNs
5.1. Network Accuracy
5.2. Hardware Efficiency
6. Directions and Challenges of SC
6.1. Stochastic Number Generators (SNGs)
6.2. Computational Accuracy and Latency Strategies
6.3. Optimization of Neural Networks
6.4. Integrated Circuit Design Optimization
7. Conclusions
Author Contributions
Funding
Data Availability Statement
Conflicts of Interest
References
- Burger, W.; Burge, M.J. Digital Image Processing: An Algorithmic Introduction; Springer Nature: Berlin/Heidelberg, Germany, 2022. [Google Scholar]
- Bailey, D.G. Design for Embedded Image Processing on FPGAs; John Wiley & Sons: Hoboken, NJ, USA, 2023. [Google Scholar]
- Zhao, J.; Zhao, W.; Deng, B.; Wang, Z.; Zhang, F.; Zheng, W.; Cao, W.; Nan, J.; Lian, Y.; Burke, A.F. Autonomous driving system: A comprehensive survey. Expert Syst. Appl. 2023, 242, 122836. [Google Scholar] [CrossRef]
- Teng, S.; Hu, X.; Deng, P.; Li, B.; Li, Y.; Ai, Y.; Yang, D.; Li, L.; Xuanyuan, Z.; Zhu, F.; et al. Motion planning for autonomous driving: The state of the art and future perspectives. IEEE Trans. Intell. Veh. 2023, 8, 3692–3711. [Google Scholar] [CrossRef]
- Li, J. Recent advances in end-to-end automatic speech recognition. Apsipa Trans. Signal Inf. Process. 2022, 11, e8. [Google Scholar] [CrossRef]
- Dhanjal, A.S.; Singh, W. A comprehensive survey on automatic speech recognition using neural networks. Multimed. Tools Appl. 2024, 83, 23367–23412. [Google Scholar] [CrossRef]
- Feng, S.; Halpern, B.M.; Kudina, O.; Scharenborg, O. Towards inclusive automatic speech recognition. Comput. Speech Lang. 2024, 84, 101567. [Google Scholar] [CrossRef]
- Da Silva, I.N.; Hernane Spatti, D.; Andrade Flauzino, R.; Liboni, L.H.B.; dos Reis Alves, S.F.; da Silva, I.N.; Hernane Spatti, D.; Andrade Flauzino, R.; Liboni, L.H.B.; dos Reis Alves, S.F. Artificial Neural Network Architectures and Training Processes; Springer: Cham, Switzerland, 2017. [Google Scholar]
- Hassaballah, M.; Awad, A.I. Deep Learning in Computer Vision: Principles and Applications; CRC Press: Boca Raton, FL, USA, 2020. [Google Scholar]
- Aggarwal, C.C. Neural Networks and Deep Learning; Springer: Heidelberg, Germany, 2018; Volume 10. [Google Scholar]
- Gerstner, W.; Kistler, W.M. Spiking Neuron Models: Single Neurons, Populations, Plasticity; Cambridge University Press: Cambridge, UK, 2002. [Google Scholar]
- Hertz, J.A. Introduction to the Theory of Neural Computation; CRC Press: Boca Raton, FL, USA, 2018. [Google Scholar]
- Alaghi, A.; Hayes, J.P. Survey of stochastic computing. Acm Trans. Embed. Comput. Syst. 2013, 12, 1–19. [Google Scholar] [CrossRef]
- Liu, S.; Rosselló, J.L.; Liu, S.; Tang, X.; Font-Rosselló, J.; Frasser, C.F.; Qian, W.; Han, J.; Reviriego, P.; Lombardi, F. From Multipliers to Integrators: A Survey of Stochastic Computing Primitives. IEEE Trans. Nanotechnol. 2024, 23, 238–249. [Google Scholar] [CrossRef]
- Alaghi, A.; Qian, W.; Hayes, J.P. The promise and challenge of stochastic computing. IEEE Trans.-Comput.-Aided Des. Integr. Circuits Syst. 2017, 37, 1515–1531. [Google Scholar] [CrossRef]
- Lee, Y.Y.; Halim, Z.A. Stochastic computing in convolutional neural network implementation: A review. PeerJ Comput. Sci. 2020, 6, e309. [Google Scholar] [CrossRef]
- Morán, A.; Parrilla, L.; Roca, M.; Font-Rossello, J.; Isern, E.; Canals, V. Digital implementation of radial basis function neural networks based on stochastic computing. IEEE J. Emerg. Sel. Top. Circuits Syst. 2022, 13, 257–269. [Google Scholar] [CrossRef]
- Li, P.; Qian, W.; Riedel, M.D.; Bazargan, K.; Lilja, D.J. The synthesis of linear finite state machine-based stochastic computational elements. In Proceedings of the 17th Asia and South Pacific Design Automation Conference, Sydney, Australia, 30 January–2 February 2012; IEEE: Piscataway, NJ, USA, 2012; pp. 757–762. [Google Scholar]
- Cai, B.; He, Y.; Xin, Y.; Yuan, Z.; Zhang, X.; Zhu, Z.; Liang, G. Unconventional computing based on magnetic tunnel junction. Appl. Phys. A 2023, 129, 236. [Google Scholar] [CrossRef]
- Aygun, S.; Kouhalvandi, L.; Najafi, M.H.; Ozoguz, S.; Gunes, E.O. Hardware-software co-optimization of long-latency stochastic computing. IEEE Embed. Syst. Lett. 2023, 15, 190–193. [Google Scholar] [CrossRef]
- Yang, J.; Graening, A.; Romaszkan, W.; Jacob, V.K.; Gupta, P.; Pamarti, S. A 278-514M Event/s ADC-Less Stochastic Compute-In-Memory Convolution Accelerator for Event Camera. In Proceedings of the 2024 IEEE Symposium on VLSI Technology and Circuits (VLSI Technology and Circuits), Honolulu, HI, USA, 16–20 June 2024; IEEE: Piscataway, NJ, USA, 2024; pp. 1–2. [Google Scholar]
- Li, T.; Romaszkan, W.; Pamarti, S.; Gupta, P. REX-SC: Range-extended stochastic computing accumulation for neural network acceleration. IEEE Trans.-Comput.-Aided Des. Integr. Circuits Syst. 2023, 42, 4423–4435. [Google Scholar] [CrossRef]
- Wang, D.; Wang, Z.; Yu, L.; Wu, Y.; Yang, J.; Mei, K.; Wang, J. A Survey of Stochastic Computing in Energy-Efficient DNNs On-Edge. In Proceedings of the 2021 IEEE Intl Conf on Parallel & Distributed Processing with Applications, Big Data & Cloud Computing, Sustainable Computing & Communications, Social Computing & Networking (ISPA/BDCloud/SocialCom/SustainCom), New York City, NY, USA, 30 September–3 October 2021; IEEE: Piscataway, NJ, USA, 2021; pp. 1554–1561. [Google Scholar]
- Chen, L.; Xiong, X.; Liu, J. A survey of intelligent chip design research based on spiking neural networks. IEEE Access 2022, 10, 89663–89686. [Google Scholar] [CrossRef]
- Liu, Y.; Liu, S.; Wang, Y.; Lombardi, F.; Han, J. A survey of stochastic computing neural networks for machine learning applications. IEEE Trans. Neural Netw. Learn. Syst. 2020, 32, 2809–2824. [Google Scholar] [CrossRef]
- Poppelbaum, W.; Afuso, C.; Esch, J. Stochastic computing elements and systems. In Proceedings of the Fall Joint Computer Conference, Anaheim, CA, USA, 14–16 November 1967; pp. 635–644. [Google Scholar]
- Gaines, B.R. Stochastic computing systems. Adv. Inf. Syst. Sci. 1969, 2, 37–172. [Google Scholar]
- Brown, B.D.; Card, H.C. Stochastic neural computation. I. Computational elements. IEEE Trans. Comput. 2001, 50, 891–905. [Google Scholar] [CrossRef]
- Waho, T.; Koyama, A.; Hayashi, H. Delta-Sigma Domain Signal Processing Revisited with Related Topics in Stochastic Computing. Ieice Trans. Inf. Syst. 2024, 107, 966–975. [Google Scholar] [CrossRef]
- Lin, Z.; Xie, G.; Wang, S.; Han, J.; Zhang, Y. A review of deterministic approaches to stochastic computing. In Proceedings of the 2021 IEEE/ACM International Symposium on Nanoscale Architectures (NANOARCH), Vancouver, BC, Canada, 8–10 November 2021; IEEE: Piscataway, NJ, USA, 2021; pp. 1–6. [Google Scholar]
- Gaines, B.R. R68-18 random pulse machines. IEEE Trans. Comput. 1968, 100, 410. [Google Scholar] [CrossRef]
- Von Neumann, J. Probabilistic logics and the synthesis of reliable organisms from unreliable components. Autom. Stud. 1956, 34, 43–98. [Google Scholar]
- Poppelbaum, W. Statistical processors. In Advances in Computers; Elsevier: Amsterdam, The Netherlands, 1976; Volume 14, pp. 187–230. [Google Scholar]
- Jeavons, P.; Cohen, D.A.; Shawe-Taylor, J. Generating binary sequences for stochastic computing. IEEE Trans. Inf. Theory 1994, 40, 716–720. [Google Scholar] [CrossRef][Green Version]
- Kim, Y.C.; Shanblatt, M.A. Architecture and statistical model of a pulse-mode digital multilayer neural network. IEEE Trans. Neural Netw. 1995, 6, 1109–1118. [Google Scholar] [PubMed]
- Gu, Y.; Li, H. Enhancing the Decoding of Short LDPC Codes with Stochastic Sequences. Master’s Thesis, Lund University, Lund, Sweden, 2021. [Google Scholar]
- Mou, D.; Wang, B.; Liu, D. SC-CGRA: An Energy-Efficient CGRA Using Stochastic Computing. IEEE Trans. Parallel Distrib. Syst. 2024, 35, 2023–2038. [Google Scholar] [CrossRef]
- Nobari, M.; Jahanirad, H. FPGA-based implementation of deep neural network using stochastic computing. Appl. Soft Comput. 2023, 137, 110166. [Google Scholar] [CrossRef]
- Xiao, S.; Liu, W.; Guo, Y.; Yu, Z. Low-cost adaptive exponential integrate-and-fire neuron using stochastic computing. IEEE Trans. Biomed. Circuits Syst. 2020, 14, 942–950. [Google Scholar] [CrossRef]
- Xie, T.; Hu, Y.; Wei, R.; Li, M.; Wang, Y.; Wang, R.; Huang, R. ASCEND: Accurate yet Efficient End-to-End Stochastic Computing Acceleration of Vision Transformer. In Proceedings of the 2024 Design, Automation & Test in Europe Conference & Exhibition (DATE), Valencia, Spain, 25–27 March 2024; IEEE: Piscataway, NJ, USA, 2024; pp. 1–6. [Google Scholar]
- Lee, V.T.; Alaghi, A.; Pamula, R.; Sathe, V.S.; Ceze, L.; Oskin, M. Architecture considerations for stochastic computing accelerators. IEEE Trans.-Comput.-Aided Des. Integr. Circuits Syst. 2018, 37, 2277–2289. [Google Scholar] [CrossRef]
- Vatsavai, S.S.; Karempudi, V.S.P.; Thakkar, I.; Salehi, A.; Hastings, T. Sconna: A stochastic computing based optical accelerator for ultra-fast, energy-efficient inference of integer-quantized cnns. In Proceedings of the 2023 IEEE International Parallel and Distributed Processing Symposium (IPDPS), Lyon, France, 30 May–3 June 2022; IEEE: Piscataway, NJ, USA, 2023; pp. 546–556. [Google Scholar]
- Li, M.; Hu, Y.; Zhang, T.; Wei, R.; Zhang, Y.; Huang, R.; Wang, R. Efficient yet Accurate End-to-End SC Accelerator Design. arXiv 2024, arXiv:2401.15332. [Google Scholar]
- Jia, X.; Gu, H.; Liu, Y.; Yang, J.; Wang, X.; Pan, W.; Zhang, Y.; Cotofana, S.; Zhao, W. An energy-efficient Bayesian neural network implementation using stochastic computing method. IEEE Trans. Neural Netw. Learn. Syst. 2023, 35, 12913–12923. [Google Scholar] [CrossRef] [PubMed]
- El-Derhalli, H.; Le Beux, S.; Tahar, S. Design space exploration of stochastic computing architectures implemented using integrated optics. IEEE Trans. Emerg. Top. Comput. 2020, 9, 2158–2169. [Google Scholar] [CrossRef]
- Liu, S.; Gross, W.J.; Han, J. Introduction to dynamic stochastic computing. IEEE Circuits Syst. Mag. 2020, 20, 19–33. [Google Scholar] [CrossRef]
- Qian, W. Digital Yet Deliberately Random: Synthesizing Logical Computation on Stochastic Bit Streams; University of Minnesota: Minneapolis, MN, USA, 2011. [Google Scholar]
- Riahi Alam, M.; Najafi, M.H.; TaheriNejad, N.; Imani, M.; Peng, L. Stochastic Computing for Reliable Memristive In-Memory Computation. In Proceedings of the Great Lakes Symposium on VLSI 2023, Knoxville, TN, USA, 5–7 June 2023; pp. 397–401. [Google Scholar]
- Li, J.; Yuan, Z.; Li, Z.; Ren, A.; Ding, C.; Draper, J.; Nazarian, S.; Qiu, Q.; Yuan, B.; Wang, Y. Normalization and dropout for stochastic computing-based deep convolutional neural networks. Integration 2019, 65, 395–403. [Google Scholar] [CrossRef]
- Li, B.; Qin, Y.; Yuan, B.; Lilja, D.J. Neural network classifiers using a hardware-based approximate activation function with a hybrid stochastic multiplier. ACM J. Emerg. Technol. Comput. Syst. 2019, 15, 1–21. [Google Scholar] [CrossRef]
- Song, Y.; Li, H.; Zhu, X.; Chen, Y. Design of Multiplier Circuit Based on Signed-Digit Hybrid Stochastic Computing. In Proceedings of the 2024 IEEE Computer Society Annual Symposium on VLSI (ISVLSI), Knoxville, TN, USA, 1–3 July 2024; IEEE: Piscataway, NJ, USA, 2024; pp. 57–62. [Google Scholar]
- Hussein, A.K.; Artan, N.S. Low-Latency Deterministic Multiplier for Stochastic Computing. In Proceedings of the 2024 IEEE 67th International Midwest Symposium on Circuits and Systems (MWSCAS), Springfield, MA, USA, 11–14 August 2024; IEEE: Piscataway, NJ, USA, 2024; pp. 272–276. [Google Scholar]
- Chu, S.I. New divider design for stochastic computing. IEEE Trans. Circuits Syst. II Express Briefs 2019, 67, 147–151. [Google Scholar] [CrossRef]
- Liu, Y.; Yu, S.; Tasnim, M.; Tan, S.X.D. Fast and Scaled Counting-Based Stochastic Computing Divider Design. IEEE Trans.-Comput.-Aided Des. Integr. Circuits Syst. 2024, 43, 2277–2287. [Google Scholar]
- Salehi, S.A. Low-cost stochastic number generators for stochastic computing. IEEE Trans. Very Large Scale Integr. Syst. 2020, 28, 992–1001. [Google Scholar] [CrossRef]
- Knag, P.; Lu, W.; Zhang, Z. A native stochastic computing architecture enabled by memristors. IEEE Trans. Nanotechnol. 2014, 13, 283–293. [Google Scholar] [CrossRef]
- Temenos, N.; Ntinas, V.; Sotiriadis, P.P.; Sirakoulis, G.C. Time-based Memristor Crossbar Array Programming for Stochastic Computing Parallel Sequence Generation. In Proceedings of the 2023 IEEE International Symposium on Circuits and Systems (ISCAS), Monterey, CA, USA, 21–25 May 2023; IEEE: Piscataway, NJ, USA, 2023; pp. 1–5. [Google Scholar]
- Yang, B.; Chen, T.; Chen, A.; Duan, S.; Wang, L. A lightweight cnn based on memristive stochastic computing for electronic nose. Int. J. Bifurc. Chaos 2024, 34, 2450027. [Google Scholar] [CrossRef]
- Liu, S.; Han, J. Toward energy-efficient stochastic circuits using parallel Sobol sequences. IEEE Trans. Very Large Scale Integr. Syst. 2018, 26, 1326–1339. [Google Scholar] [CrossRef]
- Hu, J.; Li, B.; Ma, C.; Lilja, D.; Koester, S.J. Spin-hall-effect-based stochastic number generator for parallel stochastic computing. IEEE Trans. Electron. Devices 2019, 66, 3620–3627. [Google Scholar] [CrossRef]
- Frasser, C.F.; Linares-Serrano, P.; de los Ríos, I.D.; Morán, A.; Skibinsky-Gitlin, E.S.; Font-Rosselló, J.; Canals, V.; Roca, M.; Serrano-Gotarredona, T.; Rosselló, J.L. Fully parallel stochastic computing hardware implementation of convolutional neural networks for edge computing applications. IEEE Trans. Neural Netw. Learn. Syst. 2022, 34, 10408–10418. [Google Scholar] [CrossRef] [PubMed]
- Chen, Z.; Ma, Y.; Wang, Z. Hybrid stochastic-binary computing for low-latency and high-precision inference of CNNs. IEEE Trans. Circuits Syst. I Regul. Pap. 2022, 69, 2707–2720. [Google Scholar] [CrossRef]
- Liu, Y.; Liu, S.; Wang, Y.; Lombardi, F.; Han, J. A stochastic computational multi-layer perceptron with backward propagation. IEEE Trans. Comput. 2018, 67, 1273–1286. [Google Scholar] [CrossRef]
- Li, P.; Lilja, D.J.; Qian, W.; Riedel, M.D.; Bazargan, K. Logical computation on stochastic bit streams with linear finite-state machines. IEEE Trans. Comput. 2012, 63, 1474–1486. [Google Scholar] [CrossRef]
- Li, J.; Yuan, Z.; Li, Z.; Ding, C.; Ren, A.; Qiu, Q.; Draper, J.; Wang, Y. Hardware-driven nonlinear activation for stochastic computing based deep convolutional neural networks. In Proceedings of the 2017 International Joint Conference on Neural Networks (IJCNN), Anchorage, AK, USA, 14–19 May 2017; IEEE: Piscataway, NJ, USA, 2017; pp. 1230–1236. [Google Scholar]
- Chen, K.C.J.; Syu, W.R. High Reliable and Accurate Stochastic Computing-based Artificial Neural Network Architecture Design. In Proceedings of the 2024 IEEE International Symposium on Circuits and Systems (ISCAS), Singapore, 19–22 May 2024; IEEE: Piscataway, NJ, USA, 2024; pp. 1–5. [Google Scholar]
- Varadharajan, S.K.; Nallasamy, V. P-SCADA-a novel area and energy efficient FPGA architectures for LSTM prediction of heart arrthymias in BIoT applications. Expert Syst. 2022, 39, e12687. [Google Scholar] [CrossRef]
- Li, Z.; Li, J.; Ren, A.; Cai, R.; Ding, C.; Qian, X.; Draper, J.; Yuan, B.; Tang, J.; Qiu, Q.; et al. HEIF: Highly efficient stochastic computing-based inference framework for deep neural networks. IEEE Trans.-Comput.-Aided Des. Integr. Circuits Syst. 2018, 38, 1543–1556. [Google Scholar] [CrossRef]
- Li, B.; Najafi, M.H.; Lilja, D.J. An FPGA implementation of a restricted boltzmann machine classifier using stochastic bit streams. In Proceedings of the 2015 IEEE 26th International Conference on Application-Specific Systems, Architectures and Processors (ASAP), Toronto, ON, Canada, 27–29 July 2015; IEEE: Piscataway, NJ, USA, 2015; pp. 68–69. [Google Scholar]
- Chen, K.C.; Wu, C.H. High-accurate stochastic computing for artificial neural network by using extended stochastic logic. In Proceedings of the 2021 IEEE International Symposium on Circuits and Systems (ISCAS), Daegu, Republic of Korea, 22–28 May 2021; IEEE: Piscataway, NJ, USA, 2021; pp. 1–4. [Google Scholar]
- Chen, K.C.J.; Chen, C.T. High-accuracy and Low-latency Hybrid Stochastic Computing for Artificial Neural Network. In Proceedings of the 2021 18th International SoC Design Conference (ISOCC), Jeju, Republic of Korea, 6–9 October 2021; IEEE: Piscataway, NJ, USA, 2021; pp. 254–255. [Google Scholar]
- Xia, Z.; Chen, J.; Huang, Q.; Luo, J.; Hu, J. Neural synaptic plasticity-inspired computing: A high computing efficient deep convolutional neural network accelerator. IEEE Trans. Circuits Syst. I Regul. Pap. 2020, 68, 728–740. [Google Scholar] [CrossRef]
- Li, W.; Xu, N.; Wang, R.; He, G. Efficient compression methods for wire-spread-based stochastic computing deep neural networks. IEEE Trans. Circuits Syst. I Express Briefs 2022, 69, 4538–4542. [Google Scholar] [CrossRef]
- Xiong, H.; He, G. Hardware implementation of an improved stochastic computing based deep neural network using short sequence length. IEEE Trans. Circuits Syst. I Express Briefs 2020, 67, 2667–2671. [Google Scholar] [CrossRef]
- Wang, Z.; Jia, Z.; Shen, Z.; Zhao, Y.; Chen, R. Optimization for deep convolutional neural network of stochastic computing on MLC-PCM-based system. Microprocess. Microsyst. 2022, 90, 104505. [Google Scholar] [CrossRef]
- Song, Y.; Sha, E.H.M.; Zhuge, Q.; Xu, R.; Xu, X.; Li, B.; Yang, L. Hardware-aware neural architecture search for stochastic computing-based neural networks on tiny devices. J. Syst. Archit. 2023, 135, 102810. [Google Scholar] [CrossRef]
- Abdellatef, H.; Khalil-Hani, M.; Shaikh-Husin, N.; Ayat, S.O. Accurate and compact convolutional neural network based on stochastic computing. Neurocomputing 2022, 471, 31–47. [Google Scholar] [CrossRef]
- Li, J.; Ren, A.; Li, Z.; Ding, C.; Yuan, B.; Qiu, Q.; Wang, Y. Towards acceleration of deep convolutional neural networks using stochastic computing. In Proceedings of the 2017 22nd Asia and South Pacific Design Automation Conference (ASP-DAC), Chiba/Tokyo, Japan, 16–19 January 2017; IEEE: Piscataway, NJ, USA, 2017; pp. 115–120. [Google Scholar]
- Ren, A.; Li, Z.; Ding, C.; Qiu, Q.; Wang, Y.; Li, J.; Qian, X.; Yuan, B. Sc-dcnn: Highly-scalable deep convolutional neural network using stochastic computing. ACM Sigplan Not. 2017, 52, 405–418. [Google Scholar] [CrossRef]
- Yu, J.; Kim, K.; Lee, J.; Choi, K. Accurate and efficient stochastic computing hardware for convolutional neural networks. In Proceedings of the 2017 IEEE International Conference on Computer Design (ICCD), Boston, MA, USA, 5–8 November 2017; IEEE: Piscataway, NJ, USA, 2017; pp. 105–112. [Google Scholar]
- Li, S.; Wang, Q.; Liu, X.; Chen, J. Low cost LSTM implementation based on stochastic computing for channel state information prediction. In Proceedings of the 2018 IEEE Asia Pacific Conference on Circuits and Systems (APCCAS), Chengdu, China, 26–30 October 2018; IEEE: Piscataway, NJ, USA, 2018; pp. 231–234. [Google Scholar]
- Maor, G.; Zeng, X.; Wang, Z.; Hu, Y. An FPGA implementation of stochastic computing-based LSTM. In Proceedings of the 2019 IEEE 37th International Conference on Computer Design (ICCD), Abu Dhabi, United Arab Emirates, 17–20 November 2019; IEEE: Piscataway, NJ, USA, 2019; pp. 38–46. [Google Scholar]
- Sengupta, R.; Polian, I.; Hayes, J.P. Stochastic computing architectures for lightweight LSTM neural networks. In Proceedings of the 2022 25th International Symposium on Design and Diagnostics of Electronic Circuits and Systems (DDECS), Prague, Poland, 6–8 April 2022; IEEE: Piscataway, NJ, USA, 2022; pp. 124–129. [Google Scholar]
- Liu, Y.; Liu, L.; Lombardi, F.; Han, J. An energy-efficient and noise-tolerant recurrent neural network using stochastic computing. IEEE Trans. Very Large Scale Integr. Syst. 2019, 27, 2213–2221. [Google Scholar] [CrossRef]
- Smithson, S.C.; Boga, K.; Ardakani, A.; Meyer, B.H.; Gross, W.J. Stochastic computing can improve upon digital spiking neural networks. In Proceedings of the 2016 IEEE International Workshop on Signal Processing Systems (SiPS), Dallas, TX, USA, 26–28 October 2016; IEEE: Piscataway, NJ, USA, 2016; pp. 309–314. [Google Scholar]
- Liu, J.; Wang, Y.; Luo, Y.; Zhang, S.; Jiang, D.; Hua, Y.; Qin, S.; Yang, S. Hardware Spiking Neural Networks with Pair-Based STDP Using Stochastic Computing. Neural Process. Lett. 2023, 55, 7155–7173. [Google Scholar] [CrossRef]
- Song, Z.; Katti, P.; Simeone, O.; Rajendran, B. Stochastic Spiking Attention: Accelerating Attention with Stochastic Computing in Spiking Networks. arXiv 2024, arXiv:2402.09109. [Google Scholar]
- Chen, Z.; Ma, Y.; Wang, Z. Optimizing stochastic computing for low latency inference of convolutional neural networks. In Proceedings of the 39th International Conference on Computer-Aided Design, Storrs, CT, USA, 2–5 November 2020; pp. 1–7. [Google Scholar]
- Sim, H.; Kenzhegulov, S.; Lee, J. DPS: Dynamic precision scaling for stochastic computing-based deep neural networks. In Proceedings of the 55th Annual Design Automation Conference, San Francisco, CA, USA, 24–29 June 2018; pp. 1–6. [Google Scholar]
- Hojabr, R.; Givaki, K.; Tayaranian, S.R.; Esfahanian, P.; Khonsari, A.; Rahmati, D.; Najafi, M.H. SkippyNN: An embedded stochastic-computing accelerator for convolutional neural networks. In Proceedings of the 56th Annual Design Automation Conference 2019, Las Vegas, Nevada, USA, 2–6 June 2019; pp. 1–6. [Google Scholar]
- Wu, D.; Li, J.; Yin, R.; Hsiao, H.; Kim, Y.; San Miguel, J. UGEMM: Unary computing architecture for GEMM applications. In Proceedings of the 2020 ACM/IEEE 47th Annual International Symposium on Computer Architecture (ISCA), Virtual Event, 30 May–3 June 2020; IEEE: Piscataway, NJ, USA, 2020; pp. 377–390. [Google Scholar]
- Romaszkan, W.; Li, T.; Gupta, P. SASCHA—Sparsity-aware stochastic computing hardware architecture for neural network acceleration. IEEE Trans.-Comput.-Aided Des. Integr. Circuits Syst. 2022, 41, 4169–4180. [Google Scholar] [CrossRef]
- Frasser, C.F.; Linares-Serrano, P.; Morán, A.; Font-Rosselló, J.; Canals, V.; Roca, M.; Serrano-Gotarredona, T.; Rosselló, J.L. Exploiting correlation in stochastic computing based deep neural networks. In Proceedings of the 2021 XXXVI Conference on Design of Circuits and Integrated Systems (DCIS), Vila do Conde, Portugal, 24–26 November 2021; IEEE: Piscataway, NJ, USA, 2021; pp. 1–6. [Google Scholar]
- LeCun, Y.; Bottou, L.; Bengio, Y.; Haffner, P. Gradient-based learning applied to document recognition. Proc. IEEE 1998, 86, 2278–2324. [Google Scholar] [CrossRef]
- Krizhevsky, A.; Sutskever, I.; Hinton, G.E. Imagenet classification with deep convolutional neural networks. Adv. Neural Inf. Process. Syst. 2012, 25, 1–9. [Google Scholar] [CrossRef]












































| Reference | Theory | Components | ANN | DNN | CNN | RNN | SNN | Focus | 
|---|---|---|---|---|---|---|---|---|
| Wang et al. [23] | ✓ | ✓ | ✓ | Edge Intelligent Device Deployment | ||||
| Chen et al. [24] | ✓ | ✓ | ✓ | Spiking Neural Networks chip design | ||||
| Liu et al. [25] | ✓ | ✓ | ✓ | ✓ | ✓ | Applications in Machine Learning | ||
| Poppelbaum et al. [26] | ✓ | Discussion of SC circuits | ||||||
| Lee et al. [16] | ✓ | ✓ | ✓ | Hardware Deployment of CNN | ||||
| Gaines et al. [27] | ✓ | ✓ | SC Theory and Component Analysis | |||||
| Brown et al. [28] | ✓ | ✓ | ANN use SC elements | |||||
| Alaghi et al. [13] | ✓ | ✓ | Advantages and disadvantages of SC circuits | |||||
| Liu et al. [14] | ✓ | ✓ | Multipliers to Integrators | |||||
| Alaghi et al. [15] | ✓ | ✓ | ✓ | ✓ | SC Inherent properties and application scenarios | |||
| Waho et al. [29] | ✓ | Signal Processing of Modulated Bitstreams | ||||||
| Lin et al. [30] | ✓ | Deterministic SC methods and related designs | ||||||
| Our survey | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | Analysis and comparison of various SC-NN | 
| Period | Reference | Contributions | 
|---|---|---|
| 1956 | [32] | Fundamental concepts of probabilistic logic design | 
| 1960–1979 | [27,31] [33] | Definition of SC and introduction to basic concepts Construction of a general-purpose SC computer | 
| 1980–1999 | [34] [35] | Optimization of SC theory Studies of special applications of SC | 
| 2000–persent | [36] [37,38,39,40] [41,42,43,44] [14] [45] | Decoding of LDPC, Wireless communication Edge deployment Neural network accelerator Nanosclae integrated circuit optimization Image processing | 
| Format | Value | Ranges | Relation to Unipolar Value | 
|---|---|---|---|
| ine Unipolar (UP) | |||
| Bipolar (BP) | |||
| Inverted Bipolar (IBP) | |||
| Specific value | 
| SC Adder | Input/Output Method | Area Efficiency | Accuracy | 
| or-gate | Dual inputs and single output | highest | lowest | 
| MUX | three inputs and single output | middle | middle | 
| AxPC | Multiple inputs and multiple outputs | lowest | highest | 
| Reference | Application Scenarios | Methods | Performances | 
|---|---|---|---|
| Lee et al. [41] | embedded system | Introducing SC accelerator | VOS increases energy efficiency up to 1.9× | 
| Li et al. [43] | SOTA models | Deterministic coding | SC NN-based processor area efficiency increased by 4.2× | 
| Vatsavai et al. [42] | Optics | Optical stochastic multiplier | SCONNA throughput increased by 66.5× | 
| Chen et al. [62] | CNN accelerator | SBC MAC Unit | CNN accelerator with SBC-MAC arrays reduces area by 44% | 
| Li et al. [81] | communications | FSM generation of activation functions | SC-LSTM reduces the hardware cost by about 70% | 
| Maor et al. [82] | IoT systems | SC-LSTM architecture | 73.24% lower power consumption than conventional LSTM | 
| Jia et al [44]. | embedded system | asynchronous parallel pipeline calculation technique | Increased computational speed by 3× | 
| Romaszkan et al. [92] | machine learning | Weighted bit slicing technique | SASCHA throughput increase of 1.75× | 
| Contributions | DPS [89] | SkippyNN [90] | HEIF [68] | uGEMM [91] | SBC [62] | 
|---|---|---|---|---|---|
| Benchmark | VGG_Small | VGG16 | AlexNet | MLP | VGG16 | 
| Dataset | ImageNet | ImageNet | ImageNet | MNIST | ImageNet | 
| Quantization | 9∼10-bit | 12-bit | 8-bit | 8-bit | 8-bit | 
| Accuracy (%) | 82.47 (top 5) | 90 (top 5) | 79.46 (top 5) | 94.7 (top 1) | 90.20 (top 5) | 
| Scope | 256 MAC units | 3 × 3 filter | All layers | 16 × 16 GEMM | 256 MAC units | 
| Technology | 45 nm | 45 nm | 45 nm | 45 nm | 28 nm | 
| Frequency (MHz) | 1000 | 1064 | 410 | 400 | 500 | 
| Area (mm2) | 0.0971 | 0.00197 | 848.1 | 0.76 | 0.0326 | 
| Power (mW) | - | 1.852 | 140.2 × 103 | 210 | 6.09 | 
| Latency (clock cycles) | 0.9 | 25.4 | - | 71 | 1.04 | 
| Reference | Problems to Be Solved | Methods Utilized | 
|---|---|---|
| Nobari et al. [38] | Slow convergence of SC-DNN deployment to hardware | Limits the length of the stochastic bitstream and establishes precise timing in the processing unit | 
| Wang et al. [75] | SC-DNN deployment to embedded devices with high memory | Replacement of traditional MLC PCM with SC PCM | 
| Frasser et al. [93] | SC-CNN deployment to hardware with high occupancy | Fully parallel compressed area strategy | 
| Li et al. [68] | SC-DCNN deployment to wearable devices with high power consumption | Optimizing AxPC while using clustering to optimize the storage weighting strategy | 
| Maor et al. [82] | SC-LSTM deployment to IoT devices with high power consumption | Using AxPC and MUX for neuronal design | 
| Liu et al. [86] | High resource footprint of SNN hardware implementation | Replace traditional basic arithmetic with SC’s logical arithmetic | 
| Jia et al. [44] | High Complexity of Bayesian Neural Network (BNN) deployment to embedded devices | Gaussian stochastic numbers with the central limit theorem in the inference phase | 
| Yang et al. [58] | Lightweight SC-CNN deployment to edge devices | Adoption of SC strategy with memristor function | 
| Network Types | Network Model | Framework | Accuracy/Precision (%For Data Sets) | Platforms | Hardware Efficiency (for % Without SC) | ||
|---|---|---|---|---|---|---|---|
| SC | FP | Area | Energies | ||||
| ANN | SC-MLP  [63] SC-ANN [66] SC-ANN [71] SC-ESL [70] | 784-200-100-10 - - - | 97.95 97.0 92.3 98.41 | 99.27 - 98.9 - | ASIC ASIC ASIC ASIC | 40.7 7.50 4.13 15.98 | 38.0 19.03 5.78 40.30 | 
| DNN | NSPC-DNN [72] WSSC-DNN1 [73] WSSC-DNN2 [73] SC-DNN [74] SC-DNN [75] HIEF [68] SC-MLP [38] SC-DNN [93] SC-NAS [76] | 784-480-240-10 784-480-240-10 784-100-200-10 784-100-200-10 Lenet-5 Lenet-5 784-100-200-10 Lenet-5 LeNet | - 98.11 97.99 98.90 97.8 99.07 98.52 97.6 95.2 | - 97.89 98.03 - - - - 98.6 97.5 | GPU GPU GPU GPU GPU ASIC FPGA FPGA GPU | 6.6 47.46 - 16 - 6.5 - - 16.55 | 2.93 31.64 - - 6.6 5.6 - - 14.25 | 
| CNN | SC-DCNN [49] SC-DCNN [78] SC-DCNN [79] SC-CNN [80] SC-CNN [61] SC-CNN [77] | LeNet-5 LeNet-5 LeNet-5 LeNet-5 LeNet-5 ResNet-20 | 80.47 98.46 98.26 99.12 - 99.19 | 77.42 - - - - - | GPU GPU ASIC GPU ASIC FPGA | - 55 36.4 - 16.58 - | - 2 3.53 - 51.2 - | 
| RNN | SC-LSTM [81] SC-LSTM [82] SC-LSTM [83] SC-RNN [84] | - - - - | - 92.31 92.7 - | - 94.00 - - | FPGA FPGA ASIC GPU | 23.07 - 41 1.6 | - 73.24 79 6.5 | 
| SNN | SC-PSTDP [86] SC-SSA [87] | - - | - 98.31 | - 99.02 | FPGA GPU | 27.56 - | 2.32 15 | 
| Disclaimer/Publisher’s Note: The statements, opinions and data contained in all publications are solely those of the individual author(s) and contributor(s) and not of MDPI and/or the editor(s). MDPI and/or the editor(s) disclaim responsibility for any injury to people or property resulting from any ideas, methods, instructions or products referred to in the content. | 
© 2024 by the authors. Licensee MDPI, Basel, Switzerland. This article is an open access article distributed under the terms and conditions of the Creative Commons Attribution (CC BY) license (https://creativecommons.org/licenses/by/4.0/).
Share and Cite
Wang, L.; Luo, Z.; Gao, L. Stochastic Computing Architectures: Modeling, Optimization, and Applications. Symmetry 2024, 16, 1701. https://doi.org/10.3390/sym16121701
Wang L, Luo Z, Gao L. Stochastic Computing Architectures: Modeling, Optimization, and Applications. Symmetry. 2024; 16(12):1701. https://doi.org/10.3390/sym16121701
Chicago/Turabian StyleWang, Lin, Zhongqiang Luo, and Li Gao. 2024. "Stochastic Computing Architectures: Modeling, Optimization, and Applications" Symmetry 16, no. 12: 1701. https://doi.org/10.3390/sym16121701
APA StyleWang, L., Luo, Z., & Gao, L. (2024). Stochastic Computing Architectures: Modeling, Optimization, and Applications. Symmetry, 16(12), 1701. https://doi.org/10.3390/sym16121701
 
        

 
       