双约束重力模型
作者:互联网
c = [[0, 0, 0, 0], [0, 2, 4, 4], [0, 4, 1, 2], [0, 4, 2, 2]] o = [0, 8, 14, 10] d = [0, 8, 14, 10] am = [0, 1, 1, 1] ampl1 = [0, 0, 0, 0] bm = [0, 0, 0, 0] bmpl1 = [0, 0, 0, 0] mi = 0.01 e = 0.05 m = 0 for j in range(1, 4): sumnum = 0 for i in range(1, 4): sumnum += am[i] * o[i] * pow(c[i][j], -mi) bm[j] = 1 / sumnum for i in range(1, 4): sumnum = 0 for j in range(1, 4): sumnum += bm[j] * d[j] * pow(c[i][j], -mi) ampl1[i] = 1 / sumnum for j in range(1, 4): sumnum = 0 for i in range(1, 4): sumnum += ampl1[i] * o[i] * pow(c[i][j], -mi) bmpl1[j] = 1 / sumnum def ifif(a, b, c, d): f = [0, 0, 0, 0, 0] for i in range(1, 4): if (a[i] / b[i] > 1 - e and a[i] / b[i] < 1 - e) and (c[i] / d[i] > 1 - e and c[i] / d[i] < 1 + e): f[i] = True if (f[1] and f[2]) and f[3]: return True else: return False for k in range(50): if not ifif(ampl1, am, bmpl1, bm): m += 1 mi += 0.05 for j in range(1, 4): sumnum = 0 for i in range(1, 4): sumnum += am[i] * o[i] * pow(c[j][i], -mi) bm[j] = 1 / sumnum print(bm[j]) for i in range(1, 4): sumnum = 0 for j in range(1, 4): sumnum += bm[j] * d[j] * pow(c[i][j], -mi) ampl1[i] = 1 / sumnum for j in range(1, 4): sumnum = 0 for i in range(1, 4): sumnum += ampl1[i] * o[i] * pow(c[j][i], -mi) bmpl1[j] = 1 / sumnum print(am, ampl1, bm, bmpl1, mi)
2020-05-26
标签:bm,模型,mi,ampl1,约束,range,sumnum,pow,重力 来源: https://www.cnblogs.com/hany-postq473111315/p/12968621.html