<Каталог>
<nanoCAD. Программирование и автоматизация>
(Перевод стаей о типах LISP из Справки к AutoCAD 2015 и дополнительная информация специфичная для nanoCAD)
Integer
AutoCAD 2015. LISP. About Integers
Integer - это целые числа, которые не содержат десятичной точки. Для хранения целых чисел используется 32 бита. 31 бит используется для хранения числа а один бит для хранения знака числа. Диапазон целых чисел в целом находится в пределах +/- 2^31 или (от - 2 147 483 648 до 2 147 483 647). Как утверждается в Справке к AutoLISP AutoCAD 2015, в некоторых функциях значения Integer интерпретируются как 16-битные чиста в пределах от - 32 678 до 32 677.
Однако, практика показывает, что на данный момент не всё так однозначно.
Например, если в nanoCAD выполнить присвоение переменной числа 2 147 483 647, то вместо ожидаемого максимально возможного целого числа, получим действительное число (REAL). А, при последующем добавлении к нему единицы значение данного действительного числа будет увеличиваться в положительную сторону. При этом, если мы инициируем переменную значением 2 147 483 646, то получим правильную верхнюю границу INT в 2 147 483 647 и переход к отрицательным значениям при последующем прибавлении 1 (единицы).
Но, если мы инициируем переменную не числом 2 147 483 647, а выражением (setq xInt (- (expt 2 31) 1)), что, казалось бы, должно привести к аналогичному результату, результат получим совершенно другой.
Более того, оказывается, что в AutoCAD 2015 и в nanoCAD 20.1 "граница" между INT и REAL в случае выполнения вышеупомянутых арифметических операций и оценке типа переменной при помощи функции type выглядит несколько по разному.
AutoCAD:
nanoCAD:
Предполагается, что, в случае превышения результата арифметических операций над INT, результат автоматически приводится к REAL. Однако, практика показывает, что это не всегда верно. Рассмотрим две операции сложения и умножения вида:
1) 384 758 647 * 12 = 4 617 103 764
2) 384 758 647 + 4 232 345 117 = 4 617 103 764
Предполагается, что операции будут эквивалентными, но в действительности получаем:
Резюме. Для корректной работы с целыми числами необходимо быть полностью уверенным, что их значения не выйдут за границы целочисленных значений LISP. Если есть сомнения, то лучше использовать действительные (REAL) числа, осознано преобразовывая их обратно к целочисленным значениям, в случае использования функций, работающих только с INT. Да, это трудоёмко и не всегда удобно, однако, позволит избежать непредсказуемых ошибок преобразования типов, как описанных выше, так и не описанных.
Real
AutoCAD 2015. LISP. About Reals
REAL - это действительные числа с десятичной точкой. Числа в диапазоне от -1 до 1 могут содержать 0 (ноль) слева от десятичной точки.
Значения REAL занимают 64 бита и соответствуют типу double в Си.
Границы допустимых значений типа REAL примерно от 4.94 x 10-324 до 1.79 x 10308.
При выходе за эти границы, будет получено значение "Infinity" (бесконечность) или 0.0 (ноль).
Поскольку представленные десятичные числа имеют одинарную точность, то Машинный эпсилон (наименьшее положительное число) ε, при котором не распознаются два числа a и b:
1 < a/b < 1+ε,
ε ≈ 5,96 x 10-8.
Похоже, что Мантисса действительного числа состоит из 7 знаков, включая десятичную точку. И не просто состоит, но записывается в память именно с такой точностью.
Поскольку в AutoLISP как AutoCAD, так и nanoCAD отсутствуют функции округления из Common LISP, типа round или trancate, прикладываю файл с функциями от Lee Mac.
http://www.lee-mac.com/round.html
LM_round.lsp
Что нужно знать про арифметику с плавающей запятой
List
AutoCAD 2015. LISP. About Lists
AutoCAD 2015. LISP. About Point Lists
AutoCAD 2015. LISP. About Dotted Pairs
List - это базовый тип LISP, представляющий собой Списки атомарных элементов и других списков.
Функции, используемые для получения доступа к элементам списков:
Для получения доступа к координатам 2D и 3D точек в точечных списках рекомендуется обращаться не через функцию nth, а через функции: car - для доступа к первой координате, cadr - для доступа ко второй координате и caddr - для доступа к третьей координате.
Функции car и cdr могут последовательно комбинироваться и обеспечивать доступ к атомарным элементам и вложенным спискам иерархического списочного дерева до 4-го уровня вложенности.
car, cdr .... cddddr
About Entity Context and Coordinate Transform Data
Обсуждение на форуме.
2020-10-14 LISP в nanoCAD 20.1
https://forum.nanocad.ru/index.php?/topic/11617-lisp-v-nanocad-201/&tab=comments#comment-74317