1
0
mirror of https://github.com/myhdl/myhdl.git synced 2024-12-14 07:44:38 +08:00
myhdl/example/arith_lib/test_LeadZeroDet.py
2003-01-23 22:33:19 +00:00

60 lines
1.5 KiB
Python

from __future__ import generators
import unittest
from unittest import TestCase
from myhdl import Signal, intbv, delay, Simulation
from arith_utils import BEHAVIOR, STRUCTURE
from arith_utils import SLOW, FAST
from LeadZeroDet import LeadZeroDet
import random
random.seed = 1
from random import random
class LeadZeroDetTest(TestCase):
def bench(self, width, speed, nrsamples=0):
A = Signal(intbv())
ZS = Signal(intbv())
ZB = Signal(intbv())
beh = LeadZeroDet(width, speed, A, ZB, architecture=BEHAVIOR)
str = LeadZeroDet(width, speed, A, ZS, architecture=STRUCTURE)
def stimulus():
if nrsamples:
vals = [long(random()*(2**width)) for i in range(nrsamples)]
else:
vals = range(2**width)
for i in vals:
A.next = intbv(i)
yield delay(10)
# print "a:%s Res: %s %s" % (A.val, ZS.val, ZB.val)
self.assertEqual(ZS.val, ZB.val)
return (beh, str, stimulus())
def testLeadZeroDetSmallSlow(self):
Simulation(self.bench(width=8, speed=SLOW)).run()
def testLeadZeroDetLargeSlow(self):
Simulation(self.bench(width=39, speed=SLOW, nrsamples=16)).run()
def testLeadZeroDetSmallFast(self):
Simulation(self.bench(width=8, speed=FAST)).run()
def testLeadZeroDetLargeFast(self):
Simulation(self.bench(width=39, speed=FAST, nrsamples=16)).run()
if __name__ == "__main__":
unittest.main()