コンテンツにスキップ

Line Overload Status#

Line Overload Statusカメラ機能を使用すると、GPIOラインが過負荷(つまり、電力供給が不適切)になっているかどうかを判断できます。

機能を使用する#

Line Overloadの原因#

GPIOラインが出力ラインとして設定されている場合は、カメラのトピックで指定されている適切な出力信号電圧を適用する必要があります。カメラのトピックは、「モデル」セクションにあります。

適切な電圧を適用しないと、ラインの過負荷が発生する可能性があります。カメラの絶対最大電圧を超えない限り、カメラは過負荷を検出し、BslLineOverloadStatusパラメーターを使用して報告します。

I/Oラインの過負荷ステータスの判別#

GPIOラインが過負荷になっているかどうかを確認するには、次の手順に従います。

  1. LineSelectorパラメーターを必要なI/Oライン(Line1など)に設定します。
  2. BslLineOverloadStatusパラメーターの値を取得します。パラメーターは読み取り専用です。

値がfalse(0)の場合は、GPIOラインが過負荷になっていないことを意味します。

値がtrue(1)の場合は、GPIOラインが過負荷になっています。I/Oラインの設定を確認します。

全I/Oラインの過負荷ステータスの判別#

1回の操作で全I/Oラインの過負荷ステータスを確認するには、BslLineOverloadStatusAllパラメーターを読み取ります。このパラメーターは64ビット値として報告されます。

情報

BslLineOverloadStatusAllパラメーターは、pylon API経由でのみ使用できます。pylon Viewer機能ツリー経由では使用できません。

値内の特定のビットは、I/Oラインに関連付けられています。各ビットは、関連するラインのステータスを示します。

  • ビットが0の場合、関連付けられたラインは過負荷になりません。
  • ビットが1の場合、関連付けられたラインは過負荷になります。I/Oラインの設定を確認してください。

ビットとラインの関連付けは次のとおりです。

  • ビット0はLine1のステータスを示します。
  • ビット1はLine2のステータスを示します。
  • ビット2はLine3のステータスを示します。

:すべてのラインが高 = 0b111

情報

Line Inverter機能が有効になっている場合、カメラはBslLineOverloadStatusAllパラメーター値を反転します。すべての0ビットが1に変更され、その逆も同様です。

サンプルコード#

ace 2およびboostカメラ#

// Select a line
camera.LineSelector.SetValue(LineSelector_Line1);
// Determine the status of the selected line
bool status = camera.BslLineOverloadStatus.GetValue();
// Get the line overload status of all I/O lines
// Because the GenICam interface does not support
// 32-bit words, the line status is reported as a 64-bit value
int64_t lineOverloadStatusAll = camera.BslLineOverloadStatusAll.GetValue();
INodeMap& nodemap = camera.GetNodeMap();
// Select a line
CEnumParameter(nodemap, "LineSelector").SetValue("Line1");
// Determine the status of the selected line
bool status = CBooleanParameter(nodemap, "BslLineOverloadStatus").GetValue();
// Get the line overload status of all I/O lines
// Because the GenICam interface does not support
// 32-bit words, the line status is reported as a 64-bit value
int64_t lineOverloadStatusAll = CIntegerParameter(nodemap, "BslLineOverloadStatusAll").GetValue();
// Select a line
camera.Parameters[PLCamera.LineSelector].SetValue(PLCamera.LineSelector.Line1);
// Determine the status of the selected line
bool status = camera.Parameters[PLCamera.BslLineOverloadStatus].GetValue();
// Get the line overload status of all I/O lines
// Because the GenICam interface does not support
// 32-bit words, the line status is reported as a 64-bit value
Int64 lineOverloadStatusAll = camera.Parameters[PLCamera.BslLineOverloadStatusAll].GetValue();
/* Macro to check for errors */
#define CHECK(errc) if (GENAPI_E_OK != errc) printErrorAndExit(errc)
GENAPIC_RESULT errRes = GENAPI_E_OK;  /* Return value of pylon methods */
_Bool status = false;
int64_t lineOverloadStatusAll = 0;
/* Select a line */
errRes = PylonDeviceFeatureFromString(hdev, "LineSelector", "Line1");
CHECK(errRes);
/* Determine the status of the selected line */
errRes = PylonDeviceGetBooleanFeature(hdev, "BslLineOverloadStatus", &status);
CHECK(errRes);
/* Get the line overload status of all I/O lines */
/* Because the GenICam interface does not support */
/* 32-bit words, the line status is reported as a 64-bit value */
errRes = PylonDeviceGetIntegerFeature(hdev, "BslLineOverloadStatusAll", &lineOverloadStatusAll);
CHECK(errRes);

その他のカメラ#

// Select a line
camera.LineSelector.SetValue(LineSelector_Line1);
// Determine the status of the selected line
bool status = camera.LineOverloadStatus.GetValue();
// Get the line overload status of all I/O lines
// Because the GenICam interface does not support
// 32-bit words, the line status is reported as a 64-bit value
int64_t lineOverloadStatusAll = camera.LineOverloadStatusAll.GetValue();
INodeMap& nodemap = camera.GetNodeMap();
// Select a line
CEnumParameter(nodemap, "LineSelector").SetValue("Line1");
// Determine the status of the selected line
bool status = CBooleanParameter(nodemap, "LineOverloadStatus").GetValue();
// Get the line overload status of all I/O lines
// Because the GenICam interface does not support
// 32-bit words, the line status is reported as a 64-bit value
int64_t lineOverloadStatusAll = CIntegerParameter(nodemap, "LineOverloadStatusAll").GetValue();
// Select a line
camera.Parameters[PLCamera.LineSelector].SetValue(PLCamera.LineSelector.Line1);
// Determine the status of the selected line
bool status = camera.Parameters[PLCamera.LineOverloadStatus].GetValue();
// Get the line overload status of all I/O lines
// Because the GenICam interface does not support
// 32-bit words, the line status is reported as a 64-bit value
Int64 lineOverloadStatusAll = camera.Parameters[PLCamera.LineOverloadStatusAll].GetValue();
/* Macro to check for errors */
#define CHECK(errc) if (GENAPI_E_OK != errc) printErrorAndExit(errc)
GENAPIC_RESULT errRes = GENAPI_E_OK;  /* Return value of pylon methods */
_Bool status = false;
int64_t lineOverloadStatusAll = 0;
/* Select a line */
errRes = PylonDeviceFeatureFromString(hdev, "LineSelector", "Line1");
CHECK(errRes);
/* Determine the status of the selected line */
errRes = PylonDeviceGetBooleanFeature(hdev, "LineOverloadStatus", &status);
CHECK(errRes);
/* Get the line overload status of all I/O lines */
/* Because the GenICam interface does not support */
/* 32-bit words, the line status is reported as a 64-bit value */
errRes = PylonDeviceGetIntegerFeature(hdev, "LineOverloadStatusAll", &lineOverloadStatusAll);
CHECK(errRes);

pylon Viewerを使用して、パラメーターを簡単に設定することもできます。