-
Notifications
You must be signed in to change notification settings - Fork 197
/
Copy pathFDTD.py
53 lines (47 loc) · 2.37 KB
/
FDTD.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
""" From "COMPUTATIONAL PHYSICS" & "COMPUTER PROBLEMS in PHYSICS"
by RH Landau, MJ Paez, and CC Bordeianu (deceased)
Copyright R Landau, Oregon State Unv, MJ Paez, Univ Antioquia,
C Bordeianu, Univ Bucharest, 2017.
Please respect copyright & acknowledge our work."""
# FDTD.py FDTD Maxwell's equations in 1-D wi Visual
from visual import *
Xm = 201; Ym = 100; Zm = 100; ts = 2; beta = 0.01
Ex = zeros((Xm,ts),float); Hy = zeros((Xm,ts),float) # Arrays
# Set up 3-D Plots
scene = display(x=0,y=0,width= 800, height= 500,
title= 'E: cyan, H: red. Periodic BC',forward=(-0.6,-0.5,-1))
Eplot = curve(x=list(range(0,Xm)),color=color.cyan,
radius=1.5,display=scene)
Hplot = curve(x=list(range(0,Xm)),color=color.red,
radius=1.5,display=scene)
vplane = curve(pos=[(-Xm,Ym),(Xm,Ym),(Xm,-Ym),(-Xm,-Ym),
(-Xm,Ym)],color=color.cyan)
zaxis = curve(pos=[(-Xm,0),(Xm,0)],color=color.magenta)
hplane = curve(pos=[(-Xm,0,Zm),(Xm,0,Zm),(Xm,0,-Zm),(-Xm,0,-Zm),
(-Xm,0,Zm)],color=color.magenta)
ball1 = sphere(pos = (Xm+30, 0,0), color = color.black, radius = 2)
ExLabel1 = label( text = 'Ex', pos = (-Xm-10, 50), box=0)
ExLabel2 = label( text = 'Ex', pos = (Xm+10, 50), box=0)
HyLabel = label( text = 'Hy', pos = (-Xm-10, 0,50), box=0)
zLabel = label( text = 'Z', pos = (Xm+10, 0), box=0)
def PlotFields():
z = arange(Xm)
Eplot.x = 2*z-Xm # World to screen coords
Eplot.y = 800*Ex[z,0]
Hplot.x = 2*z-Xm
Hplot.z = 800*Hy[z,0]
z = arange(Xm)
Ex[:Xm,0] = 0.1*sin(2*pi*z/100.0) # Initial field
Hy[:Xm,0] = 0.1*sin(2*pi*z/100.0)
PlotFields()
while True:
rate(600)
Ex[1:Xm-1,1] = Ex[1:Xm-1,0] + beta*(Hy[0:Xm-2,0]-Hy[2:Xm,0])
Hy[1:Xm-1,1] = Hy[1:Xm-1,0] + beta*(Ex[0:Xm-2,0]-Ex[2:Xm,0])
Ex[0,1] = Ex[0,0] + beta*(Hy[Xm-2,0] -Hy[1,0]) # BC
Ex[Xm-1,1] = Ex[Xm-1,0] + beta*(Hy[Xm-2,0] -Hy[1,0])
Hy[0,1] = Hy[0,0] + beta*(Ex[Xm-2,0] -Ex[1,0]) # BC
Hy[Xm-1,1] = Hy[Xm-1,0] + beta*(Ex[Xm-2,0] - Ex[1,0])
PlotFields()
Ex[:Xm,0] = Ex[:Xm,1] # New -> old
Hy[:Xm,0] = Hy[:Xm,1]