テスラコイル
偶にyoutubeとかで高電圧の動画を見るたびに作ってみたいと思っていました。
この人の作ったやつはガチでやばいです。
絶対爆音
テスラコイルを見ていて思うのが、
$\huge{2次コイルと1次コイルの間隙広すぎない?}$
ってことだと思います。
いくら、2次コイルの巻き数が大きいからといっても、こんなに距離が離れていたら漏れインダクタンスが大きくてまともにトランスとして動作しないんじゃないか?と私は思いました。
補足
ちなみに、テスラコイルはSGTC(Spark Gap Tesla Coil)とSSTC(Solid State Tesla Coil)があります。
DRSSTC(二重共振半導体テスラコイル):共振を2重に取る
いろんな名前がついていますが、交流発振の方法の違いだと理解してます
共振というのが重要な点なのでしょう
テスラの記述で
エジソンのエジソン電灯会社の求人を見つけ採用される。当時、同社は直流による電力事業を展開していて、一方、テスラは交流による電力事業を提案し、エジソンと対立して数ヶ月で失職する。
晩年は金銭苦に陥り、亡くなった時点でほぼ無一文であった
というのがあります。いつの時代も生きるのはつらいものですね。
テスラコイルの原理:集中定数回路として解析
結論:2次回路$L_2,C_2$の共振周波数$ \omega = \sqrt{\frac{1}{C_2 L_2}}$を入力すると、電圧増幅率がかなり高くできる。結合定数は低いほど電圧増幅率は高くなる。
周波数に対するグラフ
2次系の伝達関数と同じ形をしている。
周波数が低いうちは$C_2$のインピーダンスが低く、2次回路に電流が流れないため
$V_2 / V_1 = k \sqrt{\frac{L_2}{L_1}}=0.01 * \sqrt{2500} = 0.5$で一定になる。
周波数が上がるほど$C_2$に電流が流れ始め、$I_2$の逆起電圧によって$I_1$が減少し、結果$V_2 / V_1$が低下する。
共振周波数のときは、2次回路の合計インピーダンスは0になり、短絡状態になる。
上の計算式において$F=0$となり、$I_1 = 0,V_1 = j\omega M I_2,V_2 = -\frac{I_2}{j \omega C_2}$となる。
$I_1$が現実的に0になるわけではないが、2次回路側が共振して高いエネルギー(電圧)を持ってしまって、1次側からのエネルギー供給を受け付けないと考える。2次側の電流による逆起電圧で1次側に電流が流れなくなってしまうということだ。
結合定数が低いほど電圧増幅率が高いのは、結合定数が低いほど2次側の電流に対して、1次側の逆起電圧が低くなるため、2次側の電流がより高くできるためである。
直感的には結合定数は1に近づけるもののイメージであるが、テスラコイルにおいては異なる結論となる。
import numpy as np
import matplotlib.pyplot as plt
w_sync = 100*10**3
L2 = 0.05
C2 = 1/L2/(w_sync**2)
L1 = L2/2500
k=0.01
M = k*np.sqrt(L1*L2)
# xの値を生成
w = np.linspace(0, 10**8, 10**6)
G = -1/ ( C2 * (L1*L2/M - M) * w**2 - L1/M)
# グラフを描く
plt.figure(figsize=(10, 6))
#plt.plot(w, abs(F))
#plt.plot(w, abs(k))
plt.plot(w, abs(G))
#plt.plot(w, np.degrees(np.angle(I)))
plt.xlabel("w")
plt.ylabel("|V2/V1|")
plt.grid(True)
plt.xscale('log') # ←ここでx軸を対数にする
plt.yscale('log') # ←ここでx軸を対数にする
plt.axhline(0, color='black', linewidth=0.5)
plt.axvline(0, color='black', linewidth=0.5)
plt.show()
2次側回路に抵抗を追加した結果
2次側共振であることで、テスラコイルは結合率が低くても増幅率が高くできた。
現実的には抵抗を入ることになる、試してみよう。
きれいにはまとまらなかった、グラフにしてみる
抵抗が入るとやはり、共振時の電圧増幅率は大幅に減少する。
分布定数的解析①
分布定数回路について以前書いた記事
電信方程式に基づいて、電気信号が線路端で反射することが理解できます。
空芯コイルは次のように考えます
$\alpha, \beta$ともに複素数としての役割なので、符号は位相を意味する。ゲインが重要になる。
| \frac{V_n}{V_0}| > 1
上記となれば、電圧はテスラコイルを通して増幅することになる。
適切な$Z$を選択できれば、かなりの増幅率を得ることが可能になる。
適切なZについて
Rを追加して解く
適切なZについて
Z= (-480667.2877785036-113639.12482537022j)
import numpy as np
import matplotlib.pyplot as plt
# xの値を生成
w = np.linspace(0, 10**8, 10**6)
#Z=5*10**5
Z =1j*471
V0=1
R=400
L=0.05
C=0.0000001
Len = 471.238
F = 1/(R+L*1j*w) + C*1j*w
w2 = 1*10**4
F1 = 1/(R+L*1j*w2) + C*1j*w2
Z= -1*Len/F1
Z = 1/(1/Z + 1/10000000)
print(Z)
k = F*Z/Len/ (1 + F*Z/Len)
# グラフを描く
#plt.plot(w, abs(F))
#plt.plot(w, abs(k))
plt.plot(w, abs(k))
#plt.plot(w, np.degrees(np.angle(I)))
plt.xlabel("w")
plt.ylabel("|Vn/V0|")
plt.grid(True)
plt.xscale('log') # ←ここでx軸を対数にする
plt.axhline(0, color='black', linewidth=0.5)
plt.axvline(0, color='black', linewidth=0.5)
plt.show()
実験と検証
上記の回路でスイープ波を入力して周波数特性を測定してみます。
$100kHz$あたりに高いピークを持っています。2次共振系特有の曲線が出ています。
う~ん、現象を説明できない。
分布定数回路のモデルが間違っているんだろうか
考察
分布定数回路モデルではなく、集中定数回路で考えるのが正しいのか?
二次コイル側が単体で共振を起こしているのか?
ノッチフィルターみたいになっている。説明にならないなぁ
import matplotlib.pyplot as plt
import numpy as np
import cmath
import math
omega = np.logspace(-2,7,num = 100000) #10^-2 ~ 10^3
c=0.00001
L=0.5
R=10
G = (1-c*L*omega**2) / ( 1 - c*L*omega**2 + L/R*1j*omega)
#G = (1) / ( 1 - c*L*omega**2 + L/R*1j*omega)
print(math.sqrt(1/c/L)/2/np.pi)
fz = omega / 2 /np.pi
fig = plt.figure(figsize=(8, 12))
ax1 = fig.add_subplot(2,1,1)
ax2 = fig.add_subplot(2,1,2)
ax1.plot(fz,abs(G))
ax1.set_xscale("log")
ax1.set_yscale("log")
ax1.set_xlabel("freq[Hz]")
ax1.set_ylabel("G(Hz)")
ax2.plot(fz,np.angle(G)*180/np.pi)
ax2.set_xscale("log")
ax2.set_xlabel("freq[Hz]")
ax2.set_ylabel("phase[deg]")
plt.show()
考察2
100kHzあたりで振動するようにCの値を調整しました。
実験のグラフっぽくはできた。
import matplotlib.pyplot as plt
import numpy as np
import cmath
import math
omega = np.logspace(-2,9,num = 100000) #10^-2 ~ 10^3
c=0.000000000001
L=0.05
R=680000
#G = (1-c*L*omega**2) / ( 1 - c*L*omega**2 + L/R*1j*omega)
#G = (1) / ( 1 - c*L*omega**2 + L/R*1j*omega)
G =1 / ( 1 - c*L*omega**2 + L/R*1j*omega)
print(math.sqrt(1/c/L)/2/np.pi)
fz = omega / 2 /np.pi
fig = plt.figure(figsize=(8, 12))
ax1 = fig.add_subplot(2,1,1)
ax2 = fig.add_subplot(2,1,2)
ax1.plot(fz,abs(G))
ax1.set_xscale("log")
ax1.set_yscale("log")
ax1.set_ylim(bottom=1e-2)
ax1.set_ylim(top = 1e+1)
ax1.set_xlabel("freq[Hz]")
ax1.set_ylabel("G(Hz)")
ax2.plot(fz,np.angle(G)*180/np.pi)
ax2.set_xscale("log")
ax2.set_xlabel("freq[Hz]")
ax2.set_ylabel("phase[deg]")
plt.show()
つづく