11.1.18. cmcPmCfgSetFilter¶
SYNOPSYS¶
VT_I4 cmcPmCfgSetFilter ([in] VT_I4 BoardID, [in] VT_I4 NodeId, [in] VT_I4 Channel, [in] VT_I4 IsEnable )
DESCRIPTION¶
cmcPmCfgSetFilter()/cmcPmCfgGetFilter() 함수는 각종 I/O 신호에 필터 로직을 적용할지를 설정 혹은 설정 상태를 반환하는 함수입니다. 필터 로직이 적용되면 펄스 폭이 너무 짧은 입력 신호는 무시되게 됩니다. 필터 로직이 적용되는 I/O 신호 및 펄스 폭은 REFERENCE 를 참조하십시오.
이 함수의 사용과 호출에 있어, 제공된 ㈜커미조아의 함수 헤더 Visual Basic 에서는 함수의 첨두어 cmc 가 붙지 않습니다.
PARAMETER¶
▶ BoardID : 사용자가 설정한 디바이스(보드) ID.
▶ NodeId : 노드 번호. 노드 번호는 3부터 시작합니다.
▶ Channel : 축 번호. 통합 축으로 관리되는 축 번호를 의미하며, 상수 값으로 0 (Zero Based) 이상, 최대 통합 축 개수 - 1 이하의 값을 축 번호로 설정할 수 있습니다.
▶ IsEnable : 필터 로직의 적용 여부를 설정 혹은 반환합니다.
Value |
Meaning |
---|---|
0 (cmcFALSE) |
Filter Disable (필터 로직 비활성화). |
1 (cmcTRUE) |
Filter Enable (필터 로직 활성화). |
REFERENCE¶
필터 로직 적용이 Enable 됐을 때 필터 로직이 적용되는 신호 및 기준 펄스 폭은 다음과 같습니다.
필터 적용 I/O |
필터 기준 |
---|---|
+EL / -EL / SD / ORG / ALM / INP |
펄스 폭이 4μs 미만은 무시 |
+DR / -DR |
펄스 폭이 3.2ms 미만은 무시 |
RETURN VALUE¶
Value |
Meaning |
---|---|
음수 |
수행 실패 |
0(ERR_NONE) |
수행 성공 |
EXAMPLE¶
1 2 3 4 5 6 7 8 9 10 11 12 13 | C/C++
#include “ComiMLink3_SDK.h”
#include “ComiMLink3_SDK_Def.h”
long nChannel = 0;//0번 축을 선택합니다.
Long BoardID = 0;
long nFilterEnable = 0;
/* 노이즈 필터 로직 활성 여부를 확인하여 비활성 상태이면 활성 상태로 설정합니다. */
cmcPmCfgSetFilter(BoardID, 3, nChannel, &nFilterEnable );
if( nFilterEnable != cmcFALSE )
{
//Filter 를 사용하도록 설정합니다.
cmcPmCfgSetFilter(BoardID, 3, nChannel, cmcTRUE );
}
|
SEE ALSO¶
See also