2015-01-23 00:52:13 +08:00
Utilities
=========
Local running tool
------------------
.. argparse ::
:ref: artiq.frontend.artiq_run.get_argparser
:prog: artiq_run
2015-02-12 00:38:20 +08:00
Remote Procedure Call tool
2015-04-07 15:41:32 +08:00
--------------------------
2015-01-23 00:52:13 +08:00
.. argparse ::
2015-02-12 00:38:20 +08:00
:ref: artiq.frontend.artiq_rpctool.get_argparser
:prog: artiq_rpctool
This tool is the preferred way of handling simple ARTIQ controllers.
Instead of writing a client for very simple cases you can just use this tool
in order to call remote functions of an ARTIQ controller.
* Listing existing targets
The `` list-targets `` sub-command will print to standard output the
target list of the remote server::
2015-12-24 18:51:11 +08:00
$ artiq_rpctool hostname port list-targets
2015-02-12 00:38:20 +08:00
* Listing callable functions
The `` list-methods `` sub-command will print to standard output a sorted
list of the functions you can call on the remote server's target.
The list will contain function names, signatures (arguments) and
docstrings.
If the server has only one target, you can do::
2015-12-24 18:51:11 +08:00
$ artiq_rpctool hostname port list-methods
2015-02-12 00:38:20 +08:00
Otherwise you need to specify the target, using the `` -t target ``
option::
2015-12-24 18:51:11 +08:00
$ artiq_rpctool hostname port list-methods -t target_name
2015-02-12 00:38:20 +08:00
* Remotely calling a function
The `` call `` sub-command will call a function on the specified remote
server's target, passing the specified arguments.
Like with the previous sub-command, you only need to provide the target
name (with `` -t target `` ) if the server hosts several targets.
The following example will call the `` set_attenuation `` method of the
Lda controller with the argument `` 5 `` ::
2015-12-24 18:51:11 +08:00
$ artiq_rpctool ::1 3253 call -t lda set_attenuation 5
2015-02-12 00:38:20 +08:00
In general, to call a function named `` f `` with N arguments named
2015-02-12 01:13:16 +08:00
respectively `` x1, x2, ..., xN `` you can do::
2015-02-12 00:38:20 +08:00
2015-12-24 18:51:11 +08:00
$ artiq_rpctool hostname port call -t target f x1 x2 ... xN
2015-02-12 00:38:20 +08:00
You can use Python syntax to compute arguments as they will be passed
2015-04-20 18:49:13 +08:00
to the `` eval() `` primitive. The numpy package is available in the namespace
as `` np `` . Beware to use quotes to separate arguments which use spaces::
2015-02-12 00:38:20 +08:00
2015-12-24 18:51:11 +08:00
$ artiq_rpctool hostname port call -t target f '3 * 4 + 2' True '[1, 2]'
$ artiq_rpctool ::1 3256 call load_sample_values 'np.array([1.0, 2.0], dtype=float)'
2015-02-12 00:38:20 +08:00
If the called function has a return value, it will get printed to
the standard output if the value is not None like in the standard
python interactive console::
2015-12-24 18:51:11 +08:00
$ artiq_rpctool ::1 3253 call get_attenuation
2015-02-12 00:38:20 +08:00
5.0 dB
2015-04-07 15:41:32 +08:00
Static compiler
---------------
This tool compiles an experiment into a ELF file. It is primarily used to prepare binaries for the default experiment loaded in non-volatile storage of the core device.
Experiments compiled with this tool are not allowed to use RPCs, and their `` run `` entry point must be a kernel.
.. argparse ::
:ref: artiq.frontend.artiq_compile.get_argparser
:prog: artiq_compile
2015-04-30 20:03:11 +08:00
Flash storage image generator
-----------------------------
This tool compiles key/value pairs into a binary image suitable for flashing into the flash storage space of the core device.
.. argparse ::
:ref: artiq.frontend.artiq_mkfs.get_argparser
:prog: artiq_mkfs
2015-05-07 23:47:48 +08:00
2015-08-02 21:35:49 +08:00
.. _core-device-access-tool:
2015-05-07 23:47:48 +08:00
2015-12-24 18:51:11 +08:00
Core device configuration tool
------------------------------
2015-05-07 23:47:48 +08:00
2015-12-24 18:51:11 +08:00
The artiq_coreconfig utility gives remote access to the :ref: `core-device-flash-storage` .
2015-05-07 23:47:48 +08:00
2015-12-24 18:51:11 +08:00
To use this tool, you need to specify a `` device_db.pyon `` device database file which contains a `` comm `` device (an example is provided in `` examples/master/device_db.pyon `` ). This tells the tool how to connect to the core device and with which parameters (e.g. IP address, TCP port). When not specified, the artiq_coreconfig utility will assume that there is a file named `` device_db.pyon `` in the current directory.
2015-05-07 23:47:48 +08:00
To read the record whose key is `` mac `` ::
2015-12-24 18:51:11 +08:00
$ artiq_coreconfig cfg-read mac
2015-05-07 23:47:48 +08:00
To write the value `` test_value `` in the key `` my_key `` ::
2015-12-24 18:51:11 +08:00
$ artiq_coreconfig cfg-write -s my_key test_value
$ artiq_coreconfig cfg-read my_key
2015-05-07 23:47:48 +08:00
b'test_value'
2015-11-01 00:24:44 +08:00
You can also write entire files in a record using the `` -f `` parameter. This is useful for instance to write the startup and idle kernels in the flash storage::
2015-05-07 23:47:48 +08:00
2015-12-24 18:51:11 +08:00
$ artiq_coreconfig cfg-write -f idle_kernel idle.elf
$ artiq_coreconfig cfg-read idle_kernel | head -c9
2015-05-29 22:30:32 +08:00
b'\x7fELF
2015-05-07 23:47:48 +08:00
You can write several records at once::
2015-12-24 18:51:11 +08:00
$ artiq_coreconfig cfg-write -s key1 value1 -f key2 filename -s key3 value3
2015-05-07 23:47:48 +08:00
To remove the previously written key `` my_key `` ::
2015-12-24 18:51:11 +08:00
$ artiq_coreconfig cfg-delete my_key
2015-06-18 23:07:03 +08:00
You can remove several keys at once::
2015-12-24 18:51:11 +08:00
$ artiq_coreconfig cfg-delete key1 key2
2015-05-07 23:47:48 +08:00
To erase the entire flash storage area::
2015-12-24 18:51:11 +08:00
$ artiq_coreconfig cfg-erase
2015-05-07 23:47:48 +08:00
2015-12-24 18:51:11 +08:00
You do not need to remove a record in order to change its value, just overwrite it::
2015-05-07 23:47:48 +08:00
2015-12-24 18:51:11 +08:00
$ artiq_coreconfig cfg-write -s my_key some_value
$ artiq_coreconfig cfg-write -s my_key some_other_value
$ artiq_coreconfig cfg-read my_key
2015-05-07 23:47:48 +08:00
b'some_other_value'
.. argparse ::
2015-12-24 18:51:11 +08:00
:ref: artiq.frontend.artiq_coreconfig.get_argparser
:prog: artiq_coreconfig
Core device log download tool
-----------------------------
.. argparse ::
:ref: artiq.frontend.artiq_corelog.get_argparser
:prog: artiq_corelog
Core device RTIO analyzer tool
------------------------------
.. argparse ::
:ref: artiq.frontend.artiq_coreanalyzer.get_argparser
:prog: artiq_coreanalyzer
2015-08-17 15:44:40 +08:00
Data to InfluxDB bridge
-----------------------
.. argparse ::
:ref: artiq.frontend.artiq_influxdb.get_argparser
:prog: artiq_influxdb