1.1 Jacobi迭代算法
1.2 张量A的生成函数和向量b的生成函数:
def Creat_A(m,n):#生成张量Asize=np.full(m, n)X=np.ones(n)while 1:#随机生成给定形状的张量AA=np.random.randint(-49,50,size=size)#判断Dx**(m-2)是否非奇异,如果是,则满足要求,跳出循环D=np.copy(A)for i1 in range(n):for i2 in range(n):if i1!=i2:D[i1,i2]=0for i in range(m-2):D=np.dot(D,X)det=np.linalg.det(D)if det!=0:break#将A的对角面张量扩大十倍,使对角面占优for i1 in range(n):for i2 in range(n):if i1==i2:A[i1,i2]=A[i1,i2]*10print('A:')print(A)return A#由A和给定的X根据Ax**(m-1)=b生成向量bdef Creat_b(A,X,m):a=np.copy(A)for i in range(m-1):a=np.dot(a,X)print('b:')print(a)return a1.3 对称张量S的生成函数:
def Creat_S(m,n):#生成对称张量Bsize=np.full(m, n)S=np.zeros(size)print('S',S)for i in range(4):#生成n为向量aa=np.random.random(n)*np.random.randint(-5,6)b=np.copy(a)#对a进行m-1次外积,得到秩1对称张量bfor j in range(m-1):b=outer(b,a)#将不同的b叠加得到低秩对称张量SS=S+bprint('S:')print(S)return Sdef outer(a,b):c=[]for i in b:c.append(i*a)return np.array(c)return a1.4 实验一
def test_1():Delta=0.01#精度m=3#A的阶数n=3#A的维数M=200#最大迭代步数X_real=np.array( [2,3,4])A=Creat_A(m,n) b=Creat_b(A,X_real,m)Jacobi_tensor_V2(A,b,Delta,m,n)以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。