疑似逆行列(一般逆行列)

シェアする

  • このエントリーをはてなブックマークに追加
最近の記事
  • 7/6 【参考書籍】画像処理・機械学習プログラミング OpenCV 3対応
  • 6/20 【Python,matplotlib】動くグラフをAnimationGifに保存する方法
  • 6/17 シグモイド関数の微分
  • 6/15 シグモイド関数
  • 6/13 合成関数の微分
  • 6/12 WordPressで数式エディタ風に数式を入力したい
  • 6/11 PythonをVisual Studioでインストールする方法
  • 6/9 【Python】OpenCVをAnacondaでインストール(Windows編)
  • 6/6 【Python】Anacondaで複数バージョンの環境切り替え
  • 6/6 画像センシング展2017に出展します。
  • 6/1 【Office365】Web版Outlookのフォントサイズ変更
  • 6/1 【Anaconda】モジュールのアップデートでエラー発生
  • 6/1 【Anaconda】コマンドリストの表示
  • 5/29 Windows10パソコン購入
  • 5/24 Anacondaのアンインストール
  • 5/24 【Jupyter Notebook】新規プログラムの作成
  • 5/23 【Python】開発環境の構築
  • 5/23 Pythonはじめました
  • 4/6 【Office365】Web版Outlookのスレッド表示を解除する方法
  • 4/5 【Excel】フーリエ解析(FFT)
  • 3/20 Canny edge detection
  • 3/20 【Excel2016】分析ツールの表示
  • 3/5 【Visual Studio】黒い背景色を白に変更する方法
  • 2/8 【Windows10】拡張モニタに表示されたウィンドウを元に戻す
  • 2/7 複素数の計算
  • 1/18 【Excel】棒グラフの横軸の目盛を0始まりにする
  • 1/16 【Excel】フーリエ変換
  • 1/6 【OpenCV】疑似カラー(カラーマップ)
  • 11/8 【Visual Studio】検索結果のウィンドウ表示
  • 11/3 ニコン 一眼レフカメラ D5500レビュー
  • 10/26 カラーカメラはモノクロカメラを兼ねない
  • 9/6 (Free Soft)Animation GIF Builder
  • 8/30 【C#】タブの無いTabControlっぽいものを作る
  • 8/29 【OpenCvSharp】サンプルプログラムの公開
  • 8/28 【PowerPoint】部分的にカラーにする(セレクトカラー処理)
  • 8/27 【C#】引数の値渡し、参照渡し(ref, out)
  • 8/26 【Word/Excel】図形内に文字を挿入する
  • 8/25 【C#】NumericUpDownコントロール
  • 8/24 ニコン D3400 VS D5500 仕様比較
  • 8/22 【C#】MDIフォームにリサイズ可能なPanelを設置する
  • 8/20 【Visual Studio 2015】文字の色が変、かすむ
  • 8/20 【Visual Studio】行のコピー、切り取り、貼り付け
  • 8/20
  • 8/16
  • 7/7 標準偏差のよくある誤解
  • 6/17 ホーム
  • 6/15
  • 6/15
  • 6/15
  • 6/15

  • 逆行列の計算では行数と列数が等しい正方行列のみ計算が可能でした。
    しかし、下記のようにn個の未知数(a1~an)に対して、式がm本 (m>n)ある場合、
    逆行列を使って解くことができません。

    疑似逆行列(一般逆行列)

    上記式を行列であらわすと

    疑似逆行列(一般逆行列)

    となり、行列部分を記号で書くと

    疑似逆行列(一般逆行列)・・・式①

    のようになり行列Xに関して逆行列が求まれば、未知数の行列Aについて解く事が可能となります。

    行列Xの行数が列数よりも多い時(未知数よりもデータ数が多い時)、疑似逆行列(一般逆行列ともいう)という物を使って、行列Aに関して近似的に解く事が可能となります。

    疑似逆行列は、通常の逆行列転置行列を使って、下記のように現されます。

    疑似逆行列(一般逆行列)・・・式②

    この疑似逆行列を使って式①は

    疑似逆行列(一般逆行列)

    のように未知数を解く事が可能となります。

    ちなみに、この計算は最小二乗法と同じ結果になるそうです。

    という事で、この疑似逆行列を使って、Excelで近似式を求めてみたいと思います。

    ExcelではXとYのデータのグラフを書くと、近似曲線の追加という機能を使えば簡単に求まります。

    でも、この近似式をエクセルの計算を使って求めたいな~という事もあるかと思います。

    疑似逆行列(一般逆行列)

    そこで、疑似逆行列を使って、データを二次関数で近似する時の例で説明したいと思います。

    まず、二次関数の一般式

    疑似逆行列(一般逆行列)

    を少し変形して

    疑似逆行列(一般逆行列)

    のようにします。このXとYに近似するm個のデータ(X, Y)を代入し、行列で表すと

    疑似逆行列(一般逆行列)

    のようになり、行列の各要素をエクセルで計算します。

    疑似逆行列(一般逆行列)

    次が少々難しいのですが、エクセルのワークシート関数の

    • 行列の積:mmult
    • 逆行列 :minverse
    • 転置行列:transpose

    を使って、疑似逆行列を求めます。

    今回は未知数が3つなので、縦に3つのセルを選択し、

    =MMULT(MMULT(MINVERSE(MMULT(TRANSPOSE(行列Xの範囲),行列Xの範囲)),TRANSPOSE(行列Xの範囲)),行列Yの範囲)

    のように入力します。

    (入力例)

    =MMULT(MMULT(MINVERSE(MMULT(TRANSPOSE(B45:D54),B45:D54)),TRANSPOSE(B45:D54)),G45:G54)

    のように入力し、Ctrl+Shift+Enterキーを同時に押すと、a1~a3が求まり、二次の近似式が求まります。

    疑似逆行列(一般逆行列)

    このエクセルのファイルはエクセルにより疑似逆行列の計算よりダウンロードできます。

    エクセルで行列の計算は少し分かりづらいので、【Excel】行列の積、逆行列、転置行列の計算のページも参考にして下さい。

    今回は二次関数の近似を行いましたが、これさえ知っていれば、未知数が定数で行列で式を表せればいいだけなので、かなり応用が効くと思います。

    使える数学へ戻る