nsqdriver 0.5.7__cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of nsqdriver might be problematic. Click here for more details.
- nsqdriver/NS_CST.py +260 -0
- nsqdriver/NS_MCI.py +564 -0
- nsqdriver/NS_QSYNC.py +721 -0
- nsqdriver/__init__.py +10 -0
- nsqdriver/common.py +20 -0
- nsqdriver/compiler/__init__.py +0 -0
- nsqdriver/compiler/assembler.cpython-38-x86_64-linux-gnu.so +0 -0
- nsqdriver/compiler/ns_wave.cpython-38-x86_64-linux-gnu.so +0 -0
- nsqdriver/compiler/ns_wave.pyi +151 -0
- nsqdriver/compiler/py_wave_asm.cpython-38-x86_64-linux-gnu.so +0 -0
- nsqdriver/compiler/py_wave_asm.pyi +29 -0
- nsqdriver/wrapper/AWG_ADC.py +534 -0
- nsqdriver/wrapper/ND_NSMCI.py +245 -0
- nsqdriver/wrapper/__init__.py +0 -0
- nsqdriver-0.5.7.dist-info/METADATA +104 -0
- nsqdriver-0.5.7.dist-info/RECORD +18 -0
- nsqdriver-0.5.7.dist-info/WHEEL +6 -0
- nsqdriver-0.5.7.dist-info/top_level.txt +1 -0
|
@@ -0,0 +1,245 @@
|
|
|
1
|
+
import numpy as np
|
|
2
|
+
from nsqdriver import MCIDriver, QSYNCDriver
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
class _XYChannel:
|
|
6
|
+
def __init__(self, mci: "DeviceBase", ch=1):
|
|
7
|
+
self.mci = mci
|
|
8
|
+
self.ch = ch
|
|
9
|
+
self.to_zero = np.zeros((16,))
|
|
10
|
+
self.to_one = np.ones((16,))
|
|
11
|
+
self.en = True
|
|
12
|
+
self.mode = 0
|
|
13
|
+
self.off = 0
|
|
14
|
+
|
|
15
|
+
def wave(self, w):
|
|
16
|
+
self.wavex(w, self.ch)
|
|
17
|
+
|
|
18
|
+
def wavex(self, w, idx):
|
|
19
|
+
if np.max(np.abs(w)) < 1e-30:
|
|
20
|
+
wr = np.zeros(16)
|
|
21
|
+
else:
|
|
22
|
+
wr = w
|
|
23
|
+
self.mci.mci_driver.set("Waveform", wr, idx)
|
|
24
|
+
|
|
25
|
+
def arm(self, k=None):
|
|
26
|
+
self.mci.mci_driver.set('PushWaveCache')
|
|
27
|
+
|
|
28
|
+
def trig_del(self, delay):
|
|
29
|
+
...
|
|
30
|
+
|
|
31
|
+
def output_del(self, delay):
|
|
32
|
+
...
|
|
33
|
+
|
|
34
|
+
def __del__(self):
|
|
35
|
+
pass
|
|
36
|
+
|
|
37
|
+
def output(self, b):
|
|
38
|
+
self.en = bool(b)
|
|
39
|
+
if not self.en:
|
|
40
|
+
self.mci.mci_driver.set("Waveform", self.to_zero, self.ch)
|
|
41
|
+
|
|
42
|
+
def mode(self, m_):
|
|
43
|
+
...
|
|
44
|
+
|
|
45
|
+
def offsetx(self, off, idx):
|
|
46
|
+
self.mci.mci_driver.set('Waveform', off*self.to_one, idx)
|
|
47
|
+
self.off = off
|
|
48
|
+
|
|
49
|
+
def offset(self, off):
|
|
50
|
+
self.offsetx(off, self.ch)
|
|
51
|
+
|
|
52
|
+
W = {
|
|
53
|
+
"wave": wave,
|
|
54
|
+
"output": output,
|
|
55
|
+
"trig_del": trig_del,
|
|
56
|
+
"output_del": output_del,
|
|
57
|
+
"mode": mode,
|
|
58
|
+
"offset": offset,
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
Q = {"arm": arm}
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
class _ZChannel(_XYChannel):
|
|
65
|
+
pass
|
|
66
|
+
|
|
67
|
+
|
|
68
|
+
class _Probe:
|
|
69
|
+
def __init__(self, mci: "DeviceBase", ch=1):
|
|
70
|
+
self.mci = mci
|
|
71
|
+
self.ch = ch
|
|
72
|
+
self.freqList = []
|
|
73
|
+
self.SGS = None # single shot temp cache
|
|
74
|
+
self.AVG = None # average temp cache
|
|
75
|
+
self.depth = 2000
|
|
76
|
+
self._width = 1000
|
|
77
|
+
self.start = 500
|
|
78
|
+
self.demod = 1
|
|
79
|
+
self.averaged_I = np.zeros((16384, )) # 直播直采,相当于只有I路数据
|
|
80
|
+
|
|
81
|
+
def depth(self, depth_):
|
|
82
|
+
self.depth = depth_
|
|
83
|
+
self.mci.mci_driver.set('PointNumber', depth_, self.ch)
|
|
84
|
+
|
|
85
|
+
def demodulation_on(self, demod_):
|
|
86
|
+
self.demod = int(demod_)
|
|
87
|
+
|
|
88
|
+
def start(self, start_):
|
|
89
|
+
self.start = start_
|
|
90
|
+
self.mci.mci_driver.set('TriggerDelay', start_, self.ch)
|
|
91
|
+
|
|
92
|
+
def width(self, width_):
|
|
93
|
+
self._width = width_/4e9
|
|
94
|
+
self.mci.mci_driver.set('PointNumber', width_, self.ch)
|
|
95
|
+
|
|
96
|
+
def freqs(self, *freqList_):
|
|
97
|
+
self.freqList = freqList_
|
|
98
|
+
self.mci.mci_driver.set('FreqList', freqList_, self.ch)
|
|
99
|
+
|
|
100
|
+
def shot(self, _shot):
|
|
101
|
+
self.mci.mci_driver.set('Shot', _shot)
|
|
102
|
+
|
|
103
|
+
def measure(self, k=None):
|
|
104
|
+
self.mci.mci_driver.set('StartCapture')
|
|
105
|
+
if self.demod:
|
|
106
|
+
self.SGS = self.mci.mci_driver.get('IQ', self.ch)
|
|
107
|
+
self.AVG = np.mean(self.SGS, axis=0)
|
|
108
|
+
else:
|
|
109
|
+
self.averaged_I = np.mean(self.mci.mci_driver.get('TraceIQ', self.ch), axis=0)
|
|
110
|
+
|
|
111
|
+
def single_shot(self, k=None):
|
|
112
|
+
return self.SGS
|
|
113
|
+
|
|
114
|
+
def average(self, k=None):
|
|
115
|
+
return self.AVG
|
|
116
|
+
|
|
117
|
+
def trace_I(self, k=None):
|
|
118
|
+
return self.averaged_I
|
|
119
|
+
|
|
120
|
+
def trace_Q(self, k=None):
|
|
121
|
+
return self.averaged_I
|
|
122
|
+
|
|
123
|
+
def __del__(self):
|
|
124
|
+
pass
|
|
125
|
+
|
|
126
|
+
W = {
|
|
127
|
+
"demod": demodulation_on,
|
|
128
|
+
"depth": depth,
|
|
129
|
+
"width": width,
|
|
130
|
+
"start": start,
|
|
131
|
+
"freqs": freqs,
|
|
132
|
+
"shot": shot,
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
Q = {
|
|
136
|
+
"measure": measure,
|
|
137
|
+
"A": average,
|
|
138
|
+
"S": single_shot,
|
|
139
|
+
"traceI": trace_I,
|
|
140
|
+
"traceQ": trace_Q
|
|
141
|
+
};
|
|
142
|
+
|
|
143
|
+
|
|
144
|
+
# one box need one class
|
|
145
|
+
class DeviceBase:
|
|
146
|
+
def __init__(self):
|
|
147
|
+
self.mci_driver = MCIDriver('127.0.0.1')
|
|
148
|
+
self.qsync_driver = QSYNCDriver('127.0.0.1')
|
|
149
|
+
|
|
150
|
+
|
|
151
|
+
class NS_MCI(DeviceBase):
|
|
152
|
+
def __init__(self, addr, srate=10e9, mixmode=2, ref_clk='in'):
|
|
153
|
+
"""!
|
|
154
|
+
此类涉及到系统同步,放到最后实例化
|
|
155
|
+
@param addr: 设备ip
|
|
156
|
+
@param srate: OUT通道采样率
|
|
157
|
+
@param mixmode: 为2时开启OUT通道混合模式,增强第二奈奎斯特区输出
|
|
158
|
+
@param ref_clk: 设备参考信号来源,不接外输出100M时都配置为'in'
|
|
159
|
+
"""
|
|
160
|
+
super(NS_MCI, self).__init__()
|
|
161
|
+
self.mci_driver = MCIDriver(addr)
|
|
162
|
+
self.qsync = QSYNCDriver(addr)
|
|
163
|
+
self.srate = srate
|
|
164
|
+
self.mixmode = mixmode
|
|
165
|
+
self.ref_clk = ref_clk
|
|
166
|
+
self.connect()
|
|
167
|
+
|
|
168
|
+
def connect(self):
|
|
169
|
+
mci_params = {'DArate': self.srate, 'MixMode': self.mixmode}
|
|
170
|
+
qsync_params = {'RefClock': self.ref_clk}
|
|
171
|
+
|
|
172
|
+
self.qsync.open(system_parameter=qsync_params)
|
|
173
|
+
self.mci_driver.open(system_parameter=mci_params)
|
|
174
|
+
self.qsync.sync_system()
|
|
175
|
+
|
|
176
|
+
self.mci_driver.set('EnableWaveCache', True)
|
|
177
|
+
|
|
178
|
+
for _ch in range(22):
|
|
179
|
+
xy_ch = _ch+1
|
|
180
|
+
setattr(self, f'OUT{xy_ch}', _XYChannel(self, xy_ch))
|
|
181
|
+
for _ch in range(2):
|
|
182
|
+
probe_ch = _ch+1
|
|
183
|
+
setattr(self, f'IN{probe_ch}', _Probe(self, probe_ch))
|
|
184
|
+
|
|
185
|
+
def trig_interval(self, interval):
|
|
186
|
+
self.interval = interval
|
|
187
|
+
self.qsync.set('TrigPeriod', int(interval))
|
|
188
|
+
|
|
189
|
+
def trig_count(self, count_):
|
|
190
|
+
self.qsync.set('Shot', int(count_))
|
|
191
|
+
|
|
192
|
+
def trig(self):
|
|
193
|
+
self.qsync.set('GenerateTrig', self.interval)
|
|
194
|
+
|
|
195
|
+
def awg_arm(self):
|
|
196
|
+
self.mci_driver.set('PushWaveCache')
|
|
197
|
+
|
|
198
|
+
def __del__(self):
|
|
199
|
+
pass
|
|
200
|
+
|
|
201
|
+
W = {
|
|
202
|
+
"trig_interval": trig_interval,
|
|
203
|
+
"trig_count": trig_count,
|
|
204
|
+
"connect": connect,
|
|
205
|
+
"trig": trig,
|
|
206
|
+
"awg_arm": awg_arm,
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
Q = {
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
|
|
213
|
+
class NS_Z(DeviceBase):
|
|
214
|
+
def __init__(self, addr, mixmode=2):
|
|
215
|
+
"""!
|
|
216
|
+
此类负责控制24 Z OUT通道的设备,采样率固定为2Gsps,mixmode固定为1
|
|
217
|
+
@param addr: 设备ip
|
|
218
|
+
@param mixmode: 为1时关闭OUT通道混合模式
|
|
219
|
+
"""
|
|
220
|
+
super(NS_Z, self).__init__()
|
|
221
|
+
self.mci_driver = MCIDriver(addr)
|
|
222
|
+
self.qsync = QSYNCDriver(addr)
|
|
223
|
+
self.srate = 2e9
|
|
224
|
+
self.mixmode = 1
|
|
225
|
+
self.connect()
|
|
226
|
+
|
|
227
|
+
def connect(self):
|
|
228
|
+
mci_params = {'DArate': self.srate, 'MixMode': self.mixmode}
|
|
229
|
+
self.mci_driver.open(system_parameter=mci_params)
|
|
230
|
+
|
|
231
|
+
self.mci_driver.set('EnableWaveCache', True)
|
|
232
|
+
|
|
233
|
+
for _ch in range(24):
|
|
234
|
+
xy_ch = _ch+1
|
|
235
|
+
setattr(self, f'OUT{xy_ch}', _ZChannel(self, xy_ch))
|
|
236
|
+
|
|
237
|
+
def awg_arm(self):
|
|
238
|
+
self.mci_driver.set('PushWaveCache')
|
|
239
|
+
|
|
240
|
+
W = {
|
|
241
|
+
"connect": connect,
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
Q = {
|
|
245
|
+
}
|
|
File without changes
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
Metadata-Version: 2.1
|
|
2
|
+
Name: nsqdriver
|
|
3
|
+
Version: 0.5.7
|
|
4
|
+
Summary: Naishu Q series quantum measurement and control equipment driver interface
|
|
5
|
+
Home-page: https://g2hoyqcmh4.feishu.cn/wiki/wikcnzvyMd82DLZUe2NsI6HxsFc
|
|
6
|
+
Author: Naishu Technology
|
|
7
|
+
Author-email: jilianyi@naishu.tech
|
|
8
|
+
Classifier: Intended Audience :: Developers
|
|
9
|
+
Classifier: Topic :: Scientific/Engineering :: Interface Engine/Protocol Translator
|
|
10
|
+
Classifier: Operating System :: MacOS :: MacOS X
|
|
11
|
+
Classifier: Operating System :: Microsoft :: Windows
|
|
12
|
+
Classifier: Operating System :: POSIX
|
|
13
|
+
Classifier: Programming Language :: Python :: 3.8
|
|
14
|
+
Classifier: Programming Language :: Python :: 3.9
|
|
15
|
+
Classifier: Programming Language :: Python :: 3.10
|
|
16
|
+
Classifier: Programming Language :: Python :: 3.11
|
|
17
|
+
Requires-Python: >=3.8
|
|
18
|
+
Description-Content-Type: text/markdown
|
|
19
|
+
Requires-Dist: numpy >=1.18
|
|
20
|
+
Provides-Extra: waveforms
|
|
21
|
+
Requires-Dist: waveforms ; extra == 'waveforms'
|
|
22
|
+
|
|
23
|
+
```
|
|
24
|
+
_ _ ____ ___ ____ _
|
|
25
|
+
| \ | | / ___| / _ \ | _ \ _ __ (_) __ __ ___ _ __
|
|
26
|
+
| \| | \___ \ | | | | | | | | | '__| | | \ \ / / / _ \ | '__|
|
|
27
|
+
| |\ | ___) | | |_| | | |_| | | | | | \ V / | __/ | |
|
|
28
|
+
|_| \_| |____/ \__\_\ |____/ |_| |_| \_/ \___| |_|
|
|
29
|
+
```
|
|
30
|
+
***
|
|
31
|
+
|
|
32
|
+
### 简介
|
|
33
|
+
NSQDriver为一套耐数®量子测控系列设备的Python通用驱动接口。可使用Python作为编程语言,基于此驱动接口可以实现对本公司测控设备的控制,进而完成各种超导量子芯片的表征实验和高保真门操作。
|
|
34
|
+
|
|
35
|
+
```
|
|
36
|
+
+------------------------+
|
|
37
|
+
| Python |
|
|
38
|
+
| +------------------+
|
|
39
|
+
| | NSQDriver |
|
|
40
|
+
+------------------------+
|
|
41
|
+
: : :
|
|
42
|
+
+---------- : -----+
|
|
43
|
+
: : :
|
|
44
|
+
V V V
|
|
45
|
+
+-----------+ +-----------+ +-----------+
|
|
46
|
+
| Device A | | Device B | | QSYNC |
|
|
47
|
+
+-----------+ +-----------+ +-----------+
|
|
48
|
+
```
|
|
49
|
+
|
|
50
|
+
NSQDriver接口可用于统一控制耐数®生产的Q100、MC、QSYNC等一系列量子测控仪器,可详细控制每台仪器每个OUT、IN通道的播放与采集行为,以及查看设备的运行状态等。在一个多台测控设备组成的多量子比特测控系统中,可以有效的在软件层面实现对系统中每台设备的详细控制。
|
|
51
|
+
|
|
52
|
+
耐数®量子测控系列设备详细信息参考: [耐数](http://naishu.tech)
|
|
53
|
+
|
|
54
|
+
***
|
|
55
|
+
### 快速开始
|
|
56
|
+
- 驱动接口的通用流程如下
|
|
57
|
+
```python
|
|
58
|
+
from nsqdriver import MCIDriver, QSYNCDriver
|
|
59
|
+
|
|
60
|
+
# 实例化设备驱动接口
|
|
61
|
+
driver = MCIDriver('127.0.0.1')
|
|
62
|
+
qsync = QSYNCDriver('127.0.0.1')
|
|
63
|
+
|
|
64
|
+
# 连接设备
|
|
65
|
+
qsync.open()
|
|
66
|
+
driver.open()
|
|
67
|
+
|
|
68
|
+
# 初始化系统
|
|
69
|
+
qsync.sync_system()
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
# 相关参数,参数细节相关参考 8.可用参数列表
|
|
73
|
+
driver.set('Shot', 1024)
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
- NSWave接口
|
|
77
|
+
- NSWave是一种对于耐数®Sequence序列发生技术的控制接口,Sequence序列发生模式将量子测控所需的各种门的编辑由主控计算机直接生成波形转化成了设备实时计算
|
|
78
|
+
- 提供了一套直观的时序编辑接口
|
|
79
|
+
- 如下示例展示了使用nswave控制设备重复播放一段波形200次
|
|
80
|
+
```python
|
|
81
|
+
from nsqdriver import InsChannel
|
|
82
|
+
import numpy as np
|
|
83
|
+
|
|
84
|
+
ch = InsChannel() # 生成参数化波形通道实例
|
|
85
|
+
|
|
86
|
+
frame_65e9 = ch.ins_frame(6.5e9) # 生成一个frame
|
|
87
|
+
frame_67e9 = ch.ins_frame(6.7e9) # 生成一个frame
|
|
88
|
+
|
|
89
|
+
gaussian = ch.evlp_gaussian(4500e-9) # 生成一个高斯包络
|
|
90
|
+
square = ch.evlp_square(2500e-9) # 生成一个方波包络
|
|
91
|
+
|
|
92
|
+
wave1 = gaussian * frame_67e9 # 生成一段高斯包络的波形
|
|
93
|
+
wave2 = square * frame_65e9 # 生成一段方波包络的波形
|
|
94
|
+
|
|
95
|
+
ch.ins_reset_frame('phase', frame_65e9)
|
|
96
|
+
ch.ins_reset_frame('phase', frame_67e9)
|
|
97
|
+
ch.wait_for_trigger() # 等待触发到来
|
|
98
|
+
# 循环播放200次 3μs延迟+ 7μs波形
|
|
99
|
+
with ch.ins_loop(times=200) as _loop:
|
|
100
|
+
_loop.play_zero(3000e-9)
|
|
101
|
+
_loop.inc_phase(frame_65e9, np.pi / 2)
|
|
102
|
+
_loop.play_wave(wave2)
|
|
103
|
+
_loop.play_wave(wave1)
|
|
104
|
+
```
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
nsqdriver/NS_CST.py,sha256=_QYCjg1YglIJ4YVmxvISqvy5rExWGlMhyrK9zYIRbRY,7877
|
|
2
|
+
nsqdriver/common.py,sha256=IHfShqgNN3THbe7KD7ICdfFY7JKC_kQj0_KJk-449gQ,499
|
|
3
|
+
nsqdriver/__init__.py,sha256=rprb8TO2c6Nxr7wTVBj8rSzWNJo60MReiFTM4zafVkM,371
|
|
4
|
+
nsqdriver/NS_MCI.py,sha256=LWaPn2XGjlT20gupsg8aDAvHVxmtmLehCmI63pt4m74,20791
|
|
5
|
+
nsqdriver/NS_QSYNC.py,sha256=Qq0y2eISRo2faRQk3U57RHeAbssvYy7ex5rsCfxNfLU,24743
|
|
6
|
+
nsqdriver/compiler/py_wave_asm.pyi,sha256=w2PWlBrns4tfDYjTLyOBfNgjjjVA_xzMJZYYyDPKce4,656
|
|
7
|
+
nsqdriver/compiler/assembler.cpython-38-x86_64-linux-gnu.so,sha256=5JEbVjx1Ipf4TL-cxJuulQdi0AxNfOVgCBhmJc8Tb_k,2508248
|
|
8
|
+
nsqdriver/compiler/ns_wave.cpython-38-x86_64-linux-gnu.so,sha256=4ZJ5jbGeMbrODteJJeYeIR2JuhSfaa38iXC5v-YqrX0,1781384
|
|
9
|
+
nsqdriver/compiler/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
10
|
+
nsqdriver/compiler/ns_wave.pyi,sha256=JQiE_9HqCzm00bS6c2JaaIXwt7xN_x9XXax-BBrE7-o,3824
|
|
11
|
+
nsqdriver/compiler/py_wave_asm.cpython-38-x86_64-linux-gnu.so,sha256=rfOht9g4RtyYCO_JRl98bQNqVKvjIXk57aIJFt-YAzQ,2371952
|
|
12
|
+
nsqdriver/wrapper/AWG_ADC.py,sha256=ktQkORc8VZUFkNg6huC7DKIkvZyHYXRolQ2SAA89JnM,19199
|
|
13
|
+
nsqdriver/wrapper/ND_NSMCI.py,sha256=gTyrDObhbggl35V_q-kpDoPsfttIEnDFc6f0-pk_P0k,6288
|
|
14
|
+
nsqdriver/wrapper/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
15
|
+
nsqdriver-0.5.7.dist-info/METADATA,sha256=5i6Xs_CCMOSABTy9tFyh9rRlgOXbHYPL0SWdFbGjBhI,4359
|
|
16
|
+
nsqdriver-0.5.7.dist-info/RECORD,,
|
|
17
|
+
nsqdriver-0.5.7.dist-info/top_level.txt,sha256=o7EbQoFO6BoaG3KGbS9Lg_aRheZSY5KYzoYuI9vx-AI,10
|
|
18
|
+
nsqdriver-0.5.7.dist-info/WHEEL,sha256=L0ABBnxO_xKRR_wTzM7WWWX8RRfdKRK-fZ5a3ZEhDqQ,148
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
nsqdriver
|