ハンドルの書き込み (Scilab ゲートウェイ)
ハンドルの行列を書き込む方法.
呼び出し手順
入力引数プロファイル:
SciErr createMatrixOfHandle(void* _pvCtx, int _iVar, int _iRows, int _iCols, const long long* _pllHandle)
引数
- _pvCtx
Scilab環境ポインタ, api_scilab.h により定義された "pvApiCtx"で指定.
- _iVar
変数を保存するScilabメモリの位置.
- _piRows
返される変数の行数.
- _piCols
返される変数の列数.
- _pllHandle
返されるデータ配列のアドレス (大きさ: _iRows * _iCols).
- SciErr
エラー構造体で,エラーメッセージ履歴と最初のエラー番号を格納します.
Scilabメモリに直接書き込み.
呼び出し手順
入力引数プロファイル:
SciErr allocMatrixOfHandle(void* _pvCtx, int _iVar, int _iRows, int _iCols, long long** _pllHandle)
引数
- _pvCtx
Scilab環境ポインタ, api_scilab.h により定義された "pvApiCtx"で指定.
- _iVar
変数を保存するScilabメモリの位置.
- _iRows
新規変数の行数.
- _iCols
新規変数の列数.
- _pllHandle
実数データ配列のアドレスを返す (大きさ: _iCols * _iRows).
- SciErr
エラー構造体で,エラーメッセージ履歴と最初のエラー番号を格納します.
説明
このヘルプはハンドルの行列を書き込む方法を示します.
ゲートウェイのソース
#include "api_scilab.h" int read_write_handle(char *fname,void* pvApiCtx) { SciErr sciErr; int i; //最初の変数の情報 : double実数行列 int iRows = 0; int iCols = 0; int *piAddr = NULL; long long* pllHandle = NULL; //入力/出力引数を確認 CheckInputArgument(pvApiCtx, 1,1); CheckOutputArgument(pvApiCtx, 0,1); //最初の入力引数の変数アドレスを取得 sciErr = getVarAddressFromPosition(pvApiCtx, 1, &piAddr); if(sciErr.iErr) { printError(&sciErr, 0); return 0; } // Scilabメモリから大きさとデータを取得 sciErr = getMatrixOfHandle(pvApiCtx, piAddr, &iRows, &iCols, &pllHandle); if(sciErr.iErr) { printError(&sciErr, 0); return 0; } sciErr = createMatrixOfHandle(pvApiCtx, nbInputArgument(pvApiCtx) + 1, iRows, iCols, pllHandle); if(sciErr.iErr) { printError(&sciErr, 0); return 0; } AssignOutputVariable(pvApiCtx, 1) = nbInputArgument(pvApiCtx) + 1; return 0; }
Scilab テストスクリプト
履歴
バージョン | 記述 |
5.5.0 | この関数は Scilab 5.5.0で追加されました |
Report an issue | ||
<< ハンドルの読み込み (Scilab ゲートウェイ) | Low level functions | 整数の精度 (Scilabゲートウェイ) >> |