ベクトルと行列のかけ算

Namespace: fvalgcli
Assembly: fvalgcli (in fvalgcli.dll) Version: 3.1.0.0 (3.1.0.11)

Syntax

C#
public static int fnFIE_mat_mul_va(
	FVECTOR_PTR vs,
	FMATRIX_PTR a,
	FVECTOR_PTR vd
)
Visual Basic
Public Shared Function fnFIE_mat_mul_va ( 
	vs As FVECTOR_PTR,
	a As FMATRIX_PTR,
	vd As FVECTOR_PTR
) As Integer

Parameters

vs
Type: fvalgcli..::..FVECTOR_PTR
掛け合わせる行ベクトル(左)
a
Type: fvalgcli..::..FMATRIX_PTR
掛け合わせる行列(右)
vd
Type: fvalgcli..::..FVECTOR_PTR
計算結果(行ベクトル)

Return Value

Type: Int32
以下のエラーコードを返します。

エラーコード:
f_err内容
F_ERR_NONE正常終了
F_ERR_INVALID_PARAMパラメータ異常
F_ERR_NO_LICENCEライセンスエラー、または未初期化エラー

Remarks

Examples

C# Copy imageCopy
//    $Revision: 1.1 $

using System;
using System.Collections.Generic;
using System.Text;
using fvalgcli;

namespace TC
{
    public partial class FIE
    {
        [FvPluginExecute]
        public void fnFIE_mat_mul_va()
        {

            fvalgcli.FVECTOR_PTR vs = fvalgcli.FVECTOR_PTR.Zero;
            fvalgcli.FMATRIX_PTR a = fvalgcli.FMATRIX_PTR.Zero;
            fvalgcli.FVECTOR_PTR vd = fvalgcli.FVECTOR_PTR.Zero;

            try
            {
                int status = (int)fvalgcli.f_err.F_ERR_NONE;
                vs = fvalgcli.api.fnFIE_mat_valloc(3);
                a = fvalgcli.api.fnFIE_mat_aalloc(3, 4);
                vd = fvalgcli.api.fnFIE_mat_valloc(4);
                Assert.IsTrue(a != fvalgcli.FMATRIX_PTR.Zero, "エラーが発生しました。");
                Assert.IsTrue(vs != fvalgcli.FVECTOR_PTR.Zero, "エラーが発生しました。");
                Assert.IsTrue(vd != fvalgcli.FVECTOR_PTR.Zero, "エラーが発生しました。");

                status = fvalgcli.api.fnFIE_mat_mul_va(vs, a, vd);
                Assert.IsTrue(status == (int)fvalgcli.f_err.F_ERR_NONE, "エラーが発生しました。({0})", (fvalgcli.f_err)status);
            }
            finally
            {
                // 解放.
                fvalgcli.api.fnFIE_mat_vfree(vs);
                fvalgcli.api.fnFIE_mat_afree(a);
                fvalgcli.api.fnFIE_mat_vfree(vd);
            }
        }
    }
}


Visual Basic Copy imageCopy
'    $Revision: 1.1 $

Imports System.Collections.Generic
Imports System.Text
Imports fvalgcli

Public Partial Class FIE
    <FvPluginExecute> _
    Public Sub fnFIE_mat_mul_va()

        Dim vs As fvalgcli.FVECTOR_PTR = fvalgcli.FVECTOR_PTR.Zero
        Dim a As fvalgcli.FMATRIX_PTR = fvalgcli.FMATRIX_PTR.Zero
        Dim vd As fvalgcli.FVECTOR_PTR = fvalgcli.FVECTOR_PTR.Zero

        Try
            Dim status As Integer = CInt(fvalgcli.f_err.F_ERR_NONE)
            vs = fvalgcli.api.fnFIE_mat_valloc(3)
            a = fvalgcli.api.fnFIE_mat_aalloc(3, 4)
            vd = fvalgcli.api.fnFIE_mat_valloc(4)
            Assert.IsTrue(a <> fvalgcli.FMATRIX_PTR.Zero, "エラーが発生しました。")
            Assert.IsTrue(vs <> fvalgcli.FVECTOR_PTR.Zero, "エラーが発生しました。")
            Assert.IsTrue(vd <> fvalgcli.FVECTOR_PTR.Zero, "エラーが発生しました。")

            status = fvalgcli.api.fnFIE_mat_mul_va(vs, a, vd)
            Assert.IsTrue(status = CInt(fvalgcli.f_err.F_ERR_NONE), "エラーが発生しました。({0})", CType(status, fvalgcli.f_err))
        Finally
            ' 解放.
            fvalgcli.api.fnFIE_mat_vfree(vs)
            fvalgcli.api.fnFIE_mat_afree(a)
            fvalgcli.api.fnFIE_mat_vfree(vd)
        End Try
    End Sub
End Class

See Also