Skip to content

arminalaghi/scsynth

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

61 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

scsynth

scsynth is a synthesis tool for stochastic computing circuits developed by N. Eamon Gaffney and Armin Alaghi at the Univeristy of Washington. Currently, it can create Verilog files describing reconfigurable architectures based on stochastic logic, or ReSCs (Qian et al., 2011), as well as similar STRAUSS architectures (Alaghi et al., 2015) but its functionality is constantly expanding.

Code forked and reviewed by Danilo Cavalcanti at the Federal University of Paraíba.

Stochastic Computing

Stochastic computing is a computing technique involving representing numbers as single streams of bits in sequence rather than groups of bits probabilistically in parallel as is typically done in modern computing architectures. Stochastic circuits tend to run slower than their typical digital counterparts, but they also tend to be smaller (and thus lower-energy) and can be more error tolerant, giving them a number of potential applications, including neural networks and image processing.

More information can be found at https://en.wikipedia.org/wiki/Stochastic_computing.

Usage

scsynth consists of functions that can be run in Octave or MATLAB to generate Verilog modules. Currently, the following user-facing functions exist:

  • VerilogLFSRGenerator(dataLen, addZero, moduleName, taps=0) which generates a linear feedback shift register, a module for pseudorandom number generation
  • VerilogSCFromData(data, degree, N, m_input, m_coeff, namePrefix, singleWeightLFSR=true, ConstantRNG='SharedLFSR', InputRNG='LFSR', ConstantSNG='HardWire', InputSNG='Comparator', SCModule='ReSC') which, given datapoints from a function and the desired degree of the polynomial used to model the function, generates a full ReSC or STRAUSS unit, including conversion to and from binary equivalents (and pseudorandom number generators used therein) as well as a testbench for the module
  • VerilogSCFromFunction(func, degree, N, m_input, m_coeff, namePrefix, singleWeightLFSR=true, ConstantRNG='SharedLFSR', InputRNG='LFSR', ConstantSNG='HardWire', InputSNG='Comparator', SCModule='ReSC', domain=[0,1], granularity=100) which works like VerilogSCFromData, but takes a function itself rather than data representing that function (note: complexity grows with granularity; granularity should be proportional to the chosen degrees)
  • VerilogMReSCFromData(data, degrees, N, m_input, m_coeff, namePrefix, ConstantRNG='SharedLFSR', InputRNG='LFSR') which functions much like the normal ReSC generator but allows for functions on multiple variables (note: computational complexity scales very quickly as you add variables)
  • VerilogMReSCFromFunction(func, degrees, N, m_input, m_coeff, namePrefix, singleWeightLFSR=true, domains=[0,1], granularities=100) which generates a multivariate ReSC from a function rather than data

More details on the usage of these functions can be found in the source code.

Note on MATLAB usage

  • Since there are a few differences in optimset two lines have to be changed
  • Comment out (%) line 63 of BernAppr.m and uncomment line 60 (erase %)
  • Comment out (%) line 124 of MultivariateBernAppr.m and uncomment line 121 (erase %)

Note on Multivariate SC Synthesis

  • Code needs to be reviewed to take in consideration changes in single variable synthesis functions

Required/Recommended versions

  • Octave 4.4.1 with 64-bit enabled
    • Packages
      • io (2.4.12)
      • optim (1.5.3)
      • parallel (3.1.3) [optional, minimal usage at the moment]
      • statistics (1.4.0)
      • struct (1.0.15)

References

  • A. Alaghi and J. P. Hayes,, "A spectral transform approach to stochastic circuits," 2012 IEEE 30th International Conference on Computer Design (ICCD), Montreal, QC, 2012, pp. 315-321. doi: 10.1109/ICCD.2012.6378658
  • A. Alaghi and J. P. Hayes, "Exploiting correlation in stochastic circuit design," 2013 IEEE 31st International Conference on Computer Design (ICCD), Asheville, NC, 2013, pp. 39-46. doi: 10.1109/ICCD.2013.6657023
  • A. Alaghi and J. P. Hayes, "STRAUSS: Spectral Transform Use in Stochastic Circuit Synthesis," in IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. 34, no. 11, pp. 1770-1783, Nov. 2015. doi: 10.1109/TCAD.2015.2432138
  • B. D. Brown and H. C. Card, "Stochastic neural computation. I. Computational elements," IEEE Trans. Computers, 2001. doi: 10.1109/12.954505
  • P. K. Gupta and R. Kumaresan, "Binary multiplication with PN sequences," IEEE Trans. Acoustics Speech Signal Process, 1988.
  • W. Qian, X. Li, M. D. Riedel, K. Bazargan and D. J. Lilja, D. J. "An architecture for fault-tolerant computation with stochastic logic," IEEE Trans. on Computers, 2011. doi:10.1109/tc.2010.202
  • W. Qian and M. D. Riedel, "The synthesis of stochastic logic to perform multivariate polynomial arithmetic," 2010.
  • The Berkeley ABC library. https://people.eecs.berkeley.edu/~alanmi/abc/abc.htm

About

Synthesis tool for stochastic computing

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •