|
НАЗВАНИЕ
dc - настольный калькулятор
СИНТАКСИС
dc [файл]
ОПИСАНИЕ
Dc - пакет для арифметических вычислений с произвольной
точностью. Обычно он оперирует в десятичной системе
счисления с целыми числами, однако можно задать системы
счисления для ввода и вывода, а также точность вычислений. Общая структура dc - стековый калькулятор, использующий обратную польскую запись. [См. также bc(1)
- препроцессор для dc, поддерживающий инфиксную нотацию
и C-подобный синтаксис.] Если аргумент указан, то сначала ввод производится из файла, а потом со стандартного ввода.
Dc распознает следующие конструкции:
| число | Значение числа помещается в стек. Число - непрерывная цепочка цифр 0-9. В начале ее может стоять знак подчеркивания _ для ввода отрицательного числа. Число может содержать десятичную точку. | ||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| + - / * % ^ | Верхние два числа стека складываются (+), вычитаются (-), умножаются (*), делятся (/), берется остаток (%) или выполняется возведение в степень. Оба операнда извлекаются из стека и результат помещается обратно в стек. Дробная часть показателя степени игнорируется. | ||||||||||||||||||||
| sx | Извлекается вершина стека и помещается в регистр с именем x, где x - любой символ. Если конструкция имеет вид Sx, то x рассматривается как стек, в который и помещается извлеченное значение. | ||||||||||||||||||||
| lx | Значение, хранящееся в регистре x, помещается в стек. Регистр x не изменяется. Изначально все регистры инициализируются нулем. Если конструкция имеет вид Lx, то x рассматривается как стек, его вершина извлекается и помещается в главный стек. | ||||||||||||||||||||
| d | Вершина стека удваивается. | ||||||||||||||||||||
| p | Выводится вершина стека (без удаления из стека). | ||||||||||||||||||||
| P | Вершина стека трактуется как цепочка символов, печатается и удаляется из стека. | ||||||||||||||||||||
| f | Выводятся все элементы стека (без удаления). | ||||||||||||||||||||
| q | Завершает работу программы. При выполнении цепочки символов уровень рекурсии уменьшается на два. | ||||||||||||||||||||
| Q | Завершает работу программы. Вершина стека извлекается и уровень рекурсии уменьшается на полученное значение. | ||||||||||||||||||||
| x | Вершина стека трактуется как цепочка символов, содержащая dc-команды, и выполняется. | ||||||||||||||||||||
| X | Вершина стека заменяется количеством цифр в ее дробной части. | ||||||||||||||||||||
| [..] | Цепочка символов, заключенная в скобки, помещается в вершину стека. | ||||||||||||||||||||
| Два верхних элемента стека извлекаются и сравниваются. Если они удовлетворяют указанному условию, то содержимое регистра x рассматривается как команда dc и выполняется.
| v | Верхний элемент стека заменяется квадратным корнем из него. Если он имел дробную часть, то она учитывается; в противном случае точность вычислений (см. команду k) игнорируется.
| ! | Остаток строки интерпретируется как команда shell'а.
| c | Очистка стека.
| i | Вершина стека извлекается и используется как основание системы счисления при вводе. Команда I помещает используемое при вводе основание системы счисления в вершину стека.
| o | Вершина стека извлекается и используется как основание системы счисления при выводе. Команда O помещает используемое при выводе основание системы счисления в вершину стека.
| k | Извлекается вершина стека; она используется для задания точности вычислений: количества знаков в дробной части при выводе и при выполнении умножения, деления и возведения в степень.
| z | В стек помещается количество его элементов.
| Z | Число в вершине стека заменяется его длиной (без учета десятичной точки и знака минус).
| ? | Со стандартного ввода вводится одна строка и исполняется.
| ;: | Используются утилитой bc(1) для операций с массивами.
| |
ПРИМЕР
Вывести факториалы первых 10 натуральных чисел:
[la1+dsa*pla10>y]sy 0sa1 lyx
СМ. ТАКЖЕ
bc(1).
ДИАГНОСТИКА
x is unimplemented
(где x - восьмеричное число). Операция, обозначен-
ная символом с кодом x, не реализована.
stack empty
В стеке меньше элементов, чем требуется.
Out space
Слишком длинное число.
Out of headers
Слишком много чисел приходится хранить одновремен-
но.
Out of pushdown
Стек переполнен.
Nesting depth
Слишком большой уровень вложенности при выполне-
нии.
|