paddle_quantum.state.common
常见的量子态的实现。
- to_state(data, num_qubits=None, backend=None, dtype=None)
根据给定的输入,生成对应的量子态。
- 参数:
data (Union[paddle.Tensor, np.ndarray, QCompute.QEnv]) – 量子态的数学解析形式。
num_qubits (int, optional) – 量子态所包含的量子比特数。默认为
None
,会自动从 data 中推导出来。backend (paddle_quantum.Backend, optional) – 指定量子态的后端实现形式。默认为
None
,使用全局的默认后端。dtype (str, optional) – 量子态的数据类型。默认为
None
,使用全局的默认数据类型。
- 返回:
生成的量子态。
- 返回类型:
paddle_quantum.State
- zero_state(num_qubits, backend=None, dtype=None)
生成零态。
- 参数:
num_qubits (int) – 量子态所包含的量子比特数。
backend (paddle_quantum.Backend, optional) – 指定量子态的后端实现形式。默认为 None,使用全局的默认后端。
dtype (str, optional) – 量子态的数据类型。默认为 None,使用全局的默认数据类型。
- 抛出:
NotImplementedError – 所指定的后端必须为量桨已实现的后端。
- 返回:
所生成的零态。
- 返回类型:
paddle_quantum.State
- computational_basis(num_qubits, index, backend, dtype=None)
生成计算基态 \(|e_{i}\rangle\) ,其中 \(|e_{i}\rangle\) 的第 \(i\) 个元素为 1,其余元素为 0。
- 参数:
num_qubits (int) – 量子态所包含的量子比特数。
index (int) – 计算基态 \(|e_{i}\rangle\) 的下标 \(i\) 。
backend (paddle_quantum.Backend, optional) – 指定量子态的后端实现形式。默认为
None
,使用全局的默认后端。dtype (str, optional) – 量子态的数据类型。默认为
None
,使用全局的默认数据类型。
- 抛出:
NotImplementedError – 所指定的后端必须为量桨已实现的后端。
- 返回:
所生成的计算基态。
- 返回类型:
paddle_quantum.State
- bell_state(num_qubits, backend=None)
生成贝尔态。
其数学表达形式为:
\[|\Phi_{D}\rangle=\frac{1}{\sqrt{D}} \sum_{j=0}^{D-1}|j\rangle_{A}|j\rangle_{B}\]- 参数:
num_qubits (int) – 量子态所包含的量子比特数。
backend (paddle_quantum.Backend, optional) – 指定量子态的后端实现形式。默认为
None
,使用全局的默认后端。
- 抛出:
NotImplementedError – 所指定的后端必须为量桨已实现的后端。
- 返回:
生成的贝尔态。
- 返回类型:
paddle_quantum.State
- bell_diagonal_state(prob)
生成对角贝尔态。
其数学表达形式为:
\[p_{1}|\Phi^{+}\rangle\langle\Phi^{+}|+p_{2}| \Psi^{+}\rangle\langle\Psi^{+}|+p_{3}| \Phi^{-}\rangle\langle\Phi^{-}| + p_{4}|\Psi^{-}\rangle\langle\Psi^{-}|\]- 参数:
prob – 各个贝尔态的概率。
- Type:
List[float]
- 抛出:
Exception – 当后端为态矢量时,所输入量子态应该为纯态。
NotImplementedError – 所指定的后端必须为量桨已经实现的后端。
- 返回:
生成的量子态。
- random_state(num_qubits, is_real=False, rank=None)
生成一个随机的量子态。
- 参数:
num_qubits (int) – 量子态所包含的量子比特数。
is_real (bool, optional) – 是否为实数。默认为
False
,表示为复数。rank (int, optional) – 密度矩阵的秩。默认为
None
,表示使用满秩。
- 抛出:
NotImplementedError – 所指定的后端必须为量桨已经实现的后端。
- 返回:
随机生成的一个量子态。
- 返回类型:
paddle_quantum.State
- w_state(num_qubits)
生成一个 W-state。
- 参数:
num_qubits (int) – 量子态所包含的量子比特数。
- 抛出:
NotImplementedError – 所指定的后端必须为量桨已经实现的后端。
- 返回:
生成的 W-state。
- 返回类型:
paddle_quantum.State
- ghz_state(num_qubits)
生成一个 GHZ-state。
- 参数:
num_qubits (int) – 量子态所包含的量子比特数。
- 抛出:
NotImplementedError – 所指定的后端必须为量桨已经实现的后端。
- 返回:
生成的 GHZ-state。
- 返回类型:
paddle_quantum.State
- completely_mixed_computational(num_qubits)
生成一个完全混合态。
- 参数:
num_qubits (int) – 量子态所包含的量子比特数。
- 抛出:
Exception – 当后端为态矢量时,所输入量子态应该为纯态。
NotImplementedError – 所指定的后端必须为量桨已经实现的后端。
- 返回:
生成的 GHZ-state。
- 返回类型:
paddle_quantum.State
- r_state(prob)
生成一个 R-state。
其数学表达形式为:
\[p|\Psi^{+}\rangle\langle\Psi^{+}| + (1 - p)|11\rangle\langle11|\]- 参数:
prob (float) – 控制生成 R-state 的参数,它应该在 \([0, 1]\) 区间内。
- 抛出:
Exception – 当后端为态矢量时,所输入量子态应该为纯态。
NotImplementedError – 所指定的后端必须为量桨已经实现的后端。
- 返回:
生成的 R-state。
- 返回类型:
paddle_quantum.State
- s_state(prob)
生成一个 S-state。
其数学表达形式为:
\[p|\Phi^{+}\rangle\langle\Phi^{+}| + (1 - p)|00\rangle\langle00|\]- 参数:
prob (float) – 控制生成 S-state 的参数,它应该在 \([0, 1]\) 区间内。
- 抛出:
Exception – 当后端为态矢量时,所输入量子态应该为纯态。
NotImplementedError – 所指定的后端必须为量桨已经实现的后端。
- 返回:
生成的 S-state。
- 返回类型:
paddle_quantum.State
- isotropic_state(num_qubits, prob)
生成 isotropic state。
其数学表达形式为:
\[p(\frac{1}{\sqrt{D}} \sum_{j=0}^{D-1}|j\rangle_{A}|j\rangle_{B}) + (1 - p)\frac{I}{2^n}\]- 参数:
num_qubits (int) – 量子态所包含的量子比特数。
prob (float) – 控制生成 isotropic state 的参数,它应该在 \([0, 1]\) 区间内。
- 抛出:
Exception – 当后端为态矢量时,所输入量子态应该为纯态。
NotImplementedError – 所指定的后端必须为量桨已经实现的后端。
- 返回:
生成的 isotropic state。
- 返回类型:
paddle_quantum.State