Python Package (qm-qua) Releases¶
All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog.
1.1.7 - 2024-02-19¶
Tested against QOP 1.2, 2.2
Changed
- Changed the flag
check_for_errors
default, in all fetching functions, toTrue
. This will produce a warning if any run-time errors are detected during the job execution. - Importing everything from
qm.qua
(from qm.qua import *
) will no longer import external libraries such as NumPy and logging.
Fixed
- Fixed a bug that disabled external loggers when importing the qm-qua package.
- Fixed a bug that prevented the waveform reporting from generating.
- Fixed the plot label units in the waveform report.
- Optimized the program's execution latency, especially for larger programs.
- Optimized the latency for setting and reading the Octave's LO frequency.
- Speed up QMM initialization by removing an unneeded call to Octave clients.
- Fixed the Octave calibration algorithm to shut down upconverters and downconverters during calibration, so that the calibration will not be affected by RF in.
- Fixed cases in which compilation errors related to elements were given without a location.
- Fixed a bug that prevents setting the downconverter's frequency when connected through a loopback.
- Fixed a bug that prevented connecting one pair of OPX outputs to different Octave upconverters.
Added
- Added the option to receive Octaves with the cluster when opening a QuantumMachinesManager, instead of manually giving their addresses using
OctaveConfig
. This requires QOP 2.4.0 or above. - Added
program.to_protobuf(config)
andprogram.to_file('my_program.pb', config)
to save a program to memory or to disk. - Added
Program.from_protobuf(config)
andProgram.from_file('my_program.pb', config)
to load a serialized program from memory or to disk. - Added support for OPX1000 – The config controller seciotn now accepts a controller of type "OPX1000", and the element’s input and output ports can now indicate which FEM is to be used.
Variable
class is now exported to allow type checking.- Connections’ headers are now forwarded to the Octaves.
- Connections’ headers are now indicating to which device the message belongs to.
Deprecation
- Deprecated old Octave configuration API; these functions will be removed in a future version.
- Deprecated
Program.build
; this function will be removed in the next minor version. Instead, you can useProgram.qua_program
.
Removed
- Dropped support of Python 3.7.
Known Issues
- At the end of the Octave calibration, dc-offsets stay at the last values calibrated.
- Connecting an octave to two or more FEMs / OPX+es is unsupported and will give an undescriptive error.
- An Octave connected to a 2 GSPS OPX1000 port will not calibrate and will give a compilation error. As a workaround, set the port to 1 GSPS, calibrate, and then set it back to 2 GSPS.
1.1.6 - 2023-11-19¶
Fixed
- Fixed the serialization if a list was used for port definition instead of a tuple
- Fixed a bug which prevented the waveform reporting from generating plots (bad encoding)
Added
- When empty loopback is given, it is treated as no loopbacks interface.
- Python 3.11 is now supported
1.1.5.1 - 2023-10-30¶
Fixed
- Downgrading from this version will not break the Octave (Introduced in 1.1.5)
- Saving timestamps directly to a string will now not mess up adc saving
- Improved serialization handling of streams, fixes issues in some cases
1.1.5 - 2023-10-22¶
Note, this version was Yanked, downgrading from this version could lead to issues, this was fixed in 1.1.5.1
Fixed
- Fixed simulations with negative IF frequency (in mixer).
- Deprecation warnings will now be shown for imports in IPython
- Improved octave calibration algorithm.
Added
- Added new API for octave configuration, through the QUA config dict (except for the octave's IP and port)
Deprecation
- All the functions that config octave through the OctaveConfig object
- All the functions that config the octave through the QMOctave object
1.1.4 - 2023-09-07¶
Deprecation
- Starting from version 1.2.0,
QuantumMachinesMananger.version()
will have a different return type. ServerDetails.qop_version
has been renamed toServerDetails.server_version
.
Added
- Added
QuantumMachinesMananger.version_dict()
which returns a dict with two keysqm-qua
andQOP
. - Two new keys were added to the dict returned by
QuantumMachinesMananger.version()
:qm-qua
andQOP
.
Fixed
- Fixed missing import of
ClockMode
. - Fixed simulations with negative IF frequency (in mixer).
- Fixed simulations with the new sticky API.
- Fixed conversion back to ns of the sticky duration for the config received from the OPX.
- Fixed rare cases in which the octave failed to boot.
- Fixed the serialization for a list in a
.maps(FUNCTION.average(list))
call in the stream processing. - Serialization will now not give an error if it fails to generate a config with the QMM configuration.
- Intermediate frequency returns with the same sign as it was set in te config.
- Deprecation warnings are now shown by default.
Changed
- If no port is given to
QuantumMachinesManager
, and there isn't a saved configuration file, it will default to80
(instead of80
&9510
)
1.1.3 - 2023-05-29¶
Fixed
- Fixed negative IF freq handling in config builder
- Sticky Element duration is to be given in ns and not clock cycles
- Fixed a bug that prevents opening many QMMs/QMs due to thread exhaustion when creating Octave clients.
- The deprecated
strict
andflags
arguments now work but give a deprecation warning. - Fixed the version of typing-extensions, to prevent import-error
1.1.2 - 2023-05-11¶
Deprecation
- Moved
qm.QuantumMachinesManager.QuantumMachinesManager
path toqm.quantum_machines_manager.QuantumMachinesManager
. Old path will be removed in 1.2.0
Added
- Added
qmm.validate_qua_config()
for config validation without opening a qm - Added support for getting clusters by name in
QuantumMachinesManager
- Added a
py.typed
file, that marks the package as supporting type-hints. - Added a default (minimal) duration for sticky elements
- Added
qm.get_job(job_id)
to retreieve previously ran jobs
Fixed
- Fixed creating credentials for authentication in gRPC
- Removed redundant entry from element generated class (
up_converted
) - Float frequency support - fixed the creation of config classes so integer frequency will always exist
- Fixed creating a mixer dict-config from protobuf class instance
- Fixed error raised when fetching saved data in the backwards compatible
- Fixed creating a digital port dict-config from protobuf class instance
- Fixed event-loop Windows bug of creating multiple instances of QuantumMachine
1.1.1 - 2023-03-20¶
Fixed
- Fixed long delay while waiting for values
1.1.0 - 2023-03-16¶
Note, this version (and all future versions) does not support QOP 2.0.0 or 2.0.1
Deprecation
- The
hold_offset
entry in the config is deprecated and is replaced by a newsticky
entry with an improved API - Moved
_Program
path toqm.program.program.Program
. Old path will be removed in 1.2.0 - Moved
QmJob
path toqm.jobs.qm_job.QmJob
. Old path will be removed in 1.2.0 - Moved
QmPendingJob
path toqm.jobs.pending_job.QmPendingJob
. Old path will be removed in 1.2.0 - Moved
QmQueue
path toqm.jobs.job_queue.QmQueue
. Old path will be removed in 1.2.0 - Renamed
JobResults
intoStreamingResultFetcher
. Old name will be removed in 1.2.0 - Moved
StreamingResultFetcher
path toqm.results.StreamingResultFetcher
. QmJob.id()
is deprecated, useQmJob.id
instead, will be removed in 1.2.0QmJob
no longer hasmanager
propertyQmPendingJob.id()
is deprecated, useQmPendingJob.id
instead, will be removed in 1.2.0QuantumMachine
no longer hasmanager
propertyQuantumMachine.peek
is removed (was never implemented)QuantumMachine.poke
is removed (was never implemented)IsInt()
function for qua variables is deprecated, useis_int()
instead, will be removed in 1.2.0IsFixed()
function for qua variables is deprecated, useis_fixed()
instead, will be removed in 1.2.0IsBool()
function for qua variables is deprecated, useis_bool()
instead, will be removed in 1.2.0set_clock
method of the octave changed API, old API will be removed in 1.2.0.- Deprecated the
strict
andflags
kwargs arguments in theexecute
andsimulate
functions.
Added
- Added autocorrection for config dict in IDEs, when creating a config, add the following:
config: DictQuaConfig = {...}
. - Added the option to invert the digital markers in a quantum machine by indicating it in the config.
- Support
fast_frame_rotation
, a frame rotation with a cosine and sine rotation matrix rather than an angle. - Added support for floating point numbers in the
intermediate_frequency
field ofelement
. - Conditional
play
is extended to both the digital pulse if defined for operation. - Extended the sticky capability to include the digital pulse (optional)
- Added option to validate QUA config with protobuf instead of marshmallow. It is usually faster when working with large configs, to use this feature, set
validate_with_protobuf=True
while opening a quantum machine. - Added type hinting for all
qua
functions and programs - Added another way of getting results from job results:
job.result_handles["result_name"]
.` - Octave reset request command added to "Octave manager".
- Added support for octave configuration inside the QUA-config dictionary, this will later deprecate the
OctaveConfig
object, which is still supported - Added objects that reflects the elements in the
QuantumMachine
instance. - Added the waveform report for better displaying simulation results.
Changed
- Updated
play
docstrings to reflect that the changes to conditional digital pulse. - Changed octave's
set_clock
API. - Changed and improved internal grpc infrastructure
- Changed and improved async infrastructure
1.0.2 - 2023-01-01¶
Removed
- Removed deprecated
math
library (use {class}~qm.qua.lib.Math
instead). - Removed deprecated
qrun_
context manager (use {func}~qm.qua._dsl.strict_timing_
instead).
Added
- Better exception error printing.
- An api to add more information to error printing
activate_verbose_errors
- Add support for OPD (Please check the OPD documentation for more details).
- Added timestamps for {func}
~qm.qua._dsl.play
and {func}~qm.qua._dsl.measure
statements. - Support for numpy float128.
- Added the function {func}
qm.user_config.create_new_user_config
to create a configuration file with the QOP host IP & Port to allow opening {func}~qm.QuantumMachinesManager.QuantumMachinesManager
without inputs. - Added infrastructure for anonymous log sending (by default, no logs are sent).
Fixed
- Serializer - Added support for averaging on different axes.
- Serializer - Remove false message about lacking
play(ramp()...)
support. - Serializer - Fixed the serialization when
.length()
is used. - Serializer - Fixed cases in which the serializer did not deal with
adc_trace=true
properly. - Serializer - The serializer does not report failed serialization when the only difference is the streams' order.
- Serializer - The serializer now correctly serialize the configuration when an element's name has a
'
.
1.0.1 - 2022-09-22¶
Changed
- Octave - Added a flag to not close all the quantum machines in {func}
~qm.octave.qm_octave.QmOctave.calibrate_element
. - Octave - The quantum machine doing the calibrations will be closed after the calibration is done.
1.0.0 - 2022-09-04¶
- Removed deprecated entries from the configuration schema
- Removed dependency in
qua
package
Fixed
- QuantumMachineManager - Fixed a bug where you could not connect using SSL on python version 3.10+
- Serializer - Fixed
declare_stream()
withadc_true=True
Changed
- Update betterproto version.
- OctaveConfig: changed
set_device_info
name toadd_device_info
- OctaveConfig: changed
add_opx_connections
name toadd_opx_octave_port_mapping
- OctaveConfig: changed
get_opx_octave_connections
name toget_opx_octave_port_mapping
Added
- API to control Octave - an up-conversion and down-conversion module with built-in Local Oscillator (LO) sources.
- Support Numpy as input - Support numpy scalars and arrays as valid input. Numpy object can now be used interchangeably with python scalars and lists. This applies to all statements imported with
from qm.qua import *
- Serializer - Added support for legacy save
0.3.8 - 2022-07-10¶
Fixed
- Serializer - Fixed a bug which caused binary expression to fail
Changed
- QuantumMachineManager will try to connect to 80 before 9510 if the user did not specify a port.
- QuantumMachineManager will give an error if no host is given and config file does not contain one.
- QRun - Change qrun to strict_timing
- Input Stream - Fixed API for input stream
Added
- Serializer - add strict_timing to serializer
- Logger - Can now add an environment variable to disable the output to stdout
0.3.7 - 2022-05-31¶
Fixed
- Serializer - Fixed a bug which caused the serializer to fail when given completely arbitrary integration weights
- Serializer - Fixed a bug which caused the serializer to fail when given a list of correction matrices
- Serializer - Added support for "pass" inside blocks (if, for, etc). "pass" inside "else" is not supported.
Added
- play - Add support for continue chirp feature
- High Resolution Time Tagging - Add support for high resolution time-tagging measure process
- Input Stream - Add support for streaming data from the computer to the program
- OPD - Added missing OPD timetagging function
Changed
- set_dc_offset - 2nd input for function was renamed from
input_reference
toelement_input
- QuantumMachineManager will try to connect to ports 9510 and 80 if the user did not specify a port.
- set_output_dc_offset_by_element - can now accept a tuple of ports and offsets
signalPolarity
in the timetagging parameters (outputPulseParameters
in configuration) now acceptAbove
andBelow
instead ofRising
andFalling
, which better represent it's meaning.
0.3.6 - 2022-01-23¶
Added
signalPolarity
in the timetagging parameters (outputPulseParameters
in configuration) now accept alsoRising
andFalling
, which better represent it's meaning.derivativePolarity
in the timetagging parameters (outputPulseParameters
in configuration) now accept alsoAbove
andBelow
, which better represent it's meaning.- Add unsafe switch to
generate_qua_config
function. - Add library functions and
amp()
in measure statement togenerate_qua_config
function.
Changed
- Better error for library functions as save source
0.3.5 - 2021-12-27¶
Added
- Raises an error when using Python logical operators
- Add elif statement to
generate_qua_config
function
Changed
- Fix indentation problem on the end of for_each block in
generate_qua_config
function - The
generate_qua_config
now compresses lists to make the resulting file smaller and more readable
0.3.4 - 2021-12-05¶
Added
- Define multiple elements with shared oscillator.
- Define an analog port with channel weights.
- Add measure and play features to
generate_qua_config
function - format
generate_qua_config
function output - improve
wait_for_all_values
execution time
0.3.3 - 2021-10-24¶
Added
- Define an analog port with delay.
- New
set_dc_offset()
statement that can change the DC offset of element input in real time. - New input stream capabilities facilitating data transfer from job to QUA.
- New flag for stream processing fft operator to control output type.
- Add information about demod on a tuple.
- Added best practice guide.
Changed
- Validate that element has one and only one of the available input type QMQUA-26
0.3.2 - 2021-10-03¶
Added
- QuantumMachinesManager health check shows errors and warnings.
- Fetching job results indicates if there were execution errors.
- Define an element with multiple input ports.
- Stream processing demod now supports named argument
integrate
. IfFalse
is provided the demod will not sum the items, but only multiply by weights.
Changed
- Documentation structure and content.
0.3.1 - 2021-09-13¶
Fixed
- Fixed serialization of IO values.
- Support running
QuantumMachinesManager
inside ipython or jupyter notebook.
Changed
- Removing deprecation notice from
with_timestamps
method on result streams. - Setting
time_of_flight
orsmearing
are required if element hasoutputs
and must not appear if it does not.
0.3.0 - 2021-09-03¶
Changed
- Support for result fetching of both versions of QM Server.
- Now the SDK supports all version of QM server.
0.2.1 - 2021-09-01¶
Changed
- Default port when creating new
QuantumMachineManager
is now80
and user config file is ignored.
0.2.0 - 2021-08-31¶
Added
- The original QM SDK for QOP 2.
0.1.0 - 2021-08-31¶
Added
- The original QM SDK for QOP 1.