[关闭]
@c-xy 2016-12-11T16:55:41.000000Z 字数 2939 阅读 178

第十二次作业


一、背景
1.Laplace'equation


It can be written in a rectangular coordinate system as.
2.Poisson'equation

It is a Non-homogeneous partial differential equations.
二、代码
1

  1. import numpy as np
  2. from pylab import *
  3. from math import *
  4. import mpl_toolkits.mplot3d
  5. V0=[[[0 for i in range(21)]for j in range(21)]for k in range(21)]#i represents x, j represents y
  6. VV=[]
  7. VV.append(V0)
  8. s=0
  9. dx=0.1
  10. p0=[[[0 for i in range(21)]for j in range(21)]for k in range(21)]
  11. for i in [10]:
  12. for j in [10]:
  13. for k in [10]:
  14. p0[k][j][i]=1/dx**3
  15. p=[]
  16. p.append(p0)
  17. while True:
  18. VV.append(V0)
  19. p.append(p0)
  20. for m in range(1,len(V0)-1):
  21. for j in range(1,len(V0[1])-1):
  22. for i in range(1,len(V0[1][1])-1):
  23. VV[s+1][m][j][i]=(VV[s][m][j][i+1]+VV[s][m][j][i-1]+VV[s][m][j+1][i]+VV[s][m][j-1][i]+VV[s][m+1][j][i]+VV[s][m-1][j][i])/6.0+p[s][m][j][i]*dx**2/6.0
  24. VV[s]=np.array(VV[s])
  25. VV[s+1]=np.array(VV[s+1])
  26. dVV=VV[s+1]-VV[s]
  27. dV=0
  28. for k in range(len(V0)):
  29. for j in range(1,len(V0[1])-1):
  30. for i in range(1,len(V0[1][1])-1):
  31. dV=dV+abs(dVV[k][j][i])
  32. s=s+1
  33. if dV<0.0001 and s>1:
  34. break
  35. print s
  36. V=np.array(VV[-1][10])
  37. Ex=np.array(V0[10])
  38. Ey=np.array(V0[10])
  39. for j in range(1,len(V0[10])-1):
  40. for i in range(1,len(V0[10][1])-1):
  41. Ex[j][i]=-(V[j][i+1]-V[j][i-1])/(2*dx)
  42. Ey[j][i]=-(V[j+1][i]-V[j-1][i])/(2*dx)
  43. figure(figsize=[8,8])
  44. x=np.arange(-1.0,1.01,dx)
  45. y=np.arange(-1.0,1.01,dx)
  46. X,Y=np.meshgrid(x,y)
  47. CS = contour(X,Y,V,15)
  48. clabel(CS, inline=1, fontsize=10)
  49. xlim(-0.5,0.5)
  50. xlabel('x')
  51. ylim(-0.5,0.5)
  52. ylabel('y')
  53. title('Equipotential lines around a point charge in 3D')
  54. fig = figure(figsize=[8,8])
  55. ax = fig.add_subplot(111, projection='3d')
  56. ax.plot_surface(X, Y, V,rstride=1, cstride=1,linewidth=0)
  57. ax.set_xlabel('X')
  58. ax.set_ylabel('Y')
  59. ax.set_zlabel('V')
  60. title('electric potential')
  61. figure(figsize=[8,8])
  62. Q=quiver(X,Y,Ex,Ey,scale=100)
  63. xlim(-1,1)
  64. xlabel('x')
  65. ylim(-1,1)
  66. ylabel('y')
  67. title('Field lines around a point charge in 3D')
  68. show()

2

  1. import numpy as np
  2. from pylab import *
  3. from math import *
  4. import mpl_toolkits.mplot3d
  5. V0=[[[0 for i in range(21)]for j in range(21)]for k in range(21)]#i represents x, j represents y
  6. VV=[]
  7. VV.append(V0)
  8. s=0
  9. dx=0.1
  10. p0=[[[0 for i in range(21)]for j in range(21)]for k in range(21)]
  11. for i in [10]:
  12. for j in [10]:
  13. for k in [10]:
  14. p0[k][j][i]=1/dx**3
  15. p=[]
  16. p.append(p0)
  17. while True:
  18. VV.append(V0)
  19. p.append(p0)
  20. for m in range(1,len(V0)-1):
  21. for j in range(1,len(V0[1])-1):
  22. for i in range(1,len(V0[1][1])-1):
  23. VV[s+1][m][j][i]=(VV[s][m][j][i+1]+VV[s][m][j][i-1]+VV[s][m][j+1][i]+VV[s][m][j-1][i]+VV[s][m+1][j][i]+VV[s][m-1][j][i])/6.0+p[s][m][j][i]*dx**2/6.0
  24. VV[s]=np.array(VV[s])
  25. VV[s+1]=np.array(VV[s+1])
  26. dVV=VV[s+1]-VV[s]
  27. dV=0
  28. for k in range(len(V0)):
  29. for j in range(1,len(V0[1])-1):
  30. for i in range(1,len(V0[1][1])-1):
  31. dV=dV+abs(dVV[k][j][i])
  32. s=s+1
  33. if dV<0.0001 and s>1:
  34. break
  35. print s
  36. V=[]
  37. x=np.linspace(0.1,1.0,10)
  38. X=np.linspace(0.01,1.00,99)
  39. Y=[]
  40. for i in range(len(X)):
  41. Y.append(1/(4*pi*X[i]))
  42. for i in range(11,21):
  43. V.append(VV[-1][10][10][i])
  44. figure(figsize=[8,8])
  45. plot(X,Y)
  46. scatter(x,V)
  47. title('Potential near a point charge')
  48. legend(('V versus x(y=0,z=0)'),'upper right')
  49. xlabel('x')
  50. ylabel('V')
  51. xlim(0,1.1)
  52. ylim(0,1.1)
  53. show()

三、致谢
感谢李鹏对我本次作业的帮助!

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注