Original Mathematica File

強制振動

DSolveを用いてとにかく力任せに解いてみる(brute-force method)

 まず外力が正弦関数的に変化する場合の強制振動の例から論じることにしよう.減衰
振動をする系にこのような外力 F ="5ForcedOscillationVer6_1.gif"がかかったとすると、運動方程式は次のように書ける.

"5ForcedOscillationVer6_2.gif"

または,

"5ForcedOscillationVer6_3.gif"

ここで, A ="5ForcedOscillationVer6_4.gif"/m で,その他の記号の定義はこれまでどうりである.

ここでは力任せに解を求めてみよう.

次の方程式を解く.初期条件は"5ForcedOscillationVer6_5.gif"とする.

In[1]:=

"5ForcedOscillationVer6_6.gif"

Out[1]=

"5ForcedOscillationVer6_7.gif"

解を定義しておく.その前に,解を少し見やすくしておく.

In[2]:=

"5ForcedOscillationVer6_8.gif"

Out[2]=

"5ForcedOscillationVer6_9.gif"

In[3]:=

"5ForcedOscillationVer6_10.gif"

相当に複雑な解であるが(教科書は振幅、位相等を導入して見やすく書いてある.)、とにかく、変位、速度を適当な初期条件でプロットしてみよう.

変位は

In[4]:=

"5ForcedOscillationVer6_11.gif"

Out[4]=

"5ForcedOscillationVer6_12.gif"

となり、速度は、

In[5]:=

"5ForcedOscillationVer6_13.gif"

Out[5]=

"5ForcedOscillationVer6_14.gif"

となる.時間tが小さいところは複雑に振動するが、時間がたつと余関数が指数関数的に小さくなり(教科書参照)、特解のみが生き残る.

問1 上の図で時間が十分たったときの角振動数はいくらか.

問2 減衰パラメターbetaをもっと大きくすると系はどのように振る舞うか.

hint:以下のようにベターの値を変えて変位を時間の関数としてプロットしてみなさい.アウトプットはアニメーションで見て下さい.

In[6]:=

"5ForcedOscillationVer6_15.gif"

Out[6]=

"5ForcedOscillationVer6_16.gif"

In[7]:=

"5ForcedOscillationVer6_17.gif"

Out[7]=

"5ForcedOscillationVer6_18.gif"

位相空間図

ここでParametricPlotを使って位相空間図を描いてみよう.

In[8]:=

"5ForcedOscillationVer6_19.gif"

Out[8]=

"5ForcedOscillationVer6_20.gif"

問3 上の位相空間図を解釈せよ.(時間の経過に運動がどのように変わるか.)また、ベターの値を変えると位相空間図はどのように変わるか.

Hint: ベータを変えながら、速度と位置の相空間図を描いてみる.

In[9]:=

"5ForcedOscillationVer6_21.gif"

In[10]:=

"5ForcedOscillationVer6_22.gif"

Out[10]=

"5ForcedOscillationVer6_23.gif"

複素数を用い特解を求める

"5ForcedOscillationVer6_24.gif"

であることに注意して,

In[11]:=

"5ForcedOscillationVer6_25.gif"

Out[11]=

"5ForcedOscillationVer6_26.gif"

と仮定して,与えられた方程式に代入し,B を求める.

In[12]:=

"5ForcedOscillationVer6_27.gif"

Out[12]=

"5ForcedOscillationVer6_28.gif"

B を結果のように定義する.

In[13]:=

"5ForcedOscillationVer6_29.gif"

Out[13]=

"5ForcedOscillationVer6_30.gif"

B の絶対値 |B| を求めるには、

In[14]:=

"5ForcedOscillationVer6_31.gif"

Out[14]=

"5ForcedOscillationVer6_32.gif"

Aが正であるとして,

In[15]:=

"5ForcedOscillationVer6_33.gif"

Out[15]=

"5ForcedOscillationVer6_34.gif"

また,偏角をαとすると,αは

In[16]:=

"5ForcedOscillationVer6_35.gif"

Out[16]=

"5ForcedOscillationVer6_36.gif"

または,

In[17]:=

"5ForcedOscillationVer6_37.gif"

Out[17]=

"5ForcedOscillationVer6_38.gif"

以上より,"5ForcedOscillationVer6_39.gif" の特解は"5ForcedOscillationVer6_40.gif"

"5ForcedOscillationVer6_41.gif"

で,

Tan[α]="5ForcedOscillationVer6_42.gif"
である.

共鳴

とにかく力任せに解いてみる(brute-force method)の続き

上の結果を使って議論しよう.共鳴とは自然振動数"5ForcedOscillationVer6_43.gif"に強制振動の振動数Ωが近づいたとき振幅が大きくなり、位相が大きく変わる現象を言う.(教科書を参照).

まず、Ωを変えながら位置を時間の関数として3次元的に描いてみよう.

In[18]:=

"5ForcedOscillationVer6_44.gif"

Out[18]=

"5ForcedOscillationVer6_45.gif"

上の図は少しわかりにくのでrotate して真正面から見てみよう.

In[19]:=

"5ForcedOscillationVer6_46.gif"

Out[19]=

"5ForcedOscillationVer6_47.gif"

Ω の値が1に近づくと振幅が大きくなる様子が読みとれる.βの値をもう少し小さくすると,

In[20]:=

"5ForcedOscillationVer6_48.gif"

Out[20]=

"5ForcedOscillationVer6_49.gif"

さて、振幅の大きさを見つけよう.時間がたつと系は外力と同じ周期で変化する.時間が十分たったとしてFindMaximumを使って振幅の最大値を探そう.

In[21]:=

"5ForcedOscillationVer6_50.gif"

Out[21]=

"5ForcedOscillationVer6_51.gif"

この結果はt =100の近くで最大値を探すと0.187112であるとアウトプットは示している.

OMEGA の値を変えつつ最大値の数列を作ってみよう.(この計算は少し時間がかかる.また,計算が収束しない場合もあるが無視することにする.)

In[22]:=

"5ForcedOscillationVer6_52.gif"

In[23]:=

"5ForcedOscillationVer6_53.gif"

Out[23]=

"5ForcedOscillationVer6_54.gif"

In[24]:=

"5ForcedOscillationVer6_55.gif"

Out[24]=

"5ForcedOscillationVer6_56.gif"

Ωが"5ForcedOscillationVer6_57.gif"の値(=1)に近づいたとき振幅が最大値をとると推測できる.

問4 Ωが"5ForcedOscillationVer6_58.gif"の値(=1)に近づいたとき振幅を大きくするためにはどのような減衰パラメターを選べばよいか.

つぎにΩの変化に従いどのように変化するかみよう.

In[25]:=

"5ForcedOscillationVer6_59.gif"

Out[25]=

"5ForcedOscillationVer6_60.gif"

これをプロットすると

In[26]:=

"5ForcedOscillationVer6_61.gif"

Out[26]=

"5ForcedOscillationVer6_62.gif"

上の図は極小値を与える時間t をOMEGAの関数としてプロットしたものである.従って位相はOMEGAの関数として次のように描ける.

In[27]:=

"5ForcedOscillationVer6_63.gif"

Out[27]=

"5ForcedOscillationVer6_64.gif"

この図は共鳴の起こるところで(OMEGA ~1)で位相が大きく変わる様子が読みとれる.

注:ここで位相が2Piでもとに戻るのでMod を用いた.例としては

In[28]:=

"5ForcedOscillationVer6_65.gif"

Out[28]=

"5ForcedOscillationVer6_66.gif"

In[29]:=

"5ForcedOscillationVer6_67.gif"

Out[29]=

"5ForcedOscillationVer6_68.gif"

のようにMod[m,n]はmをnで割った残りを示す.

”複素数を用い特解を求める”の続き

興味のあるのは特解のみであるので

In[30]:=

"5ForcedOscillationVer6_69.gif"

と定義する.

In[31]:=

"5ForcedOscillationVer6_70.gif"

Out[31]=

"5ForcedOscillationVer6_71.gif"

In[32]:=

"5ForcedOscillationVer6_72.gif"

Out[32]=

"5ForcedOscillationVer6_73.gif"

振幅Bのみをプロットすると,

In[33]:=

"5ForcedOscillationVer6_74.gif"

Out[33]=

"5ForcedOscillationVer6_75.gif"

振幅Abs[B]を最大とする振動数 "5ForcedOscillationVer6_76.gif" を振幅共鳴振動数 (amplitude resonancefrequency) という.即ち、

In[34]:=

"5ForcedOscillationVer6_77.gif"

Out[34]=

"5ForcedOscillationVer6_78.gif"

より,正の解のみひろうと

In[35]:=

"5ForcedOscillationVer6_79.gif"

Out[35]=

"5ForcedOscillationVer6_80.gif"

となる..これからわかるように β が大きくなれば共鳴振動数 "5ForcedOscillationVer6_81.gif" は小さくなり,もっと大きくなると"5ForcedOscillationVer6_82.gif" は虚数となり 振幅 は Ω が大きくなるに従い減少する.
β が "5ForcedOscillationVer6_83.gif"に比べて小さいとき、共鳴振動数 "5ForcedOscillationVer6_84.gif" はほとんど減少しないが、Ω ∼"5ForcedOscillationVer6_85.gif"のとき当然振幅 は大きな変化をみせる.

位相のみをプロットすると

In[36]:=

"5ForcedOscillationVer6_86.gif"

Out[36]=

"5ForcedOscillationVer6_87.gif"

β が小さくなるに従って位相αは自然振動数 "5ForcedOscillationVer6_88.gif" の近傍にあるときより急激に変化する.
β = 0 ではその変化が π になることに注意する.

Q値

 強制振動では、よく Q 値というものが引用される.これは共鳴の鋭さをあらわすパラメターで
"5ForcedOscillationVer6_89.gif"
で定義される. Q 値が大きいほど共鳴は鋭い.ここでは、緩やかな減衰振動の場合、すなわち減衰パラメター β が自然振動数 "5ForcedOscillationVer6_90.gif" 比べて小さいとき、
Q≈"5ForcedOscillationVer6_91.gif"
であることを示す.ここでΔω は半値幅 (FWHM: Full Width at Half Maximum) と呼ばれ、振幅がその最大値の丁度"5ForcedOscillationVer6_92.gif"になった2点をむすんだ振動数の幅に対応する.すなわち,

In[37]:=

"5ForcedOscillationVer6_93.gif"

Out[37]=

"5ForcedOscillationVer6_94.gif"

を得る.負の解は物理的に意味をなさないので第2番目と第4番目の解のみひろい、 x1と x2 とする.即ち、

In[38]:=

"5ForcedOscillationVer6_95.gif"

Out[38]=

"5ForcedOscillationVer6_96.gif"

In[39]:=

"5ForcedOscillationVer6_97.gif"

Out[39]=

"5ForcedOscillationVer6_98.gif"

と定義し、半値幅を Δω とよべば、それは、( b について1次のオーダーのみ計算す
る)

In[40]:=

"5ForcedOscillationVer6_99.gif"

Out[40]=

"5ForcedOscillationVer6_100.gif"

In[43]:=

"5ForcedOscillationVer6_101.gif"

Out[43]=

"5ForcedOscillationVer6_102.gif"

となる.また,"5ForcedOscillationVer6_103.gif"

In[42]:=

"5ForcedOscillationVer6_104.gif"

Out[42]=

"5ForcedOscillationVer6_105.gif"

"5ForcedOscillationVer6_106.gif"

問5 以上の結果を踏まえ,強制振動とは何か、分かり易く説明せよ.

問6 共鳴とは何か、分かり易く説明せよ.

問7 共強制振動する振動子の力学的エネルギーはどのような時間変化をするか.計算してプロットしてみよ.

Spikey Created with Wolfram Mathematica 6