mindquantum.algorithm.qaia.NMFA
- class mindquantum.algorithm.qaia.NMFA(J, h=None, x=None, n_iter=1000, batch_size=1, alpha=0.15, sigma=0.15)[源代码]
含噪平均场退火算法。
参考文献:Emulating the coherent Ising machine with a mean-field algorithm。
说明
为了内存效率,输入数组 'x' 不会被复制,并且会在优化过程中被原地修改。 如果需要保留原始数据,请使用 x.copy() 传入副本。
- 参数:
J (Union[numpy.array, scipy.sparse.spmatrix]) - 耦合矩阵,维度为 \((N \times N)\)。
h (numpy.array) - 外场强度,维度为 \((N, )\)。
x (numpy.array) - 自旋初始化配置,维度为 \((N \times batch\_size)\)。会在优化过程中被修改。如果不提供(
None
),将被初始化为全零数组。默认值:None
。n_iter (int) - 迭代步数。默认值:
1000
。batch_size (int) - 样本个数。默认值为:
1
。alpha (float) - 动量系数。默认值:
0.15
。sigma (float) - 噪声标准差。默认值:
0.15
。
样例:
>>> import numpy as np >>> from mindquantum.algorithm.qaia import NMFA >>> J = np.array([[0, -1], [-1, 0]]) >>> solver = NMFA(J, batch_size=5) >>> solver.update() >>> print(solver.calc_cut()) [1. 1. 1. 1. 1.] >>> print(solver.calc_energy()) [-1. -1. -1. -1. -1.]