フーリエ級数展開の計算例

フーリエ解析 3/N

公開日: 2022-08-14
更新日: 2024-01-19

  Table of Contents

フーリエ級数展開

Def: フーリエ級数展開

関数$f(x)$を周期$2\pi$の周期関数とする. このとき, 関数$f(x)$が区分的になめらかな連続関数であるとき, $f(x)$はフーリエ級数展開で以下のように表すことができる:

\[f(x)\sim \frac{a_0}{2} + \sum_{n=1}^\infty(a_n \cos nx + b_n \sin nx)\]

このときのフーリエ係数は

\[\begin{align*} a_n &= \frac{1}{\pi}\int^{2\pi}_0 f(x) \cos nx dx\\ b_n &= \frac{1}{\pi}\int^{2\pi}_0 f(x) \sin nx dx \end{align*}\]

$\cos nx, \sin nx$の基本周期は$2\pi/n$であるが, 共通に$2\pi$周期をもつのでRHSが収束するならば LHSも$2\pi$周期をもつことがわかります.

有限項で表せるフーリエ級数展開の例として,

\[\begin{align*} \sin^2 x &= \frac{1 - \cos 2x}{2}\\[3pt] \cos^2 x &= \frac{1 + \cos 2x}{2}\\[3pt] \cos^3 x &= \frac{3\cos x + \cos 3x}{4} \end{align*}\]

これらはそれぞれフーリエ級数との比較で表すと

\[\begin{align*} \sin^2 x &= \frac{1}{2} - \frac{1}{2}\cos 2x\\[3pt] \cos^2 x &= \frac{1}{2} + \frac{1}{2}\cos 2x\\[3pt] \cos^3 x &= \frac{3}{4}\cos x + \frac{1}{4}\cos 3x \end{align*}\]

フーリエ係数の公式導出

基本周期$2\pi$の関数$f(x)$が

\[f(x)\sim \frac{a_0}{2} + \sum_{n=1}^\infty(a_n \cos nx + b_n \sin nx)\]

と展開できるとします. この式の両辺に関数$\cos mx (m=0,1,2,\cdots)$をかけ, $[0, 2\pi]$区間で積分をする. 積分と和の順序を交換できるとすると, 三角関数の直交性より

\[\begin{align*} \int^{2\pi}_0 f(x) \cos mx dx =& \int^{2\pi}_0\frac{a_0}{2}\cos mx\ dx\\[3pt] &+ \sum_{n=1}^\infty\int^{2\pi}_0(a_n \cos nx \cos mx + b_n \sin nx \cos mx)\ dx\\ &= a_m\pi \end{align*}\]

同様に

\[\begin{align*} \int^{2\pi}_0 f(x) \sin mx dx =& \int^{2\pi}_0\frac{a_0}{2}\sin mx\ dx\\[3pt] &+ \sum_{n=1}^\infty\int^{2\pi}_0(a_n \cos nx \sin mx + b_n \sin nx \sin mx)\ dx\\ &= b_m\pi \end{align*}\]

従って,

\[\begin{align*} a_n &= \frac{1}{\pi}\int^{2\pi}_0 f(x) \cos nx dx\\ b_n &= \frac{1}{\pi}\int^{2\pi}_0 f(x) \sin nx dx \end{align*}\]

を得る.

周期関数の特性

関数$f(x)$を基本周期$2\pi$の周期関数とすると, $f(x)$と$\cos nxm \sin nx$はともに周期$2\pi$の周期関数であるので, その積も周期$2\pi$の関数となります. 従って, 周期関数の特性より

\[\begin{align*} a_n &= \frac{1}{\pi}\int^{2\pi}_0 f(x) \cos nx dx\\ &= \frac{1}{\pi}\int^{2\pi+c}_c f(x) \cos nx dx \end{align*}\]

従って, $c=\pi$として以下のようにフーリエ係数を表記したりする

\[\begin{align*} a_n &= \frac{1}{\pi}\int^{\pi}_{-\pi} f(x) \cos nx dx\\ b_n &= \frac{1}{\pi}\int^{\pi}_{-\pi} f(x) \sin nx dx \end{align*}\]

フーリエ級数展開計算例

ここではフーリエ級数展開で表現可能な周期関数の例を紹介します. 有名なところだとノコギリ波や方形波 があります.

  • ノコギリ波: テレビのブラウン管に流す電流の波形
  • 方形波: コンピューターなどで用いるデジタル信号の基本波形

といわれています.

方形波

例題: 方形波

関数

\[f(x) = \begin{cases} \displaystyle 1 & (0\leq x < \pi)\\ \displaystyle 0 & (-\pi\leq x < 0) \end{cases}\]

を$f(x+2\pi)=f(x)$によって拡張した関数$\tilde f(x)$のフーリエ係数を求めよ


解答1

$\tilde f(x)$は周期$2\pi$をもつので

\[\begin{align*} a_n &= \frac{1}{\pi}\int^{\pi}_{-\pi} \tilde f(x) \cos nx dx\\[3pt] b_n &= \frac{1}{\pi}\int^{\pi}_{-\pi} \tilde f(x) \sin nx dx \end{align*}\]

と計算できる

\[\begin{align*} a_n &=\frac{1}{\pi}\int^{\pi}_{-\pi} \tilde f(x) \cos nx dx\\[3pt] &= \frac{1}{\pi}\left(\int^{\pi}_{0} \cos nx dx\\\right)\\[3pt] &= \begin{cases} \displaystyle 1&n=0\\[5pt] \displaystyle 0& n>1\\ \end{cases} \end{align*}\] \[\begin{align*} b_n &=\frac{1}{\pi}\int^{\pi}_{-\pi} \tilde f(x) \sin nx dx\\[3pt] &= \frac{1}{n\pi}\left[-\cos nx\right]^{\pi}_{0}\\[3pt] &= \begin{cases} \displaystyle \frac{2}{n\pi}&\text{nが奇数}\\[5pt] \displaystyle 0& \text{nが偶数}\\ \end{cases} \end{align*}\]

従って,

\[\begin{align*} \tilde f(x) \sim \frac{1}{2} + \sum_{n=1}^\infty \frac{2}{\pi(2n-1)}\sin (2n-1)x \end{align*}\]


解答2

$\tilde f(x)$を$\tilde f(x) = h(x) + g(x)$として

\[\begin{align*} h(x)& = \frac{1}{2}\\[3pt] g(x) &=\begin{cases} \displaystyle \frac{1}{2} & (0\leq x < \pi)\\[3pt] \displaystyle -\frac{1}{2} & (-\pi\leq x < 0) \end{cases} \end{align*}\]

と定数関数と奇関数を用いて表現し直します.

定数関数ののフーリエ係数は$a_0(h) = 1/2$と自明. $g(x)$は奇関数であるので$a_n(g) = 0$であるのは自明. また, 奇関数と奇関数の積は偶関数であるので

\[\begin{align*} b_n(g) &= \frac{1}{\pi}\int^{\pi}_{-\pi}g(x)\sin nx\ dx\\[3pt] &= \frac{2}{\pi}\int^{\pi}_{0}g(x)\sin nx\ dx\\[3pt] &= -\frac{1}{n\pi}[\cos nx]^\pi_0\\[3pt] &= \begin{cases} \displaystyle \frac{2}{n\pi}&\text{nが奇数}\\[5pt] \displaystyle 0& \text{nが偶数}\\ \end{cases} \end{align*}\] \[\begin{align*} a_n(\tilde f) &= a_n(h) + a_n(g)\\ b_n(\tilde f) &= b_n(h) + b_n(g) \end{align*}\]

より

\[\begin{align*} \tilde f(x) \sim \frac{1}{2} + \sum_{n=1}^\infty \frac{2}{\pi(2n-1)}\sin (2n-1)x \end{align*}\]

導き出した方形波をPythonでplotしてみる

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
import plotly.express as px
import numpy as np
from IPython.display import display, HTML
import plotly

plotly.offline.init_notebook_mode()
display(HTML(
    '<script type="text/javascript" async src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.1/MathJax.js?config=TeX-MML-AM_SVG"></script>'
))

# 定数

def constant_fourier(x, max_n):
    y = 1/2
    term = 1
    while max_n + 1 > term:
        y += 2/(term * np.pi) * np.sin(x*term)
        term += 2

    return y

x = np.linspace(-2*np.pi*1.1, 2*np.pi*1.1, 500)
y, y2, y3 = constant_fourier(x, max_n=10), constant_fourier(x, max_n=40), constant_fourier(x, max_n=1000)


fig = px.line(x=x, y=[y, y2, y3], 
              render_mode='SVG', 
              title='周期関数に対するフーリエ級数展開例<br><sup>opacity=.6 , n = 10, 40, 1000</sup>',
              )
newnames = {'wide_variable_0':'n=10', 
            'wide_variable_1':'n=40',
            'wide_variable_2':'n=1000'}
fig.update_traces(opacity=.8)
fig.for_each_trace(lambda t: t.update(name = newnames[t.name],
                                      legendgroup = newnames[t.name],
                                      hovertemplate = t.hovertemplate.replace(t.name, newnames[t.name])
                                     )
                  )
fig.update_xaxes(tickangle=0,
                 tickmode = 'array',
                 tickvals = [-2*np.pi, -3/2*np.pi, -np.pi, -1/2*np.pi, 
                             0, 1/2*np.pi, np.pi, 3/2*np.pi, 2*np.pi],
                 ticktext=['$-2\pi$', '', '$-\pi$', '', '0', '', '$\pi$', '', '$2\pi$'])
fig.show()

方形波の振幅とロケールを変換してみる

\[\begin{align*} \tilde f(x) \sim \frac{1}{2} + \sum_{n=1}^\infty \frac{2}{\pi(2n-1)}\sin (2n-1)x \end{align*}\]

に対して, 係数を2倍にすれば

\[g_1(x) = \begin{cases} \displaystyle 2 & (0\leq x < \pi)\\ \displaystyle 0 & (-\pi\leq x < 0) \end{cases}\]

が表現できることは直感的にわかります. さらに$-1$を加えることによって

\[g_2(x) = \begin{cases} \displaystyle 1 & (0\leq x < \pi)\\ \displaystyle -1 & (-\pi\leq x < 0) \end{cases}\]

が表現できるはずです. このときのフーリエ級数展開を

\[\begin{align*} \tilde g_2(x) \sim \sum_{n=1}^\infty \frac{4}{\pi(2n-1)}\sin (2n-1)x \end{align*}\]

して, Pythonで可視化してみると

上手くいっていることが確認できます. $g_2(x)$は奇関数ですが, フーリエ級数展開後も正弦関数のみで表現されていることから確からしさがわかります.

絶対値関数を用いたジグザグ波

例題: ジグザグ波

関数

\[f(x) = \vert x\vert \qquad (-\pi\leq x < \pi)\]

を$f(x+2\pi)=f(x)$によって拡張した関数$\tilde f(x)$のフーリエ係数を求めよ


解答

$f(x)$は偶関数なので, 余弦展開のみで十分であることがわかる. 従って,

\[\begin{align*} a_n &= \frac{1}{\pi}\int^\pi_{-\pi}\vert x\vert \cos nx\ dx\\[3pt] &= \frac{2}{\pi}\int^\pi_{0}x \cos nx\ dx \end{align*}\]

$n=0$のとき

\[a_0 = \frac{2}{\pi}\int^\pi_{0}x \ dx = \pi\]

また, $n > 0$のときは

\[\begin{align*} a_n &= \frac{2}{\pi}\int^\pi_{0}x \cos nx\ dx\\[3pt] &= \frac{2}{\pi}\left\{\frac{1}{n}[x\sin nx]^\pi_0 - \int^\pi_0 \frac{1}{n}\sin nx\ dx\right\}\\[3pt] &= \frac{2}{\pi}\left\{\frac{1}{n}[x\sin nx]^\pi_0 + \frac{1}{n^2}[\cos nx]^\pi_0\right\}\\[3pt] &= \begin{cases} \displaystyle 0 & n: \text{even} \\[3pt] \displaystyle -\frac{4}{n^2\pi}& n: \text{odd} \end{cases} \end{align*}\]

従って,

\[\tilde f(x)\sim \frac{\pi}{2} - \sum_{n=1}^\infty \frac{4}{(2n-1)^2\pi}\cos(2n-1)x\]

ノコギリ波

例題: ノコギリ波

関数

\[f(x) = x \qquad (-\pi\leq x < \pi)\]

を$f(x+2\pi)=f(x)$によって拡張した関数$\tilde f(x)$のフーリエ係数を求めよ


解答

$\tilde f(x)$は奇関数であるので正弦展開だけで十分であることがわかる.

\[\begin{align*} b_n &= \frac{1}{\pi}\int^\pi_{-\pi}x\sin nx \ dx\\[3pt] &= \frac{2}{\pi}\int^\pi_{0}x\sin nx \ dx\\[3pt] &= \frac{2}{\pi n}\left([x\cos nx]^\pi_0 + \int^\pi_{0}\cos nx \ dx\right)\\[3pt] &= \frac{2(-1)^{n+1}}{n} \end{align*}\]

従って,

\[\tilde f(x)\sim 2\sum^\infty_{n=1}\frac{(-1)^{n+1}}{n}\sin nx\]

正弦関数の絶対値変換

例題: ノコギリ波

関数

\(f(x) = \vert\sin x\vert\) のフーリエ係数を求めよ


解答

$f(x)$は偶関数なので余弦展開のみで十分である.

従って,

\[\begin{align*} a_0 &= \frac{1}{\pi}\int^\pi_{-\pi} \vert\sin x\vert dx \\[3pt] &= \frac{2}{\pi}\int^\pi_{0} \sin x dx \\[3pt] &= \frac{2}{\pi} [-\cos x]^\pi_{0}\\[3pt] &= \frac{4}{\pi} \end{align*}\]

また, $n > 0$に対して

\[\begin{align*} a_n &= \frac{2}{\pi}\int^\pi_{0} \sin x \cos nx dx \\[3pt] &= \frac{2}{2\pi}\int^\pi_{0} (\sin(n+1)x + \sin(1-n)x)\ dx\\[3pt] &= \frac{1}{\pi}\left\{\left[\frac{-1}{n+1}\cos(n+1)x\right]^\pi_0 - \left[\frac{1}{1-n}\cos(1-n)x\right]^\pi_0\right\}\\[3pt] &= \begin{cases} \displaystyle 0 & n:\text{odd}\\[3pt] \displaystyle \frac{-4}{\pi(n^2-1)} & n:\text{even} \end{cases} \end{align*}\]

従って,

\[f(x)\sim \frac{2}{\pi} - \sum_{n=1}^\infty \frac{4}{\pi(4n^2 - 1)}\cos 2n x\]

奇関数$x^3$のフーリエ級数展開

例題

関数

\[f(x) = x^3 \qquad (-\pi \leq x < x)\]

を$f(x+2\pi)=\tilde f(x)$によって周期的に拡張した関数のフーリエ係数を求めよ


解答

$\tilde f(x)$は奇関数なので正弦展開のみで十分である. 従って

\[\begin{align*} b_n &= \frac{1}{\pi}\int^\pi_{-\pi} x^3 \sin nx\ dx\\[3pt] &= \frac{2}{\pi}\int^\pi_{0} x^3 \sin nx\ dx \qquad \because\text{奇関数同士の積は偶関数なので} \end{align*}\]

$\int^\pi_{0} x^3 \sin nx\ dx$は$x^3$が4回微分すると0になるので

符号 $f(x)$ $g(x)$
$+$ $x^3$ $-\frac{1}{n}\cos nx$
$-$ $3x^2$ $-\frac{1}{n^2}\sin nx$
$+$ $6x$ $\frac{1}{n^3}\cos nx$
$-$ $6$ $-\frac{1}{n^4}\sin nx$

このとき, $[0, \pi]$区間で積分するので2行目と4行目は0とわかる. 従って,

\[b_n = (-1)^{n+1}\left(\frac{2\pi^2}{n}-\frac{12}{n^3}\right)\]

よって,

\[\tilde f(x) \sim \sum_{n=1}^\infty (-1)^{n+1}\left(\frac{2\pi^2}{n}-\frac{12}{n^3}\right) \sin nx\]

フーリエ係数の線型性

Property: フーリエ係数の線型性

周期$2\pi$の周期関数$f(x), g(x)$のフーリエ係数をそれぞれ$a_n(f), b_n(f), a_n(g), b_n(g)$とする. このとき, $c, d$を定数とするとき

\[h(x) = cf(x) + dg(x)\]

のフーリエ係数について

\[\begin{align*} a_n(h) &= ca_n(f) + da_n(g)\\ b_n(h) &= cb_n(f) + db_n(g) \end{align*}\]

が成立する.


Example

\[f(x) = \begin{cases} \displaystyle x & (0 \leq x < \pi)\\[3pt] \displaystyle 0 & (-\pi \leq x < 0) \end{cases}\]

という関数を$f(x + 2\pi)=f(x)$と周期的に拡張した関数$\tilde f(x)$を考えます. フーリエ係数$a_n, b_n$をもとめるとき, 普通に解くと

\[\begin{align*} a_0 &= \frac{1}{\pi}\int^{\pi}_{-\pi} f(x)\ dx\\[3pt] &= \frac{1}{\pi}\int^{\pi}_{0} x\ dx\\[3pt] &= \frac{\pi}{2}\\ \\ a_n &= \frac{1}{\pi}\int^{\pi}_{-\pi} f(x)\cos nx\ dx\\[3pt] &= \frac{1}{\pi}\int^{\pi}_{0} x\cos nx\ dx\\[3pt] &= \frac{1}{\pi}\left[\frac{1}{n}x \sin nx + \frac{1}{n^2}\cos nx\right]^\pi_0\\ &= \begin{cases} \displaystyle 0 & n:\text{even}\\[3pt] \displaystyle \frac{-2}{n^2\pi} & n:\text{odd} \end{cases}\\ \\ b_n &= \frac{1}{\pi}\int^{\pi}_{-\pi} f(x)\sin nx\ dx\\[3pt] &= \frac{1}{\pi}\int^{\pi}_{0} x\sin nx\ dx\\[3pt] &= \frac{1}{\pi}\left[-\frac{1}{n}x \cos nx + \frac{1}{n^2}\sin nx\right]^\pi_0\\ &= \frac{(-1)^{n+1}}{n} \\[3pt] \end{align*}\]

従って,

\[\tilde f(x)\sim \frac{\pi}{4} - \sum_{n=1}^\infty \frac{2}{(2n-1)^2\pi}\cos (2n-1)x + \sum^\infty_{n=1}\frac{(-1)^{n+1}}{n} \sin nx\]

ここで, $f(x)$がノコギリ波とジグザグ波を足し合わせたものを2で割ったことに注目します. すなわち

\[\begin{align*} g(x) &= \vert x\vert \qquad (-\pi\leq x < \pi)\\[3pt] h(x) &= x \qquad (-\pi\leq x < \pi)\\[3pt] f(x) &= \frac{g(x) + h(x)}{2} \end{align*}\]

$\tilde g(x), \tilde h(x)$をそれぞれ$2\pi$周期的に拡張した関数とすると

\[\begin{align*} \tilde g(x)&\sim \frac{\pi}{2} - \sum_{n=1}^\infty \frac{4}{(2n-1)^2\pi}\cos(2n-1)x \\[3pt] \tilde h(x)&\sim 2\sum^\infty_{n=1}\frac{(-1)^{n+1}}{n}\sin nx \end{align*}\]

すると

\[\begin{align*} &\frac{\tilde g(x) + \tilde h(x)}{2} \\[3pt] &= \frac{\pi}{4} - \sum_{n=1}^\infty \frac{2}{(2n-1)^2\pi}\cos(2n-1)x + \sum^\infty_{n=1}\frac{(-1)^{n+1}}{n}\sin nx \end{align*}\]

これは上で求めた$\tilde f(x)$のフーリエ係数と一致することがわかる.

Appendix: 瞬間部分積分

Theorem: 瞬間部分積分

複数回微分可能な関数$f(x), g(x)$が与えられ, $f(x)$は何回か微分すると0になるとします. このとき2つの関数の積の積分

\[\int f(x)g(x)\ dx\]

は次の手順で計算することができる.

  1. 3列の表をつくる
  2. 2列目に上から $f(x), f^\prime(x), f^{\prime\prime}(x), \cdots$と0になる手前まで格納する
  3. 3列目に上から$g$の積分, $g$の二回積分, $\cdots$, と手順2と同じ回数まで格納する
  4. 1列目に上から$+, -, +, \cdots$と交互に格納する
  5. 2列目と3列目の項を掛けて, 縦に1列目の符号を維持しながら足す


example

\[\int(x^3+x)\cos x\ dx\]

を瞬間部分積分で計算すると, $x^3+x$は4回微分すると0になるので

符号 $f(x)$ $g(x)$
$+$ $(x^3+x)$ $\sin x$
$-$ $(3x^2+1)$ $-\cos x$
$+$ $6x$ $-\sin x$
$-$ $6$ $\cos x$

従って,

\[\begin{align*} &\int(x^3+x)\cos x\ dx\\ &= (x^3+x)\sin x + (3x^2+1)\cos x - 6x \sin x - 6\cos x + C\\ &= (x^3-5x)\sin x + (3x^2-5)\cos x + C \end{align*}\]

References



Share Buttons
Share on:

Feature Tags
Leave a Comment
(注意:GitHub Accountが必要となります)