Skip to content

Latest commit

 

History

History
59 lines (39 loc) · 2.69 KB

README.md

File metadata and controls

59 lines (39 loc) · 2.69 KB

Metastability-Simulation

Simulating the Metastability in Flip Flops for Visualization purposes

Metastability is a critical problem in Digital Systems which is often considered as solved since most modern synthesis tools takle care of it but it still needs attention. Infact the Developers have reduced it's chances to a very small probabilistic value such that it can be easily avoided by following the best design practices.
For visualization and academnic purposes, I created this simulation under the supervision of my professor. It shows how Metastability occurs and what are it's after-effects.

Simulation Environment

LTSpice is used to create this simulation as it happens to be a sensible choice where we can vary the MOSFET properties and Simulation Variables to a great Extent.

Schematic


In the simulation below, It can be seen that the input D of the flip flop changes right on the time when clock is transitioning from LOW to HIGH state. Resultantly, such a waveform appears where both the outputs of Flip Flops are held to an undefined state for certain amount of time which RESETS to Either side once the clock pulls to LOW.
In simulation environments, It's hard to reproduce such an even due to very high precision of calculation given the fact that most of the Environmental variables are running in Ideal States.

Simulation


The downside of this work is that the states always set to the same side upon every iteration which should'nt happen for a true metastability event but this has to do with the way software simulators work. If someone in the community comes up with a fix for this, Feel free to FORK the Repo and Merge your Solution.

Colin O'flynn's Physical Recreation of metastability on FPGA

Want to see a real world experimentation with metastability on physical hardware? See Colin's work on producing metastability on an FPGA. VIDEO

Directory Tree

.
├── bsim461.nmos
├── bsim461.pmos
├── cmosedu_models.txt
├── LTspice-sources
│   ├── MetaS_ltspice_sim_2.asc
│   └── Metastability_d_Latch_success.asc
├── README.md
├── sch.png
└── Screenshot 2023-01-02 212710.png


License

This Project is published under General Public License V3.0 See LICENSE.txt for more information.

https://www.gnu.org/licenses/quick-guide-gplv3.html