-
-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathstreamplot.jl
43 lines (43 loc) · 1.34 KB
/
streamplot.jl
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
using CairoMakie, LinearAlgebra
CairoMakie.activate!()
function E(q, rx, ry, x, y)
d = sqrt((x-rx)^2 + (y-ry)^2)^3
return (q * (x - rx) / d, q * (y - ry) / d)
end
function charges(; nq = 2)
qs = []
for i in 1:nq
q = i % 2 * 2 - 1
push!(qs, (q, cos(2π * i / nq), sin(2π * i / nq)))
end
qs
end
function fieldE(x,y)
Ex, Ey = 0, 0
for q in qs
ex, ey = E(q..., x, y)
Ex += ex
Ey += ey
end
Point(Ex, Ey)
end
set_theme!(theme_dark())
fig = Figure(resolution = (600,400))
ax1 = Axis(fig[1,1]; aspect = DataAspect())
ax2 = Axis(fig[1,2]; aspect = DataAspect())
# bug alert, arrows are still not quite in the right direction
qs = charges()
streamplot!(ax1, fieldE, -2..2, -2..2; arrow_size = 6, linewidth = 0.5,
colorrange = (-3,3), colormap = :CMRmap)
[scatter!(ax1, Point(qs[i][2:3]), color = qs[i][1] > 0 ? :red : :dodgerblue,
markersize = 10) for i in 1:length(qs)]
qs = charges(; nq = 4)
streamplot!(ax2, fieldE, -2..2, -2..2; arrow_size = 6, linewidth = 0.5,
colorrange = (-3,3), colormap = :CMRmap)
[scatter!(ax2, Point(qs[i][2:3]), color = qs[i][1] > 0 ? :red : :dodgerblue,
markersize = 10) for i in 1:length(qs)]
limits!(ax, -2,2,-2,2)
hidedecorations!(ax1; grid = false)
hidedecorations!(ax2; grid = false)
save("streamplot.png", fig, px_per_unit = 2)
fig