artiq/examples/master/repository/arguments_demo.py

74 lines
2.6 KiB
Python
Raw Normal View History

2015-10-20 18:11:50 +08:00
import logging
2016-01-26 07:03:01 +08:00
from artiq.experiment import *
2015-07-18 22:25:08 +08:00
class SubComponent1(HasEnvironment):
def build(self):
self.setattr_argument("sc1_scan", Scannable(default=NoScan(3250),
scale=1e3, unit="kHz"),
2015-10-04 00:18:21 +08:00
"Flux capacitor")
self.setattr_argument("sc1_enum", EnumerationValue(["1", "2", "3"]),
"Flux capacitor")
def do(self):
print("SC1:")
for i in self.sc1_scan:
print(i)
print(self.sc1_enum)
class SubComponent2(HasEnvironment):
def build(self):
2015-10-04 00:18:21 +08:00
self.setattr_argument("sc2_boolean", BooleanValue(False),
"Transporter")
self.setattr_argument("sc2_scan", Scannable(default=NoScan(325)),
"Transporter")
self.setattr_argument("sc2_enum", EnumerationValue(["3", "4", "5"]),
"Transporter")
def do(self):
print("SC2:")
print(self.sc2_boolean)
for i in self.sc2_scan:
print(i)
print(self.sc2_enum)
2015-10-20 18:11:50 +08:00
class ArgumentsDemo(EnvExperiment):
2015-07-18 22:25:08 +08:00
def build(self):
# change the "foo" dataset and click the "recompute argument"
# buttons.
self.setattr_argument("pyon_value",
PYONValue(self.get_dataset("foo", default=42)))
self.setattr_argument("number", NumberValue(42e-6,
unit="us", scale=1e-6,
2015-10-04 00:18:21 +08:00
ndecimals=4))
self.setattr_argument("string", StringValue("Hello World"))
self.setattr_argument("scan", Scannable(global_max=400,
default=NoScan(325),
ndecimals=6))
self.setattr_argument("boolean", BooleanValue(True), "Group")
self.setattr_argument("enum", EnumerationValue(
["foo", "bar", "quux"], "foo"), "Group")
self.sc1 = SubComponent1(parent=self)
self.sc2 = SubComponent2(parent=self)
2015-07-18 22:25:08 +08:00
def run(self):
2015-10-20 18:11:50 +08:00
logging.error("logging test: error")
logging.warning("logging test: warning")
2015-11-24 23:04:01 +08:00
logging.warning("logging test:" + " this is a very long message."*15)
2015-10-20 18:11:50 +08:00
logging.info("logging test: info")
logging.debug("logging test: debug")
2015-10-14 16:31:07 +08:00
2015-11-27 19:30:05 +08:00
print(self.pyon_value)
2015-07-18 22:25:08 +08:00
print(self.boolean)
print(self.enum)
print(self.number)
print(self.string)
2015-07-21 23:23:32 +08:00
for i in self.scan:
print(i)
self.sc1.do()
self.sc2.do()