一次元拡散方程式のシミュレーションのプログラミングを作成しています。一通りシミュレーションの計算までプログラムを組んで実行しようとしたところ、「singular matrix」というエラーが発生してしまいました。行列に問題があるときにでるエラーとのことですが、どこに問題があるかさっぱりわかりません。どなたかご指摘いただけないでしょうか?
python
1import numpy as np 2import matplotlib.pyplot as plt 3import math 4import matplotlib.animation as animation 5 6T = 2 7nx = 41 8nt = 201 9dx = math.pi/(nx-1) 10dt = 0.01 11du = 0.3 12alpha = 0.1 13beta = 1.0 14gamma = 10.0 15X = np.linspace(0,math.pi,nx) 16 17#初期条件 18u1 = [] 19u2 = [] 20u3 = [] 21for i in range(nx): 22 x = dx*i 23 u1.append(math.cos(x)+math.cos(7*x)) 24 u2.append(math.cos(x)+math.cos(7*x)) 25 u3.append(math.cos(x)+math.cos(7*x)) 26 27fig = plt.figure() 28ims = [] 29for t in range(0,nt): 30 for i in range(1,nx-1): 31 u1[i] = u1[i]+alpha*dt/(dx*dx)*(u1[i+1]-2*u1[i]+u1[i-1]) 32 u2[i] = u2[i]+beta*dt/(dx*dx)*(u2[i+1]-2*u2[i]+u2[i-1]) 33 u3[i] = u3[i]+gamma*dt/(dx*dx)*(u3[i+1]-2*u3[i]+u3[i-1]) 34 im1 = plt.plot(X,u1,label="D=0.1") 35 im2 = plt.plot(X,u2,label="D=1.0") 36 im3 = plt.plot(X,u3,label="D=10.0") 37 ims.append(im1+im2+im3) 38 39 40plt.grid() 41plt.xlabel("x") 42plt.ylabel("u") 43anim = animation.ArtistAnimation(fig, ims) 44plt.show() 45
エラーが出るのは、コードのどこを実行した時ですか?
それが、プログラムを実行すると同じようなエラーが無数に出てくる上に、line1782,line97,line158,line2176…などと、どこからわからないlineばかりが指定されて、どこでエラーが起きてるかすらわからない状況です…
fig =...以降のグラフ作る部分をコメント化して、下記のように変えてください
(インデントは元のを維持したまま)
#fig = plt.figure()
#ims = []
for t in range(0,nt):
for i in range(1,nx-1):
u1[i] = u1[i]+alpha*dt/(dx*dx)*(u1[i+1]-2*u1[i]+u1[i-1])
u2[i] = u2[i]+beta*dt/(dx*dx)*(u2[i+1]-2*u2[i]+u2[i-1])
u3[i] = u3[i]+gamma*dt/(dx*dx)*(u3[i+1]-2*u3[i]+u3[i-1])
#im1 = plt.plot(X,u1,label="D=0.1")
#im2 = plt.plot(X,u2,label="D=1.0")
#im3 = plt.plot(X,u3,label="D=10.0")
#ims.append(im1+im2+im3)
#plt.grid()
#plt.xlabel("x")
#plt.ylabel("u")
#anim = animation.ArtistAnimation(fig, ims)
#plt.show()
上記の下に、下記を追加してください
print(u1)
print(u2)
print(u3)
そして実行して、上記追加したprint()の結果を見てください
確認したところ、u3について[2.0,nan,nan,nan…,]という形で欠損値?のようなものが生まれていました。
わかりました。安定条件を考えずにやっていたのが原因のようです。何とか解決させることができました!ありがとうございました!
回答1件
あなたの回答
tips
プレビュー