スプレッドシートのIMLN関数の使い方|複素数の自然対数を一発で計算

スポンサーリンク

「スプレッドシートで複素数の自然対数を出したいけど、振幅と位相に分けて手計算するのが面倒…」

スプレッドシートで複素数を扱っていると、ln(a+bi)の値が必要になる場面がありますよね。IMABSやIMARGUMENTをLNと組み合わせ、最後にCOMPLEXで合体させて…と数式を何段にも重ねるのは結構大変です。

そんなときに頼りになるのがGoogleスプレッドシートのIMLN関数です。複素数を1つ渡すだけで「その複素数の自然対数」を一発で返してくれます。フェーザ分解や周波数応答の数式が一気にすっきりしますよ。

ExcelのIMLN関数と完全互換なので、Excelファイルとやり取りする現場でも安心ですね。COMPLEX関数で作った複素数や、IMEXP関数で計算した指数関数値からも、そのまま自然対数に渡せます。

この記事では、スプレッドシートのIMLN関数の基本構文と実務での活用例を解説します。IMEXPとの逆関数関係や、主値の範囲、よくあるエラーと対処法もしっかり紹介していきますよ。

スプレッドシートのIMLN関数とは?

GoogleスプレッドシートのIMLN関数は、複素数の自然対数(底eの対数 ln(z))を返す関数です。エンジニアリング関数(電気・物理・工学系の計算で使う関数群)のひとつに分類されますよ。

読み方は「イマジナリー・エルエヌ」または「アイエム・エルエヌ」です。英語の「imaginary(虚数の)」と「natural logarithm(自然対数)」を組み合わせた名前ですね。複素数「a+bi」の自然対数を、複素数として返してくれるのが役割です。

そもそも複素数の自然対数は、極形式の考え方から導かれます。複素数 z を |z|×e^(iθ) の形に書き直すと、定義式は次のようになりますよ。

ln(a+bi) = ln(|a+bi|) + i × arg(a+bi)
        = ln(√(a²+b²)) + i × atan2(b, a)

実部は「絶対値の自然対数」、虚部は「偏角(位相角)」となり、結果も複素数で返るのが特徴ですね。虚部の偏角はラジアンで、主値の範囲は -π < θ ≤ π に収まります。

複素数(z)IMLN(z)の結果内部計算
1+0i0ln(1) = 0
e+0i(≈2.71828)1ln(e) = 1
-1+0i0+πiln(1) + i×π(オイラーの等式の逆)
0+1i0+(π/2)iln(1) + i×π/2
0-1i0-(π/2)iln(1) – i×π/2
1+1i0.3466+0.7854iln(√2) + i×π/4

IMLN関数を使えば、この表の右側にある「複素数の自然対数」をサクッと取り出せます。Excelとの互換性も完璧で、Excel 2007以降のすべてのバージョンに対応していますよ。

複素数の自然対数は、フェーザ分解・伝達関数のボード線図・安定性解析・信号処理のキャリア除去などで活躍します。複素数を「対数空間」で扱う場面で欠かせない基礎パーツですね。

IMLN関数の書き方(構文と引数)

基本構文

=IMLN(複素数)

引数は1つで、自然対数を取りたい複素数を渡す形ですよ。

引数の詳細

引数必須/任意説明
複素数(inumber)必須自然対数を計算する複素数。文字列またはセル参照で指定する

引数には「”1+2i”」や「”1+2j”」のような複素数文字列を直接渡せます。COMPLEX関数(実数と虚数から複素数を作成する関数)の結果や、複素数が入ったセルの参照も指定できますよ。

虚数単位は小文字の「i」または「j」のどちらでも受け付けます。数学では「i」、電気工学では「j」が使われる慣習ですね。IMLN関数はどちらでも同じように動作してくれます。

TIP

IMLNが返す虚部(偏角)の範囲は -π < θ ≤ π です。これを「主値」と呼びます。実際の偏角は2πの整数倍だけ無数にありますが、スプレッドシートではこの主値だけが返ってくる点を覚えておきましょう。

引数に正の実数だけを渡せば、通常の自然対数LNと同じ結果になります。「IMLN(“2.71828”)」も「LN(2.71828)」もどちらも約1ですね。違いは戻り値が複素数文字列になるか実数になるかだけですよ。

IMLN関数の基本的な使い方

文字列で複素数を直接指定する

複素数文字列をそのまま引数に渡してみましょう。

=IMLN("1+1i")

結果は「0.346573590279973+0.785398163397448i」になります。実部はln(√2)≈0.3466、虚部はπ/4≈0.7854ですね。

正の実部だけの複素数を渡すと、通常のLN関数と同じ結果になります。

=IMLN("2.71828")
=IMLN("2.71828+0i")

どちらも結果は約「1+0i」、つまり自然対数の底eの対数ですよ。実数の世界の自然対数と一致しますね。

純虚数を渡すと、結果は実部0で虚部が±π/2になります。

=IMLN("0+1i")
=IMLN("0-1i")

前者は「0+1.5708…i」、後者は「0-1.5708…i」になりますよ。複素平面の縦軸に乗っている純虚数の偏角が、±π/2として返ってきますね。

オイラーの等式の逆を確認する

「e^(iπ) = -1」というオイラーの等式は有名ですよね。両辺の自然対数を取ると「ln(-1) = iπ」になります。スプレッドシートで確認してみましょう。

=IMLN("-1")

結果は「0+3.14159…i」になりますよ。実部は0、虚部はπとなり、ln(-1) = iπ が確かに成り立っていますね。実数の世界では「負の数の対数は計算できない」とされますが、複素数まで広げるとちゃんと値が定まる点が面白いところです。

セル参照で複素数を指定する

実務ではセルに入った複素数を扱う場面が多いですよね。A2に「1+1i」が入っている場合は次のように書きます。

=IMLN(A2)

結果は「0.3466…+0.7854…i」になります。セル参照を渡すだけで、入っている複素数の自然対数を取り出せますよ。

COMPLEX関数と組み合わせる

COMPLEX関数で作った複素数を、その場でIMLNに渡すこともできます。

=IMLN(COMPLEX(1, 1))

結果は「0.3466…+0.7854…i」、つまり「IMLN(“1+1i”)」と同じですね。COMPLEX(1, 1)が内部で「1+1i」を作り、IMLN関数がその自然対数を返してくれます。

数値で実部と虚部を渡したいときに便利な書き方ですよ。

ARRAYFORMULAで複数行を一括処理する

複素数のリストに対して一気に自然対数の列を作りたい場面もありますよね。そんなときはARRAYFORMULA関数(数式を範囲全体に展開する関数)と組み合わせます。

=ARRAYFORMULA(IMLN(A2:A10))

A列の複素数を順番に自然対数に変換して、対応する結果をB列に一発で展開できますよ。フェーザ表現の振幅・位相分解を一括計算するときに重宝しますね。

IMLN関数の実務活用例

活用例1: 振幅と位相に分解する

IMLN関数の戻り値は「実部=ln(振幅)、虚部=位相角」という構造になっています。これを使うと、複素数を一発で振幅と位相に分けられますよ。

A列に複素数フェーザが並んでいるとしましょう。

B2: =IMLN(A2)              ← 自然対数
C2: =EXP(IMREAL(B2))       ← 振幅 |z|
D2: =IMAGINARY(B2)         ← 位相(ラジアン)
E2: =DEGREES(D2)           ← 位相(度数)

C列に振幅、D列にラジアン位相、E列に度数位相が並びますね。IMABSとIMARGUMENTを別々に呼ぶよりも、IMLN1本で済むのでシートがすっきりします。

活用例2: 伝達関数のゲイン・位相を求める

制御工学では、伝達関数 H(jω) を複素数として評価し、ゲイン(dB)と位相(度数)を取り出します。IMLNを使うと、片対数のボード線図用データが直接組み立てられますよ。

H(jω)が「2+3i」と評価されたとしましょう。

A2: 2                                ← 実部
B2: 3                                ← 虚部
C2: =COMPLEX(A2, B2)                 ← H(jω)
D2: =IMLN(C2)                        ← 自然対数
E2: =20/LN(10)*IMREAL(D2)            ← ゲイン(dB)
F2: =DEGREES(IMAGINARY(D2))          ← 位相(度数)

E2のゲインは「20×log10(|H|)」を「20/ln(10)×ln(|H|)」に書き換えた形ですね。F2は位相の度数表記です。ボード線図の作成やフィルタ設計のシートで使えるパターンですよ。

TIP

ゲインを dB に換算するには「20/LN(10)」をかけるのが手早い書き方です。LOG10関数を使う場合は =20*LOG10(IMABS(C2)) でも同じ結果になりますよ。

活用例3: IMEXPの逆変換として使う

IMEXP関数とIMLN関数は互いに逆関数の関係です。IMEXPで作った複素数をIMLNに通すと、元の複素数(厳密には主値の範囲)に戻りますよ。

A2: =COMPLEX(1, 1)               ← 元の複素数 1+1i
B2: =IMEXP(A2)                   ← e^(1+1i) = 1.4687+2.2874i
C2: =IMLN(B2)                    ← 元に戻る = 1+1i

C2の結果は「1+1i」と元のA2に一致します。フェーザ計算で「指数表現と対数表現を行き来したい」場面で使える書き方ですね。エネルギー計算や減衰係数の解析で重宝します。

活用例4: 複素数のべき乗を分解する

IMLN関数は、複素数の一般べき乗 z^w を計算する基礎パーツとしても使えます。定義式は z^w = e^(w × ln(z)) なので、IMLNとIMEXPを組み合わせれば実装できますよ。

たとえば「(1+i)^(2+i)」を計算してみましょう。

A2: =COMPLEX(1, 1)                              ← z = 1+i
B2: =COMPLEX(2, 1)                              ← w = 2+i
C2: =IMEXP(IMPRODUCT(B2, IMLN(A2)))             ← z^w

C2の結果は「-0.3097+0.8576i」のような値になります。IMPOWER関数(複素数のべき乗)の指数部に複素数を渡したいときの代替実装ですね。整数や実数のべき乗ならIMPOWERで足りますが、複素べき乗にはIMLN+IMEXPの組み合わせが必要です。

活用例5: 信号の包絡線抽出(ヒルベルト変換の後処理)

信号処理では、解析信号 z(t) = x(t) + i×ĥ(t) から瞬時振幅と瞬時位相を取り出す場面があります。IMLNを使うと、両方を一発で取り出せますよ。

A列にサンプル時刻、B列に解析信号(複素数)が並んでいるとしましょう。

C2: =IMLN(B2)              ← 自然対数
D2: =EXP(IMREAL(C2))       ← 包絡線(瞬時振幅)
E2: =IMAGINARY(C2)         ← 瞬時位相(ラジアン)

D列が包絡線、E列が瞬時位相ですね。位相の不連続を避けたい場合は、後段でアンラップ処理(連続化)を入れておくと安心です。AM/FM信号の解析やバイブレーション診断のシートでそのまま使える書き方ですよ。

IMLN関数とCOMPLEX関数群の関係

複素数を扱う関数群の中で、IMLN関数の位置づけを整理しておきましょう。

関数入力出力役割
COMPLEX実数 a, b複素数 a+bi複素数を作る
IMREAL複素数 a+bi実数 a実部を取り出す
IMAGINARY複素数 a+bi実数 b虚部を取り出す
IMABS複素数 a+bi実数 √(a²+b²)大きさを取り出す
IMARGUMENT複素数 a+bi実数(ラジアン)偏角を取り出す
IMEXP複素数 z複素数 e^z指数関数
IMLN複素数 z複素数 ln(z)自然対数(IMEXPの逆関数)
IMLOG2複素数 z複素数 log₂(z)2を底とする対数
IMLOG10複素数 z複素数 log₁₀(z)10を底とする対数
IMPOWER複素数 z, 実数 n複素数 z^nべき乗

IMLN関数とIMEXP関数は互いに逆関数の関係です。「IMLN(IMEXP(z)) = z」が成り立ちますよ(厳密には主値の範囲で)。逆に「IMEXP(IMLN(z)) = z」も常に成り立ちます。

たとえば定義式どおりにln(a+bi)を手動で組み立てると次のようになります。

=COMPLEX(LN(SQRT(IMREAL(A2)^2+IMAGINARY(A2)^2)), ATAN2(IMREAL(A2), IMAGINARY(A2)))

これはIMLNと同じ結果になりますが、絶対値と偏角を毎回手書きする必要がありますよね。IMLNを使えば1関数で済むので、数式が読みやすくなります。

IMLN関数のよくあるエラーと対処法

#NUM! エラー(複素数の形式エラー、または z=0)

複素数として認識できない文字列を渡したときや、ゼロを渡したときに発生します。

=IMLN("1+1I")     → #NUM!(大文字のIは不可)
=IMLN("1+1k")     → #NUM!(i・j以外は不可)
=IMLN("1 + 1i")   → #NUM!(途中の空白は不可)
=IMLN("0")        → #NUM!(ln(0)は定義されない)
=IMLN("0+0i")     → #NUM!(同上)

対処法は2つあります。1つ目は、複素数文字列を必ず半角の「a+bi」または「a+bj」の形式にすることです。虚数単位は小文字限定なので、CapsLockがオンになっていないか確認してくださいね。

2つ目は、ゼロを渡さないことです。実数の世界でln(0)が定義されないのと同じく、複素数の世界でも0の対数は計算できません。入力データに0が混じる可能性がある場合は、後述のIFERROR対策を入れておきましょう。

#VALUE! エラー(引数の型エラー)

引数に論理値やエラー値を渡したときに発生します。

=IMLN(TRUE)       → #VALUE!(論理値は不可)
=IMLN(#N/A)       → #VALUE!(エラー値は不可)

対処法は、正しい複素数文字列または数値・セル参照を渡すことです。入力元のセルがエラーになっている場合は、そのエラーを先に解消する必要がありますよ。

主値の範囲を超えた角度を期待してしまう問題

IMLNが返す虚部(偏角)は -π < θ ≤ π の主値だけです。たとえば「3π/2 ラジアン回転した複素数」を期待しても、実際には「-π/2」が返ってきますね。

=IMLN("0-1i")     → 0-1.5708i(-π/2)

この複素数 -i は「3π/2 回転した点」とも「-π/2 回転した点」とも見なせますね。IMLNはそのうち主値(後者)を返します。連続的に偏角を追跡したい信号処理などでは、後段で「アンラップ処理」を実装する必要がある点に注意してくださいね。

IFERRORでまとめてエラーを吸収する

入力データの信頼性が低い場合や、ゼロが混じる可能性がある場合に備えておきたいですよね。そんなときはIFERROR関数(エラー時に代替値を返す関数)で包んでおきましょう。シート全体の集計が止まらず安心です。

=IFERROR(IMLN(A2), "計算不可")

エラー時にメッセージを返すようにしておけば、安心して大量データに適用できますよ。

IMLN関数とExcelの互換性

GoogleスプレッドシートのIMLN関数は、ExcelのIMLN関数と仕様が完全に一致しています。構文・引数・戻り値の形式・主値の範囲・エラー条件まで同じですよ。

ExcelファイルをGoogleスプレッドシートで開いてもIMLN関数はそのまま動作します。逆にスプレッドシートで作った数式をExcelで開いても問題ありませんね。

ExcelのIMLN関数は、Excel 2007以降のすべてのバージョンで利用できます。Microsoft 365、Excel for Mac、Excel Online でも同じように使えますよ。古いExcelファイルとの互換性も心配いりません。

複素数関連の関数一覧

IMLN関数と一緒に使うことが多い、複素数関連の関数をまとめました。

関数名機能
COMPLEX実数と虚数から複素数を作成する
IMREAL複素数の実数係数を返す
IMAGINARY複素数の虚数係数を返す
IMABS複素数の絶対値(大きさ)を返す
IMARGUMENT複素数の偏角(角度)をラジアンで返す
IMCONJUGATE共役複素数を返す
IMSUM複素数の合計(足し算)を返す
IMSUB複素数の差(引き算)を返す
IMPRODUCT複素数の積(掛け算)を返す
IMDIV複素数の商(割り算)を返す
IMEXP複素数の指数関数(eべき乗)を返す
IMLN複素数の自然対数を返す(IMEXPの逆関数)
IMLOG2複素数の2を底とする対数を返す
IMLOG10複素数の10を底とする対数を返す
IMPOWER複素数のべき乗を返す
IMSQRT複素数の平方根を返す

IMLN関数は、これら複素数関数群の中で「自然対数」を担う基本関数ですね。COMPLEXで複素数を作り、IMLNで自然対数値を求めるのが基本の流れです。最後はIMREAL・IMAGINARYで振幅と位相に分けて可視化しましょう。フェーザ分解やボード線図の解析シートを軽快に組み立てられますよ。

まとめ

GoogleスプレッドシートのIMLN関数は、複素数の自然対数(ln(z))を返す関数です。フェーザ分解・ボード線図・伝達関数解析・信号処理など、複素数を「振幅と位相」に分けて扱う場面で欠かせない関数ですよ。

  • 構文は =IMLN(複素数) で複素数を1つ渡すだけ
  • 「ln(a+bi) = ln(√(a²+b²)) + i × atan2(b, a)」が内部計算式
  • 実部は絶対値の自然対数、虚部は偏角(位相角)になる
  • 「a+bi」と「a+bj」のどちらの表記もそのまま受け付ける
  • 虚部(偏角)の範囲は -π < θ ≤ π の主値
  • 正の実部だけの複素数を渡すと通常のLN関数と同じ結果になる
  • 「ln(-1) = iπ」のオイラーの等式の逆も計算できる
  • COMPLEX関数の結果やセル参照、複素数演算の結果も渡せる
  • ARRAYFORMULAで複数の複素数を一括処理できる
  • IMEXP関数とは互いに逆関数の関係
  • z=0 を渡すと #NUM! エラー(ln(0)は定義されない)
  • 大文字の「I」「J」やi・j以外の単位は #NUM! エラー
  • 論理値やエラー値を渡すと #VALUE! エラー
  • ExcelのIMLN関数と完全互換(Excel 2007以降)

複素数の自然対数が必要になったら、IMLN関数の出番ですよ。COMPLEX関数で複素数を作り、IMLNで対数を取りましょう。最後にIMREAL・IMAGINARYで振幅と位相に分解すれば、エンジニアリング系のシートを軽快に組み立てられますね。

タイトルとURLをコピーしました