11.1.5. cmlPmCfgGetInOutRatio¶
SYNOPSYS¶
VT_I4 cmlPmCfgGetInOutRatio ([in] VT_I4 BoardID, [in] VT_I4 NodeId, [in] VT_I4 Channel, [out] VT_PR8 Ratio )
DESCRIPTION¶
cmlPmCfgGetInOutRatio() 함수는 설정되어있는 Feedback펄스와 Command펄스의 분해능 비율 (Resolution ratio)을 반환합니다.
이 함수의 사용과 호출에 있어, 제공된 ㈜커미조아의 함수 헤더 Visual Basic 에서는 함수의 첨두어 cml 가 붙지 않습니다.
PARAMETER¶
▶ BoardID : 사용자가 설정한 디바이스(보드) ID.
▶ NodeId : 사용자가 제어하고자 하는 노드 번호.
▶ Channel : 축 번호. 통합 축으로 관리되는 축 번호를 의미하며, 상수 값으로 0 (Zero Based) 이상, 최대 통합 축 개수 - 1 이하의 값을 축 번호로 설정할 수 있습니다.
▶ Ratio : Feedback펄스와 Command펄스의 분해능 비를 설정 혹은 반환합니다. 이 값은 아래와 같이 설정합니다. Ratio = (Feedback펄스 분해능)/(Command 펄스의 분해능)
RETURN VALUE¶
Value |
Meaning |
---|---|
음수 |
수행 실패 |
0(ERR_NONE) |
수행 성공 |
REFERENCE¶
In/Out Ratio는 Actual(Feedback) position 또는 Actual speed 를 논리 단위로 읽을 때 적용됩니다. 논리적 단위 거리나 단위 속도는 Command 펄스 기준으로 설정되므로 Command 펄스와 Feedback 펄스의 분해능이 서로 다르다면 Actual position이나 Actual speed의 논리값 계산이 잘못되게 됩니다.
In/Out Ratio 는 cmlPmStGetPosition() 함수와 cmlPmStGetSpeed() 함수에서 카운터를 cmlCNT_FEED 으로 설정한 경우에만 영향을 미칩니다.
EXAMPLE¶
1 2 3 4 5 6 7 8 9 10 11 12 13 | C/C++
#include “ComiMLink2_SDK.h”
#include “ComiMLink2_SDK_Def.h”
long nChannel = 0;
long BoardID = 0;
double fRatio = 2.0f;
//0번 축을 선택합니다.
//분해능 비율을 2로 설정합니다.
/* 0번 축의 분해능 비율을 설정합니다. 분해능 비율은
Ratio = (Feedback 펄스 분해능)/(Command 펄스의 분해능) */
cmlPmCfgSetInOutRatio (BoardID, 0, nChannel, fRatio );
//0번 축의 현재 분해능 비율을 반환합니다.
cmlPmCfgGetInOutRatio (BoardID, 0, nChannel, &fRatio );
|