ILogic 기능 확장 및 사용자화

외부 파일에 규칙 저장

iLogic 규칙을 Inventor 모형에 저장하는 대신 외부 파일에 배치할 수 있습니다. 이 저장 방법을 사용하면 여러 위치에서 같은 규칙을 사용할 수 있습니다.

규칙을 외부 파일에 저장하려면 먼저 새 파일의 기본 파일 확장자를 설정합니다. 파일을 편집할 방법에 따라 기본 확장자를 선택합니다. 예를 들어 Visual Studio에서 파일을 편집하려는 경우 .vb를 기본 확장자로 설정할 수 있습니다. .txt 확장자를 사용하면 Microsoft 메모장과 같은 텍스트 편집기를 사용하여 규칙을 편집할 수 있습니다. 또는 iLogic에서 미리 처리되는 표준 iLogic 규칙 코드가 파일에 포함된 경우 기본 확장자를 .iLogicVB로 설정할 수 있습니다.

iLogic 규칙은 다른 .NET 조립품에 있는 코드를 사용할 수 있습니다. 이러한 .NET 조립품이 있는 디렉토리를 지정할 수 있습니다. Visual Studio 2008과 같은 프로그래밍 도구를 사용하여 .NET 조립품을 개발합니다. 규칙에서 .NET 조립품을 사용하는 방법에 대한 자세한 내용은 고급 규칙 프로그래밍을 참고하십시오.

매개변수와 규칙에 액세스하기 위한 자동화 인터페이스

iLogic에서는 자동화 인터페이스를 제공합니다. Inventor VBA, VB6 또는 .NET 코드에서 이 인터페이스를 사용하여 매개변수와 규칙에 액세스할 수 있습니다.

iLogicAutomation 클래스를 통해 이 기능을 사용할 수 있습니다.

VBA 또는 VB 프로젝트에서는 참조를 추가하지 않고 런타임에 바인딩된 유형(객체로 선언됨)으로 사용합니다. 이 유형은 완전한 .COM 객체가 아니므로 해당 메서드를 찾을 수 없습니다.

DoubleForEquals 데이터 유형

iLogic에서는 DoubleForEquals라는 사용자 데이터 유형을 사용하여 매개변수 값을 저장합니다. DoubleForEquals는 쉬운 숫자 비교를 지원합니다. 이 매개변수는 표준 VB.NET 유형인 Double과 같습니다. 단, DoubleForEquals 값이 마치 Single 값인 것처럼 비교된다는 점이 다릅니다(소수 자릿수 15 대신에 7 사용). 기본적으로 규칙의 매개변수는 DoubleForEquals로 선언됩니다.

DoubleForEquals를 사용하면 비교에서 반올림 오류를 더 쉽게 무시할 수 있습니다. 예를 들어 부품에서 문서 단위로 인치를 사용하며 값이 13/16인치인 매개변수가 있다고 가정해 봅니다. 매개변수 값이 모형에 센티미터로 저장되었기 때문에 규칙에서 부품은 13/16과 정확히 일치하지 않습니다. 그러면 규칙에서 사용할 수 있도록 값이 인치로 변환됩니다. 다음 비교를 고려해 보십시오.

if d0 = 13/16 then ... 

이 예제에서는 d0이 Double 유형일 경우 비교가 실패합니다. 그러나 d0이 DoubleForEquals 유형일 경우에는 비교가 성공합니다.

DoubleForEquals는 값을 Double 유형으로 저장하며 모든 계산을 Double 값으로 수행합니다. 비교만이 Single로 수행됩니다.

필요하면 CDbl 함수를 사용하여 매개변수 값을 Double로 변환할 수 있습니다.

DoubleForEquals는 VB.NET에서 Structure(값 유형)입니다.

0에 DoubleForEquals 값 비교

DoubleForEquals는 0과의 비교를 특수한 경우로 처리합니다. 균일성을 테스트 중인 숫자 중 하나가 정확히 0일 경우 다른 숫자가 0.0000001(절대 값) 미만이면 테스트가 성공합니다.

이 비교를 사용하면 값에서 0에 가까운 반올림 오류를 더 쉽게 무시할 수 있습니다. 예를 들어 다음 비교는 x = 0을 결정합니다.

angle = PI/2
x = cos(angle)
If (x = 0) Then
...
End If

DoubleForEquals를 비활성화해야 할 경우

DoubleForEquals는 규칙에 사용되는 모든 Inventor 매개변수의 기본 유형입니다. 다음과 같은 이유로 이 설정을 비활성화할 수 있습니다.