mirror of
https://github.com/m-labs/artiq.git
synced 2025-01-27 02:48:12 +08:00
MPO -> AutoContext
This commit is contained in:
parent
c29e6312fe
commit
c18495d484
@ -1,7 +1,7 @@
|
||||
from artiq.language.core import *
|
||||
from artiq.language.units import *
|
||||
|
||||
class DDS(MPO):
|
||||
class DDS(AutoContext):
|
||||
parameters = "dds_sysclk reg_channel rtio_channel"
|
||||
|
||||
def build(self):
|
||||
|
@ -1,6 +1,6 @@
|
||||
from artiq.language.core import *
|
||||
|
||||
class GPIOOut(MPO):
|
||||
class GPIOOut(AutoContext):
|
||||
parameters = "channel"
|
||||
|
||||
@kernel
|
||||
|
@ -1,6 +1,6 @@
|
||||
from artiq.language.core import *
|
||||
|
||||
class TTLOut(MPO):
|
||||
class TTLOut(AutoContext):
|
||||
parameters = "channel"
|
||||
|
||||
@kernel
|
||||
|
@ -5,7 +5,7 @@ from artiq.language import units
|
||||
def _make_kernel_ro(value):
|
||||
return isinstance(value, (int, float, str, units.Quantity))
|
||||
|
||||
class MPO:
|
||||
class AutoContext:
|
||||
parameters = ""
|
||||
implicit_core = True
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
from random import Random
|
||||
|
||||
from artiq.language.core import MPO, delay
|
||||
from artiq.language.core import AutoContext, delay
|
||||
from artiq.language import units
|
||||
from artiq.sim import time
|
||||
|
||||
@ -8,7 +8,7 @@ class Core:
|
||||
def run(self, k_function, k_args, k_kwargs):
|
||||
return k_function(*k_args, **k_kwargs)
|
||||
|
||||
class Input(MPO):
|
||||
class Input(AutoContext):
|
||||
parameters = "name"
|
||||
|
||||
def build(self):
|
||||
@ -25,14 +25,14 @@ class Input(MPO):
|
||||
delay(duration)
|
||||
return result
|
||||
|
||||
class WaveOutput(MPO):
|
||||
class WaveOutput(AutoContext):
|
||||
parameters = "name"
|
||||
|
||||
def pulse(self, frequency, duration):
|
||||
time.manager.event(("pulse", self.name, frequency, duration))
|
||||
delay(duration)
|
||||
|
||||
class VoltageOutput(MPO):
|
||||
class VoltageOutput(AutoContext):
|
||||
parameters = "name"
|
||||
|
||||
def set(self, value):
|
||||
|
@ -86,7 +86,7 @@ with parallel:
|
||||
\begin{frame}[fragile]
|
||||
\frametitle{\fontseries{l}\selectfont Object orientation and code reuse}
|
||||
\begin{verbatimtab}
|
||||
class Main(MPO):
|
||||
class Main(AutoContext):
|
||||
def build(self):
|
||||
self.ion1 = Ion(...)
|
||||
self.ion2 = Ion(...)
|
||||
@ -130,9 +130,9 @@ class Main(MPO):
|
||||
\begin{frame}[fragile]
|
||||
\frametitle{\fontseries{l}\selectfont Channels and parameters}
|
||||
\begin{itemize}
|
||||
\item A kernel is a method of a class that derives from the \verb!MPO! class
|
||||
\item A kernel is a method of a class that derives from the \verb!AutoContext! class
|
||||
\item The entry point for an experiment is called \verb!run! --- may or may not be a kernel
|
||||
\item The \verb!MPO! class manages channels and parameters, and sets them as attributes
|
||||
\item The \verb!AutoContext! class manages channels and parameters, and sets them as attributes
|
||||
\item If channels/parameters are passed as constructor arguments, those are used
|
||||
\item Otherwise, they are looked up in the device and parameter databases
|
||||
\end{itemize}
|
||||
|
@ -1,7 +1,7 @@
|
||||
from artiq.language.units import *
|
||||
from artiq.language.core import *
|
||||
|
||||
class AluminumSpectroscopy(MPO):
|
||||
class AluminumSpectroscopy(AutoContext):
|
||||
parameters = "mains_sync laser_cooling spectroscopy spectroscopy_b state_detection pmt \
|
||||
spectroscopy_freq photon_limit_low photon_limit_high"
|
||||
|
||||
|
@ -3,7 +3,7 @@ from artiq.language.core import *
|
||||
|
||||
my_range = range
|
||||
|
||||
class CompilerTest(MPO):
|
||||
class CompilerTest(AutoContext):
|
||||
parameters = "a b A B"
|
||||
|
||||
def print_done(self):
|
||||
|
@ -1,7 +1,7 @@
|
||||
from artiq.language.core import MPO, kernel
|
||||
from artiq.language.core import AutoContext, kernel
|
||||
from artiq.devices import corecom_serial, core, gpio_core
|
||||
|
||||
class CompilerTest(MPO):
|
||||
class CompilerTest(AutoContext):
|
||||
parameters = "led"
|
||||
|
||||
def output(self, n):
|
||||
|
@ -2,7 +2,7 @@ from artiq.language.units import *
|
||||
from artiq.language.core import *
|
||||
from artiq.devices import corecom_serial, core, dds_core, gpio_core
|
||||
|
||||
class DDSTest(MPO):
|
||||
class DDSTest(AutoContext):
|
||||
parameters = "a b c d led"
|
||||
|
||||
@kernel
|
||||
|
@ -1,7 +1,7 @@
|
||||
from artiq.language.units import *
|
||||
from artiq.language.core import *
|
||||
|
||||
class SimpleSimulation(MPO):
|
||||
class SimpleSimulation(AutoContext):
|
||||
parameters = "a b c d"
|
||||
|
||||
@kernel
|
||||
|
@ -2,7 +2,7 @@ from artiq.language.units import *
|
||||
from artiq.language.core import *
|
||||
from artiq.devices import corecom_serial, core
|
||||
|
||||
class DummyPulse(MPO):
|
||||
class DummyPulse(AutoContext):
|
||||
parameters = "name"
|
||||
|
||||
def print_on(self, t, f):
|
||||
@ -17,7 +17,7 @@ class DummyPulse(MPO):
|
||||
delay(duration)
|
||||
self.print_off(now())
|
||||
|
||||
class TimeTest(MPO):
|
||||
class TimeTest(AutoContext):
|
||||
parameters = "a b c d"
|
||||
|
||||
@kernel
|
||||
|
Loading…
Reference in New Issue
Block a user