簡體   English   中英

無法使用EDAPlayground編譯器顯示模擬

[英]Unable to display the simulation with EDAPlayground compiler

我已經嘗試了EDAPlayground.com上myHDL手冊中的以下代碼,但沒有為我輸出任何內容。 誰能告訴我為什么? 以及如何解決呢?

這里概述了我在網站上的配置。

Testbench + Design:僅Python方法:MyHDL 0.8


來自myhdl import的隨機導入randrange *

ACTIVE_LOW, INACTIVE_HIGH = 0, 1

def Inc(count, enable, clock, reset, n):

""" Incrementer with enable.

count -- output
enable -- control input, increment when 1
clock -- clock input
reset -- asynchronous reset input
n -- counter max value

"""

@always_seq(clock.posedge, reset=reset)
def incLogic():
    if enable:
        count.next = (count + 1) % n

return incLogic

def testbench():

count, enable, clock = [Signal(intbv(0)) for i in range(3)]

# Configure your reset signal here (active type, async/sync)
reset = ResetSignal(0,active=ACTIVE_LOW,async=True)



## DUT to be instantiated
inc_1 = Inc(count, enable, clock, reset, n=4)

HALF_PERIOD = delay(10)


## forever loop : clock generator

@always(HALF_PERIOD)
def clockGen():
    clock.next = not clock

## Stimulus generator
@instance
def stimulus():
    reset.next = ACTIVE_LOW
    yield clock.negedge
    reset.next = INACTIVE_HIGH
    for i in range(12):
        enable.next = min(1, randrange(3))
        yield clock.negedge
    raise StopSimulation

@instance
def monitor():
    print "enable  count"
    yield reset.posedge
    while 1:
        yield clock.posedge
        yield delay(1)
        print "   %s      %s" % (enable, count)

return clockGen, stimulus, inc_1, monitor


tb = testbench()

def main():
    Simulation(tb).run()

您需要在最后調用main()函數。 例如,添加一行

main()

最后,或者更好的是,使用Python的習慣用法

if __name__=="__main__": 
     main()

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM