Bayesian Programming

Probability as an extension of logic

HardwareResearch

Bayesian Inference With Muller C-Elements

Bayesian inference is a powerful approach for integrating independent conflicting information for decision-making. Though an important component of robotic, biological, and other sensory-motors systems, general-purpose computers perform Bayesian inference with limited efficiency.

Here we show that Bayesian inference can be efficiently performed with stochastic signals, which are particularly adapted to novel low power nano-devices that exhibit faults and device variations.

A simple Muller C-element directly implements Bayes’ rule. Complex inferences are performed by C-element trees, which compute the probability of an event based on multiple independent sources of evidence.

A naïve Bayesian spam filter circuit is demonstrated as a pedagogical application, and design techniques for improving circuit functionality are described. Limitations of this structure are discussed in terms of signal autocorrelation.

The stochastic inference structure is exceptionally robust to faults, an essential feature of decision circuits, and can therefore leverage the increased efficiency of emerging nano-devices. This hardware implementation of Bayesian inference is extremely area and power efficient, with an area-energy-delay product several orders of magnitude less than the conventional floating point implementation.

These results open a pathway for a direct stochastic hardware implementation of Bayesian inference, enabling a new class of embedded decision circuits for robotics and medical applications.

PUBLICATION

Leave a Reply

Your email address will not be published. Required fields are marked *