2014-05-31 00:20:13 +08:00
|
|
|
from artiq.language.units import *
|
2014-07-11 00:13:37 +08:00
|
|
|
from artiq.language.core import *
|
2014-05-31 00:20:13 +08:00
|
|
|
|
2014-09-05 12:03:22 +08:00
|
|
|
|
2014-06-17 03:39:33 +08:00
|
|
|
my_range = range
|
|
|
|
|
2014-09-05 12:03:22 +08:00
|
|
|
|
2014-08-13 18:30:57 +08:00
|
|
|
class CompilerTest(AutoContext):
|
2014-09-05 12:03:22 +08:00
|
|
|
parameters = "a b A B"
|
|
|
|
|
|
|
|
def print_done(self):
|
|
|
|
print("Done!")
|
|
|
|
|
|
|
|
def set_some_slowdev(self, n):
|
|
|
|
print("Slow device setting: {}".format(n))
|
|
|
|
|
|
|
|
@kernel
|
|
|
|
def run(self, n, t2):
|
|
|
|
for i in my_range(n):
|
|
|
|
self.set_some_slowdev(i)
|
|
|
|
delay(100*ms)
|
|
|
|
with parallel:
|
|
|
|
with sequential:
|
|
|
|
for j in my_range(3):
|
|
|
|
self.a.pulse((j+1)*100*MHz, 20*us)
|
|
|
|
self.b.pulse(100*MHz, t2)
|
|
|
|
with sequential:
|
|
|
|
self.A.pulse(100*MHz, 10*us)
|
|
|
|
self.B.pulse(100*MHz, t2)
|
|
|
|
self.print_done()
|
|
|
|
|
2014-05-31 00:20:13 +08:00
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2014-09-05 12:03:22 +08:00
|
|
|
from artiq.devices import corecom_dummy, core, dds_core
|
|
|
|
|
|
|
|
coredev = core.Core(corecom_dummy.CoreCom())
|
|
|
|
exp = CompilerTest(
|
|
|
|
core=coredev,
|
|
|
|
a=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
|
|
|
reg_channel=0, rtio_channel=0),
|
|
|
|
b=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
|
|
|
reg_channel=1, rtio_channel=1),
|
|
|
|
A=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
|
|
|
reg_channel=2, rtio_channel=2),
|
|
|
|
B=dds_core.DDS(core=coredev, dds_sysclk=1*GHz,
|
|
|
|
reg_channel=3, rtio_channel=3)
|
|
|
|
)
|
|
|
|
exp.run(3, 100*us)
|