ワイヤレスI/Oデバイスで複数チャネルを1回AD変換し、変換データをバイナリ値で返します。マルチプロセス対応関数です。
Ret = AioMultiAiSR ( Id , AiChannels , AiData , Timestamp , Mode )
Id [
VB.NET: Short ] [ C, C++: short ] [ C#: short ] [
Python: ctypes.c_short ]
AioInit 関数で取得したデバイスIDを指定します。
AiChannels
[ VB.NET: Short ] [ C, C++: short ] [ C#: short ]
[ Python: ctypes.c_short ]
変換チャネル数を指定します。
AiData
[ VB.NET: Integer() ] [ C, C++: long * ] [ C#: int[] ] [ Python: ctypes.POINTER(ctypes.c_long)
]
変換データを格納する配列のアドレスを指定します。変換データはバイナリ値で格納されます。
利用しているデバイスの分解能によって、変換データの範囲が異なります。
利用デバイスの分解能 |
変換データの範囲 |
10ビット |
0~1023 |
12ビット |
0~4095 |
16ビット |
0~65535 |
Timestamp
[ VB.NET: UShort] [ C, C++: unsigned short * ]
[ C#: out ushort ] [ Python: ctypes.POINTER(ctypes.c_ushort) ]
タイムスタンプを格納するアドレスを指定します。
Modeで参照先を親機に指定した場合、前回の更新からの時間が格納されます。
Mode
[ VB.NET: Byte ] [ C, C++: BYTE ] [ C#: out byte ] [ Python:
ctypes.c_ubyte ]
入力データを参照する先を指定します。
定義 |
値 |
意味 |
AIONET_MODE_DIRECT |
0 |
子機の入力データを参照します。 |
AIONET_MODE_AP |
1 |
親機の入力データを参照します。 |
Ret [ VB.NET: Integer ] [ C, C++: long ] [ C#: int ] [ Python: ctypes.c_long ]
戻り値 |
内容 |
0 |
正常終了 |
7 |
スタンバイモードから復帰したため、AioResetDevice関数を実行してください |
10001 |
無効なIDが指定されました |
10002 |
ドライバを呼び出せません |
11440 |
AiChannelsの値が関数の指定範囲外です |
11441 |
AiDataのポインタがNULLです |
20001 |
使用しているデバイスではこの関数を使用することができません |
20002 |
デバイスが動作中のため実行できません |
21441 |
変換チャネル数をオーバーしました.最大チャネルで変換します |
アナログ入力機能を持たないデバイスでは使用できません。
デバイスが動作中の場合、この関数は実行できません。
データ取得の方法として、親機に保存されているデータ取得と子機のデータを直接取得する2種類を選択できます。
それぞれの取得方法の特徴についてはワイヤレスI/Oの仕様をご参照ください。
データ取得方法で、親機に保存されているデータ取得を行う場合、親機に保存されているデータのタイムスタンプが取得できます。
タイムスタンプは前回の更新からの時間を秒単位で返します。
子機の更新間隔よりもタイムスタンプが長い場合、子機からのデータが何かしらの理由により親機に到達していないことになります。
親機に保存されているデータの有効性確認にご使用ください。
0~3チャネルを1回変換します。
VB.NET |
Dim
Ret As Integer |
C, C++ |
long
Ret; |
C# |
int
Ret; |
Python |
Ret
= ctypes.c_long() |