逆行列の生成
Namespace: FVIL.DataAssembly: FVILbasic (in FVILbasic.dll) Version: 3.1.0.0 (3.1.0.17)
Syntax
C# |
---|
public virtual CFviMatrix Inverse( int option ) |
Visual Basic |
---|
Public Overridable Function Inverse ( option As Integer ) As CFviMatrix |
Parameters
- option
- Type: System..::..Int32
オプション ( 0:Gauss-Jordan法, 1:LU分解法 )
Return Value
Type: CFviMatrix現在の行列の逆行列を生成して返します。
Remarks
許容値:
値 | 意味 |
---|---|
0 | Gauss-Jordan法 |
1 | LU分解法 |
生成に失敗した場合は例外を発行します。 例外の原因と発生位置を特定するには、発行された例外クラスの ErrorCode メンバと Function メンバを参照してください。
エラーコード:
値 | ErrorCode メンバ | 内容 |
---|---|---|
51 | FVIL.ErrorCode.LICENSE_ERROR | ライセンスがありません。 |
1 | FVIL.ErrorCode.FAILED_TO_ALLOCATE | メモリの確保に失敗しました。 |
11 | FVIL.ErrorCode.INVALID_PARAMETER | パラメータが不正です。 |
12 | FVIL.ErrorCode.INVALID_OBJECT | メモリが確保されていません。 |
29 | FVIL.ErrorCode.NOT_CALCULABLE | 計算できません。 |
関連する FIE 関数:
fnFIE_mat_inverse
fnFIE_mat_inverse2
Examples
ソースコード:
【関数の出力】(引き数0の場合)
C# | Copy |
---|---|
// $Revision: 1.2 $ using System; using System.Collections.Generic; using System.Text; using fvalgcli; // FvPluginXXXX attribute requires fvalgcli namespace User.SampleCode { public partial class Matrix { /// <summary> /// 逆行列の生成. /// </summary> [FvPluginExecute] public void Inverse0() { Inverse(0); } /// <summary> /// 逆行列の生成. /// </summary> [FvPluginExecute] public void Inverse1() { Inverse(1); } /// <summary> /// 逆行列の生成. /// </summary> public void Inverse(int option) { int rows = 3; int columns = 3; // 1) インスタンスの準備. FVIL.Data.CFviMatrix mat = new FVIL.Data.CFviMatrix(rows, columns); // 2) 行列の要素の設定. mat[0, 0] = 1.0; mat[0, 1] = 3.0; mat[0, 2] = 3.0; mat[1, 0] = 4.0; mat[1, 1] = -2.0; mat[1, 2] = 1.0; mat[2, 0] = 2.0; mat[2, 1] = 5.0; mat[2, 2] = -1.0; // 3) 計算実行. FVIL.Data.CFviMatrix result = mat.Inverse(option); // 確認) 処理結果の出力. Console.Write("CFviMatrix.Inverse(option={0})\n", option); for (int row = 0; row < result.Rows; row++) { for (int column = 0; column < result.Columns; column++) { Console.Write("[{0}][{1}]={2} ", row, column, result[row, column]); } Console.Write("\n"); } } } } |
Visual Basic | Copy |
---|---|
' $Revision: 1.1 $ Imports System.Collections.Generic Imports System.Text Imports fvalgcli ' FvPluginXXXX attribute requires fvalgcli Namespace SampleCode Public Partial Class Matrix ''' <summary> ''' 逆行列の生成. ''' </summary> <FvPluginExecute> _ Public Sub Inverse0() Inverse(0) End Sub ''' <summary> ''' 逆行列の生成. ''' </summary> <FvPluginExecute> _ Public Sub Inverse1() Inverse(1) End Sub ''' <summary> ''' 逆行列の生成. ''' </summary> Public Sub Inverse([option] As Integer) Dim rows As Integer = 3 Dim columns As Integer = 3 ' 1) インスタンスの準備. Dim mat As New FVIL.Data.CFviMatrix(rows, columns) ' 2) 行列の要素の設定. mat(0, 0) = 1.0 mat(0, 1) = 3.0 mat(0, 2) = 3.0 mat(1, 0) = 4.0 mat(1, 1) = -2.0 mat(1, 2) = 1.0 mat(2, 0) = 2.0 mat(2, 1) = 5.0 mat(2, 2) = -1.0 ' 3) 計算実行. Dim result As FVIL.Data.CFviMatrix = mat.Inverse([option]) ' 確認) 処理結果の出力. Console.Write("CFviMatrix.Inverse(option={0})" & vbLf, [option]) For row As Integer = 0 To result.Rows - 1 For column As Integer = 0 To result.Columns - 1 Console.Write("[{0}][{1}]={2} ", row, column, result(row, column)) Next Console.Write(vbLf) Next End Sub End Class End Namespace |
CFviMatrix.Inverse(option=0) [0][0]=-0.034483 [0][1]=0.206897 [0][2]=0.103448 [1][0]=0.068966 [1][1]=-0.080460 [1][2]=0.126437 [2][0]=0.275862 [2][1]=0.011494 [2][2]=-0.160920【関数の出力】(引き数1の場合)
CFviMatrix.Inverse(option=1) [0][0]=-0.034483 [0][1]=0.206897 [0][2]=0.103448 [1][0]=0.068966 [1][1]=-0.080460 [1][2]=0.126437 [2][0]=0.275862 [2][1]=0.011494 [2][2]=-0.160920
Exceptions
Exception | Condition |
---|---|
FVIL..::..CFviException | この例外の原因については、上記のエラーコード表をご参照ください。 |