Разработка и исследование алгоритмов и процессоров вычисления значений элементарных функций тема диссертации и автореферата по ВАК РФ 05.13.05, кандидат технических наук Кошарновский, Александр Николаевич
- Специальность ВАК РФ05.13.05
- Количество страниц 187
Оглавление диссертации кандидат технических наук Кошарновский, Александр Николаевич
Введение
Глава 1. АНАЛИЗ МЕТОДОВ И СТРУКТУР ПРОЦЕССОРОВ 16 ВЫЧИСЛЕНИЯ ЭЛЕМЕНТАРНЫХ ФУНКЦИЙ В СЦВМ
1.1. Основные способы представления функций
1.1.1. Степенные ряды
1.1.2. Полиномы наилучшего приближения
1.1.3. Цепные дроби
1.1.4. Итерационные процессы
1.1.5. Аппроксимация Паде
1.1.6. Метод "цифра за цифрой"
1.1.7. Мультипликативный метод
1.2. Погрешности при вычислении элементарных функций
1.2.1. Методическая ошибка
1.2.2. Форма представления чисел и точность вычислений
1.2.3. Погрешности вычисления элементарных функций с помощью полино- 31 мов
1.2.4. Погрешности вычисления элементарных функций с использованием 33 сдвига и сложения
1.3. Таблично-алгоритмические процессоры элементарных функций
1.4. Процессоры элементарных функций на основе метода "цифра за цифрой"
1.5. Выводы
Глава 2. ИССЛЕДОВАНИЕ СТРУКТУР ПРОЦЕССОРОВ И 48 АЛГОРИТМОВ ВЫЧИСЛЕНИЯ ЭЛЕМЕНТАРНЫХ ФУНКЦИЙ НА ОСНОВЕ СТЕПЕННЫХ РЯДОВ (на основе полиномиального разложения)
2.1. Вычисление элементарных функций на основе разложения в ряд Тейлора
2.1.1. Исследование и выбор параметров аппроксимации и структуры процес- 51 сора для таблично-алгоритмического метода вычисления элементарных функций, представленных в виде ряда Тейлора
2.1.2. Сокращение аппаратных затрат
2.2. Разработка структуры процессора и алгоритма вычисления элементарных 56 функций с равномерной погрешностью на основе смешанной полиномиальной аппроксимации
2.3. Улучшение аппроксимации на основе разложения в степенной ряд
2.4. Исследование и разработка специализированных процессоров для вычис- 65 ления элементарных функций на основе разложения в степенной ряд
2.4.1. Вычисление полинома на одном процессоре
2.4.2. Процессор элементарных функций с распараллеливанием вычислений
2.4.3. Обоснование наилучшего варианта процессора элементарных функций
2.5. Выводы
Глава 3. ИССЛЕДОВАНИЕ И РАЗРАБОТКА АЛГОРИТМОВ 76 ВЫЧИСЛЕНИЯ ЭЛЕМЕНТАРНЫХ ФУНКЦИЙ НА ОСНОВЕ МУЛЬТИПЛИКАТИВНОГО МЕТОДА
3.1. Введение в мультипликативный метод
3.2. Алгоритмы перевода чисел в мультипликативный код
3.3. Мультипликативные алгоритмы деления
3.4. Мультипликативные алгоритмы вычисления логарифмов
3.5. Мультипликативные алгоритмы вычисления экспоненты
3.6. Мультипликативные алгоритмы извлечения квадратного корня и выполне- 87 ния операции нормирования в случае действительных аргументов
3.6.1. Погрешность вычисления квадратного корня
3.6.2. Быстродействие алгоритмов вычисления квадратного корня
3.7. Выводы
Глава 4. РАЗРАБОТКА СТРУКТУРЫ И АЛГОРИТМОВ ПРОЦЕССОРА 106 ВЫЧИСЛЕНИЯ ЭЛЕМЕНТАРНЫХ ФУНКЦИЙ
4.1. Анализ методов вычисления элементарных функций на спецпроцессорах
4.2. Разработка алгоритмов функционирования сопроцессора для вычисления 112 элементарных функций
4.2.1. Вычисление функции экспоненты у = ех
4.2.2. Вычисление функции натурального логарифма у = In х
4.2.3. Вычисление функции квадратного корня у = л/х ^
4.2.4. Вычисление функции синуса у = sinx
4.2.5. Вычисление функции косинуса у = cos х
4.2.6. Вычисление функции тангенса у - tgx
4.2.7. Вычисление функции y = arctgx
4.3. Мультипликативные алгоритмы вычисления элементарных функций
4.3.1. Вычисление экспоненты
4.3.2. Вычисление натурального логарифма
4.3.3. Вычисление квадратного корня
4.3.4. Вычисление частного
4.3.5. Вычисление арктангенса
4.3.6. Вычисление гиперболического арктангенса
4.3.7. Вычисление синуса, косинуса, тангенса и котангенса
4.3.8. Вычисление гиперболических синуса, косинуса, тангенса и котангенса
4.4. Разработка структуры процессора элементарных функций, реализующего 131 мультипликативные алгоритмы
4.4.1. Выбор прототипа процессора элементарных функций
4.4.2. Структура универсального процессора элементарных функций, реали- 134 зующих мультипликативные алгоритмы
4.5. Синтез сопроцессора элементарных функций, реализующего мультиплика- 137 тивные алгоритмы, на основе базовых матричных кристаллов
4.6. Выводы
Рекомендованный список диссертаций по специальности «Элементы и устройства вычислительной техники и систем управления», 05.13.05 шифр ВАК
Разработка и исследование параллельных схем цифровой обработки сигналов на основе минимизации временной сложности вычисления функций2008 год, кандидат технических наук Аксайская, Любовь Николаевна
Высокопроизводительные сопроцессоры для параллельной обработки данных в формате с плавающей точкой в системах цифровой обработки сигналов2013 год, кандидат технических наук Пантелеев, Алексей Юрьевич
Компьютерно-ориентированные схемы минимизации временной сложности цифровой обработки сигналов при динамическом изменении отсчетов2010 год, кандидат технических наук Забеглов, Валерий Валерьевич
Алгоритмы оптимизации временной сложности кусочно-полиномиальной аппроксимации функций в применении к быстрому преобразованию Фурье на основе параллельного вычисления элементов базиса2004 год, кандидат технических наук Фирсова, Светлана Александровна
Моделирование вычислительного процесса, разработка алгоритмов и пакета прикладных программ для вычисления экспоненциальной функции на программируемых логических интегральных схемах2009 год, кандидат технических наук Мо Чжо Чо
Введение диссертации (часть автореферата) на тему «Разработка и исследование алгоритмов и процессоров вычисления значений элементарных функций»
Вычисление значений элементарных функций является одной из самых распространенных математических операций в современных СЦВМ и БЦВМ, т.к. составляют основу алгоритмов, реализуемых в этих ЦВМ.
Так, современные БЦВМ, устанавливаемые на борту различного рода летательных аппаратов, в большинстве своем в качестве одной из основных решают задачу о встрече с другими летательными аппаратами, т.е. траекторную задачу, и определения местоположения летательного аппарата в земной или иной системе координат.
Например, известная задача преобразования координат (нахождение новых координат при повороте системы координат на угол ср) обычно выполняется по формулам [1] : fx' = X-COS(p-y-ÚVL<p у = у • cos(р + х • sin^, требующих вычисления двух функций (sin и cos), четырех операций умножения и двух сложений/вычитаний.
Метод Голуба [2] использует соотношения х'= (х + у) • (cos^ - sin<p) + х • sin<p - у • cos(р = у • COS^ + X • sin (р, вычисление которых требует трех умножений и пяти сложений/вычитаний.
Метод Бьюмена [2] позволяет выполнить данное преобразование за три умножения и четыре сложения/вычитания:
Преобразование же координат из декартовой системы в полярную выполняется по формулам [1]:
R = Jx2 +y2 <p = arctg^/.
Другим примером может служить задача определения дальности 8 и пеленга П на объект при известных географических координатах своего места (фс, Хс) и места объекта (ср0, А,0).
Для небольших расстояний задача решается по формулам [2]:
Ас-А0)-соз((<рс+<р0)/2)
П — arctg
Рс-Ро)
Б = <Рс-<Ро)2 +(ЛС-Л0)2 ■С082 (<рс+<ро)/2) .
В более общем случае курсовой угол и и дистанция Э до объекта вычисляются с учетом радиуса Земли Яз (обратная геодезическая задача на сфере) [2]:
D = R3 ■ arctg —
Рс~<Ро) cos(p0-sm(Ác-Á0) sin{7-(sin^0 -sin^ + cos<p„ -cos(pc -cos(Ac - A0))
Как видно, для решения этих задач помимо операций сложения и вычитания требуется выполнить вычисления функций sin х, cos х, х2, х/у, Vx и arctg х.
В задачах моделирования переходных процессов (электроники, теплотехники) широко используются функции экспоненты ех и натурального логарифма In х.
Алгоритмы решения перечисленных задач в качестве основных включают операции по вычислению значений элементарных функций, количество которых с учетом их взаимных преобразований может быть сведено к шести: sin х, cos х, ехр х, In х, arctg х, Vx .
В задачах расчета напряжений и деформаций в стержнях и оболочках ис-пользуюся так называемые функции Крылова К0 . К3 [2]:
Ко(х) = ch х ■ cos х ,
К\{х) = ^--(chx-sinx + shx-cosx),
Кг(х) = sh х • sin х ,
Кз(х) = ^ ■ (ch х • sin х - sh х • cos х), которые в свою очередь требуют вычисления гиперболических функций синуса и косинуса (sh х и ch х).
Поэтому в некоторых случаях количество вычисляемых спецпроцессором функций увеличивают до 10-13, включая в упомянутый перечень гиперболические функции и расширяя его за счет других тригонометрических функций.
Таким образом, наиболее полный перечень элементарных функций, потребность вычисления которых возникает при решении задач на СЦВМ, может быть следующим: sin х, cos х, tg х, ctg х, arctg х, sh х, ch х, th х, cth х, exp х, In х, Vx, х/у.
Поскольку основными требованиями к СЦВМ, помимо массы, габаритов и потребляемой мощности, являются требование точности и обработка данных в реальном масштабе времени, то возникает проблема выбора и разработки таких методов вычисления элементарных функций, которые обеспечивают получение результатов с требуемой точностью за приемлемое время.
Предметом исследования в диссертационной работе являются процессоры специализированных ЦВМ для вычисления значений элементарных функций, методы и алгоритмы их вычисления.
Как известно, методы приближенного вычисления функций возникли задолго до появления ЦВМ. Это, например, использование разложения в ряд Тейлора, метод итерации Ньютона и др. Но с появлением ЦВМ и особенно СЦВМ, появилась потребность в разработке новых методов.
Большой вклад в разработку методов вычисления элементарных функций на ЦВМ внесли И.Я.Акушский [3], В.С.Линский [4], Л.А.Люстерник [5], Ю.В.Антропов[6], В.Д. Байков, В.Б.Смолов, С.А.Селютин, С.Н.Вашкевич [2,7. 12], А.Д.Благовещенский, Г.С.Теслер [13], Д.Волдер [14], Д.Меджит[15], А.Д.Марковский [16] и многие другие авторы. Вопросы вычисления значений функций на ЦВМ рассматриваются также в [17 . 27].
Существует большое количество алгоритмов приближенного вычисления элементарных функций, выбор которых определяется как параметрами СЦВМ (разрядная сетка, система команд, быстродействие), так и требованиями решаемой задачи (максимально допустимая погрешность, время вычисления, состав операций).
Как известно [23], погрешность численного решения задачи обуславливается следующими причинами:
- математическое описание задачи является неточным, в частности, неточно заданы исходные данные описания;
- применяемый для решения метод часто не является точным: получение точного решения возникающей математической задачи требует неограниченного или неприемлемо большого числа арифметических операций, и поэтому вместо получения точного решения задачи приходится прибегать к приближенному;
- при вводе данных в ЦВМ, при выполнении математических операций и при выводе данных производятся округления.
Погрешности, соответствующие этим причинам, называют:
- неустранимая погрешность гн (погрешность исходных данных, неточные зависимости между параметрами);
- погрешность метода гм\
- вычислительная погрешность гв.
Очевидно, оптимальным решением будет разработка такой структуры СЦВМ и алгоритма вычисления, чтобы суммарная погрешность г0 = гн + гм + гв не превышала допустимую.
Поэтому, несмотря на огромное количество существующих методов и технических решений, является актуальной задача исследования и разработки более эффективных алгоритмов и структур процессоров для вычисления элементарных функций.
Методы вычисления элементарных функций, пригодные для вычисления на СЦВМ, подразделяются на следующие:
- разложение функции в степенной ряд Тейлора:
- представление функции в виде цепной дроби;
- аппроксимация функции полиномами наилучшего приближения (полиномами Чебышева);
- аппроксимация дробно-рациональной функцией (аппроксимация Паде);
- итерационные методы (метод Ньютона, метод хорд);
- метод "цифра за цифрой";
- мультипликативный метод.
Все эти методы сводятся к такому представлению функции, чтобы вычислить её значение для заданного значения аргумента с приемлемой точностью за допустимое время. Минимизация времени вычисления осуществляется за счёт использования наиболее быстрых операций ЦВМ: сложение и сдвиг(умножение или деление на 2). А выполнение «медленных» операций умножения и деления на произвольное число используется лишь на подготовительном (приведение аргумента к интервалу улучшенной сходимости функции) и заключительном этапах вычисления (восстановление функции для исходного значения аргумента).
Наличие быстрых и медленных операций, выполняемых процессорами, имеет место для большинства существующих ЭВМ, в том числе и для современных микропроцессоров. Однако, с появлением микропроцессоров, в которых все основные операции (в том числе умножение на произвольное число) выполняются за одинаковое время (за один машинный такт) и к тому же возможно одновременное выполнение нескольких операций упрощает решбние поставленной задачи. В табл. В.1. приведено время выполнения основных операций универсальным микропроцессором Intel 486 и цифровым сигнальным процессором ADSP2100.
Для ускорения обработки данных в современные процессоры встраивают команды вычисления некоторых элементарных функций. Например, в табл. В.2 приведен список встроенных функций для процессора Intel 486 и время их вычисления (количество машинных тактов) [28].
Таблица В.1. Время выполнения основных операций современными микропроцессорами (количество машинных тактов)
Операция Intel 486 ADSP2100
Сложение, вычитание : целочисленное 1 . 3 1 с плавающей запятой 8 .20 11
Сдвиг 2. 4 1 .4
Умножение целочисленное:
16 бит 13 .26 1
32 бит 13 .42 14
Умножение с ПЗ 11 . 16 9 . 13
Деление целочисленное:
16 бит 27 17
32 бит 43 485
Деление с ПЗ 73 . 89 33 .
Таблица В.2. Время вычисления элементарных функций на разных процессорах
Функция Intel 486 ADSP2100 л/х 83 . . 87 75 ху 30 . .32 sin X, COS X 193 . .279 25 tgx 200 . .273 arctg x 218 . . 303 58
Для процессора АББР известны рекомендованные фирмой-изготовителем алгоритмы вычисления ряда элементарных функций [29], время вычисления которых (количество системных тактов) также приведено в табл.В.2. Программная реализация некоторых из этих алгоритмов приведена в приложении 1.
Однако, в силу ряда причин в специализированных ЦВМ продолжают применяться процессоры, построенные на заказных или полузаказных (матричных) БИС.
В настоящее время существует множество различных методов реализации алгоритмов вычисления элементарных функций в ЭВМ [2,3,7,8,30 . 35].
Программный метод применяется как правило в универсальных ЭВМ, работающих с данными, представленными в форме с плавающей запятой.
Микропрограммный метод характерен для современных микропроцессорных систем и обеспечивает более высокое быстродействие по сравнению с программным методом.
Аппаратно-программный метод может представлять собой комбинацию аппаратных средств (например, ПЗУ для хранения опорных значений функции) и программных средств или комбинацию аппаратных средств и микропрограммных средств.
Аппаратный метод заключается в табличной организации процессора вычисления элементарных функций на основе ПЗУ, адресная часть которого является аргументом функции, а числовая - значением самой функции. Очевидно этот метод пригоден для вычисления значений функции с невысокой точностью. Достижения современной микроэлектроники позволяют построить табличные процессоры элементарных функций на основе ПЗУ с разрядностью аргумента не превышающей 12-16 двоичных разрядов.
Поэтому актуальной является задача выбора и разработки таких алгоритмов вычисления элементарных функций и такой структуры процессора, которые учитывают структуру и особенности современных МаБИС.
Разработка специализированного процессора на основе МаБИС является достаточно трудоемким и продолжительным процессом, а начало макетных испытаний связано с достаточно длительным процессом изготовления полузаказных БИС. В случае же ошибки в структуре процессора изготовление БИС приходится повторять заново.
Значительное ускорение в процессе создания СЦВМ дает использование программируемых логических интегральных схем (ПЛИС) [36], которые позволяют быстро отладить структуру разрабатываемого процессора и, затем, приступить к созданию безошибочного процессора на МаБИС.
Целью исследования в диссертационной работе является разработка эффективных структур процессоров СЦВМ и алгоритмов вычисления на них элементарных функций.
Для достижения указанной цели решаются следующие задачи:
- создание новых и модификация существующих методов вычисления элементарных функций на специализированных процессорах;
- разработка новых и модификация существующих структур специализированных процессоров с использованием современных БИС и ПЛИС;
- реализация полученных алгоритмов и структур в конкретных разработках специализированных процессоров.
При решении поставленной задачи используется следующий математический аппарат:
- численные методы;
- машинная арифметика.
Использовалась также теория проектирования специализированных цифровых вычислительных машин.
В практической части работы использовались методы автоматизации проектирования цифровых устройств, в том числе на базе МаБИС и ПЛИС.
Результаты, приведенные в диссертационной работе, получены в ходе выполнения ряда НИР, в которых автор принимал участие в качестве основного исполнителя, будучи аспирантом, а затем и научного руководителя.
Основные положения диссертации, выносимые на защиту:
1. Метод смешанной полиномиальной аппроксимации для вычисления восьми элементарных функций (sinx, cos х, tgx, arcsin х, arctg х, In х, ex,Vx). Метод основан на разбиении диапазона изменения аргумента на сегменты и аппроксимации на них полиномами разных степеней; причем для получения высокого быстродействия степень полинома выбирается минимальной, но обеспечивающей требуемую точность вычисления.
2. Структуры процессоров элементарных функций, обеспечивающие наибольшее быстродействие при вычислениях на основе разложения в степенной ряд, в том числе по методу смешанной полиномиальной аппроксимации.
3. Алгоритмы вычисления квадратного корня на основе мультипликативного метода вычисления элементарных функций. Алгоритмы используют лишь самые быстрые операции (сложение/вычитание и сдвиг) и требуют наименьшего количества итераций из всех известных алгоритмов.
4. Структура процессора элементарных функций, обеспечивающего вычисление 14 элементарных функций на основе мультипликативных алгоритмов. Данная структура обеспечивает наилучшие характеристики при ее реализации на современной элементной базе.
Работа состоит из введения, четырех глав, заключения, пяти приложений и списка литературы из 66 наименований.
Объем работы составляет 187 страниц, включая 16 таблиц, 14 рисунков и 39 страниц приложений.
В первой главе даётся анализ методов и структур процессоров для вычисления элементарных функций в СЦВМ. Рассматриваются основные способы представления функций ( степенные ряды, цепные дроби, полиномы наилучшего приближения, итерационные процессы, аппроксимация Паде, метод "цифра за цифрой", мультипликативный метод), погрешности при вычислении элементарных функций и структуры процессоров, используемых для вычисления элементарных функций. Обосновывается необходимость Обосновывается необходимость исследования и разработки новых алгоритмов и структур процессоров для вычисления элементарных функций на основе степенных рядов и мультипликативного метода.
Вторая глава посвящена способам и структурам процессоров для вычисления элементарных функций на основе разложения в ряд Тейлора: проводится анализ способов вычисления элементарных функций, исследование и выбор параметров аппроксимации и структуры процессора для таблично-алгоритмического метода вычисления элементарных функций, , анализ способов сокращения аппаратурных затрат, разработка структуры процессора и алгоритма вычисления элементарных функций с равномерной погрешностью на основе смешанной полиномиальной аппроксимации, предлагается улучшение аппроксимации на основе разложения в степенной ряд, проводится исследование и разработка специализированных процессоров для вычисления элементарных функций на основе разложения в степенной ряд (вычисление полинома на одном процессоре, процессор элементарных функций с распараллеливанием вычислений, обоснование наилучшего варианта процессора элементарных функций).
В третьей главе подробно рассматривается мультипликативный метод вычисления элементарных функций (введение в мультипликативный метод, алгоритмы перевода чисел в мультипликативный код, мультипликативные алгоритмы деления, мультипликативные алгоритмы вычисления логарифмов, мультипликативные алгоритмы вычисления экспонент). Разрабатываются мультипликативные алгоритмы извлечения квадратного корня и выполнения операции нормирования в случае действительных аргументов.
В четвёртой главе разрабатывается сопроцессор элементарных функций. Проводится разработка алгоритмов функционирования сопроцессора для вычисления 14-ти элементарных функций (разрабатываются алгоритмы приведения аргумента к интервалу аппроксимации и мультипликативные алгоритмы вычисления на интервалах аппроксимации). Разрабатывается структура универсального процессора элементарных функций, реализующих мультипликативные алгоритмы. Проводится синтез сопроцессора элементарных функций, реализующего мультипликативные алгоритмы, на основе базовых матричных кристаллов.
В заключении сформулированы основные результаты диссертационной работы.
В приложениях приведены программы вычисления некоторых элементарных функций на цифровых сигнальных процессорах серии АОБР 2100, пример работы алгоритмов перевода двоичного кода в мультипликативный, пример вычисления функции экспоненты на основе мультипликативного метода, примеры работы мультипликативного алгоритма извлечения квадратного корня.
Похожие диссертационные работы по специальности «Элементы и устройства вычислительной техники и систем управления», 05.13.05 шифр ВАК
Методы внешнего оценивания множества решений задачи удовлетворения ограничений2003 год, кандидат физико-математических наук Лоенко, Михаил Юрьевич
Разработка математических методов моделирования параллельно-конвейерных структур нейропроцессоров для решения задач быстрого преобразования Фурье2001 год, кандидат физико-математических наук Мезенцева, Оксана Станиславовна
Метод учета инструментальной и методической погрешности вычисления некоторых трансцендентных функций2006 год, кандидат физико-математических наук Виноградов, Евгений Владимирович
Моделирование вычислительного процесса в системах навигации летательного аппарата, разработка алгоритмов и комплексов программ для его реализации на программируемых логических интегральных схемах2005 год, кандидат физико-математических наук Чумакова, Екатерина Витальевна
Методы вычислений с гарантированной точностью на платформе "Мультикор"2007 год, кандидат технических наук Захаров, Андрей Вениаминович
Заключение диссертации по теме «Элементы и устройства вычислительной техники и систем управления», Кошарновский, Александр Николаевич
4.6. Выводы
1. Разработаны алгоритмы приведения аргумента к интервалам аппроксимации для 14 элементарных функций и проведена оценка их временной сложности, которая показала, что наибольшую сложность имеет алгоритм приведения для функции тангенса, наименьшую - квадратного корня.
2. Исследованы и модифицированы мультипликативные алгоритмы вычисления четырнадцати элементарных функций, что позволяет использовать их для построения быстродействующего сопроцессора элементарных функций.
3. Разработана структура универсального сопроцессора элементарных функций, обеспечивающая реализацию мультипликативных алгоритмов с максимальным быстродействием.
4. Реализация сопроцессора на БМК Такт-6000 показала эффективность принятых решений и обеспечила обработку данных в реальном масштабе времени.
ЗАКЛЮЧЕНИЕ
1. Анализ методов и структур процессоров для вычисления элементарных функций в СЦВМ показал, что с целью обеспечения высокой точности и высокого быстродействия необходимо провести исследование и разработку алгоритмов работы и структур процессоров элементарных функций на основе полиномиального разложения и на основе мультипликативного метода.
2. Проведенное исследование вычислительной сложности и погрешности алгоритмов вычисления элементарных функций на основе разложения в ряд Тейлора показало необходимость применения метода сегментно-полиномиальной аппроксимации.
3. Проведенное исследование сегментного метода вычисления элементарных функций показало возможность аппроксимации отдельных сегментов рядами Тейлора с различным количеством членов, то есть сводящихся к полиномам разных степеней, что позволяет уменьшить на 15-25 % объем памяти для хранения коэффициентов.
4. Проведенное исследование возможности вычисления элементарных функций на основе сегментно-полиномиальной аппроксимации показало, что с точки зрения объёма аппаратных затрат, быстродействия и погрешности при заданной разрядности аргумента и функции оптимальными для вычисления элементарных функций являются полиномы третьей и четвёртой степени.
5. Разработан ряд структур процессоров элементарных функций на современной элементной базе, проведена их сравнительная оценка и показано, что наилучшими параметрами обладают:
- структура конвейерного типа с использованием ускорителей умножения;
- структура с использованием параллельных вычислений преобразованного ряда Тейлора.
Данные технические решения защищены авторским свидетельством.
6. Проведенный анализ мультипликативных алгоритмов показал их существенное превосходство над традиционными методами вычисления элементарных функций, поскольку мультипликативные алгоритмы используют лишь самые быстрые операции (сдвиг и сложение/вычитание) и требуют применения меньшего числа итераций для получения конечного результата.
Показана необходимость разработки на современной элементной базе структур специализированного сопроцессора, реализующего мультипликативные алгоритмы вычисления элементарных функций.
7. На основе мультипликативного метода разработаны пять алгоритмов вычисления квадратного корня и выполнения операции нормирования в случае действительного аргумента, обладающие друг перед другом разными достоинствами. Один из них позволяет достичь минимума объема оборудования за счет применения только операций суммирования и упрощения анализа на каждом шаге итерации, другой - максимального быстродействия за счет более сложного анализа и применением не только операций суммирования, но и вычитания.
Аппаратная реализация алгоритма вычисления квадратного корня защищена авторским свидетельством.
8. Разработаны алгоритмы приведения аргумента к интервалам аппроксимации для 14 элементарных функций и проведена оценка их временной сложности, которая показала, что наибольшую сложность имеет алгоритм приведения для функции тангенса, наименьшую - квадратного корня.
9. Исследованы и модифицированы мультипликативные алгоритмы вычисления четырнадцати элементарных функций, что позволяет использовать их для построения быстродействующего сопроцессора элементарных функций.
10. Разработана структура универсального сопроцессора элементарных функций, обеспечивающая реализацию мультипликативных алгоритмов с максимальным быстродействием.
148
11. Реализация сопроцессора на БМК Такт-6000 показала эффективность принятых решений и обеспечила обработку данных в реальном масштабе вре мени.
Список литературы диссертационного исследования кандидат технических наук Кошарновский, Александр Николаевич, 2000 год
1. Выгодский М.Я. Справочник по высшей математике. -М: Наука, 1965-872 с.
2. Байков В.Д., Смолов В.Б. Специализированные процессоры: итерационные алгоритмы и структуры. -М.:Радио и связь, 1985-288 с.
3. Акушский И.Я. Многорегистровые схемы выполнения арифметических операций. // Вопросы теории математических машин 1958- Вып.1- с. 192-218.
4. Линский B.C. Вычисление элементарных функций в автоматических цифровыхмашинах. // Вычислительная математика. 1957- №2- с.90-119.
5. Люстерник Л.А., Червоненко О.А., Янпольский А.Р. Вычисление элементарных функций -М.: Физматгиз-1963-247 с.
6. Антропов Ю.В. Метод "приведения" как метод вычисления функций в ЭЦВМ.// Изв. ЛЭТИ-1962- Вып.52- с. 159 170.
7. Специализированные ЦВМ. Учебник для вузов./ Под ред. Смолова В.Б. М.:1. Высш.школа-1981-279 с.
8. Байков В.Д., Смолов В.Б. Аппаратурная реализация элементарных функций.
9. Л.: Изд-во Ленинградского университета-1975-96 с.
10. Байков В.Д., Вашкевич С.Н. Решение траекторных задач в микропроцессорныхсистемах ЧПУ. -Л.: Машиностроение-1986-106 с.
11. Байков В.Д., Селютин С.А. Анализ методов вычисления элементарных функций в микропроцессорах и микро-ЭВМ // Известия вузов. Приборостроение-1981-Вып.1-с. 54-56.
12. Байков В.Д., Селютин С.А. Вычисление элементарных функций в ЭКВМ-М.:Радио и связь-1982-с.28-33.
13. Смолов В.Б., Байков В.Д. Принципы и перспективы применения метода вы-численияй "цифра за цифрой". // Электроника и методы гибридных вычислений. Киев: АН УССР-1978-c.l 19-130.
14. Благовещенский А.Д.,Теслер Г.С. Вычисление элементарных функций на ЭВМ.-М.:Техника-1977-208 с.
15. Voider J.E. The CORDIC Trtigometric computing techique. // Computer design development.-N.-Y- 1976-p. 301-307.
16. Meggitt J.E. Pseudo division and pseudo multiplication process. //- IBM of Res. and Dev.- 1962-vol. 6-№2-p. 210-226.
17. Марковский А.Д. Мультипликативные алгоритмы и специализированные устройства для деления и вычисления некоторых классов функций//Научн.тр. Моск. лесотехн. ин-та.-1989-Вып.217-с. 57-69.
18. Демидович Б.П., Марон И.А. Основы вычислительной математики.-М.: Нау-ка-1966-664 с.
19. Копченова Н.В., Марон И.А. Вычислительная математика в примерах и зада-чах.-М.: Наука-1972-368 с.
20. Попов Б.А., Теслер Г.С. Вычисление функций на ЭВМ. Справочник-Киев: Наукова думка-1984-600 с.
21. Ахо А., Хопкрофр Дж., Ульман Дж. Построение и анализ вычислительных алгоритмов.-М.:Мир-1979-353 с.
22. Кнут Д. Искусство программирования для ЭВМ. В 3 т.—Т. 1: Основные алгоритмы. -М.:Мир,1976-73 5с.
23. Кнут Д. Искусство программирования для ЭВМ. В 3 т-Т.2: Получисленные алгоритмы.-М. :Мир, 1977-720с.
24. Бахвалов Н.С. Численные методы.-М.: Наука-1973-632 с.
25. Ремез Е.Я. Общие вычислительные методы Чебышевских приближений-Киев: АН УССР, Институт математики- 454 с.
26. Информационные системы. Табличная обработка информации. /Под ред. Балашова Е.П. и СмоловаВ.Б- JL: Энергоатомиздат-1985-180 с.
27. Скоробогатько В.Я. Теория ветвящихся цепных дробей и ее применение в вычислительной математике.-М.: Наука-1983-311 с.
28. Бейкер Дж., Грейвс-Моррис П. Аппроксимации Паде.-М.: Мир-1986-502 с.
29. Microprocessors. Handbook, vol.2.-Intel Corp.-l991-720 p.
30. Digital Signal Processing Applications Using The ADSP-2100 Family-Vol.1.-Englewood Cliffs, NJ: Prentice Hall-1992-320 p.
31. Карцев M.A., Брик B.A. Вычислительные системы и синхронная арифметика.-М.:Радио и связь-1981-360 с.
32. Функционально ориентированные процессоры. / Водяхо А.И., СмоловВ.Б., Плюснин В.У., Пузанков Д.В. -JL: Машиностроение-1988-224 с.
33. Мячев A.A., Степанков В.Н. Персональные ЭВМ и микроЭВМ. Основы организации. Справочник.-М.: Радио и связь-1991-320 с.
34. Лиждвой Г.Л., Шилейко A.B. Принципы построения вычислительного модуля, реализующего укрупненные операции.// Вычислительные системы и сре-ды.-Таганрог-1972-c. 170-172.
35. A.c. 1314337 СССР, МКИ3 G06F7/38. Устройство для вычисления функций. /Байков В.Д., Баканов А.Е., Рахматулин O.A. (СССР).-4с.:ил.
36. Gene L. Heviland and Al A. Tuszinski. A CORDIC Arithmetic Proceccor Chip.// IEEE Trans, on Comp.-Vol. C-29- No2, February 1980- p. 68-78.
37. Программируемые логические микросхемы на КМОП-структурах и их применение / Мальцев П.П., Гарбузов Н.И., Шарапов А.П., Кнышев Д.А. М.: Энергоатомиздат-1998. - 160 с.
38. Пашковский С. Вычислительные применения многочленов и рядов Чебыше-ва.-М.:Наука-1983-384 с.
39. Виноградов И.М. Основы теории чисел.-М.: Наука-1965-172 с.
40. Плотников A.B., Степашкин Г.И. Оценка инструментальной точности специализированного вычислителя. //Вычислительная техника, вып.1. / Под ред. Смолова В.Б. Л., Изд-во ЛГУ-1970-c. 187 - 194.
41. Поспелов Д.А. Арифметические основы вычислительных машин дискретного действия М.: Высшая школа-1970-380 с.
42. Карцев М.А. Арифметика цифровых машин.-М.: Наука-1969-575 с.
43. Марковский А.Д. Структура вычислительных систем с точки зрения точности и алгебраических критериев качества вычислений.//Дис. канд. физ.-мат. на-ук.-М.-1980-205 с.
44. A.c. 1383337 СССР, МКИ3 G06F7/38. Устройство для вычисления элементарных функций табличным методом. / Кошарновский А.Н. и др. (СССР).
45. Марковский А.Д., Меликов Г.Г. Мультипликативные алгоритмы типовых вычислений и организация устройств на их основе.//Научн. тр. /Моск. лесотехн. ин-т-1989-Вып.217-с.9-21.
46. Марковский А.Д., Полянский В.В. Временная сложность и сравнительная характеристика мультипликативных алгоритмов параллельного делениям/Вопросы авиационной науки и техники. Сер. Пилотажно-навигационные системы и приборы.-1988-Вып. 1.-е. 14-29.
47. Марковский А.Д., Пустовойтов О.И. Об одном мультипликативном алгоритме параллельного деления чисел.//Научн. тр. /Моск. лесотехн. ин-т.-1986-Вып. 183-е.37-42.
48. Марковский А.Д., Полянский В.В., Пустовойтов О.И. Мультипликативные алгоритмы параллельного деления чисел.//Вопросы авиационной науки и техники. Сер. Пилотажно-навигационные системы и приборы.-1988-Вып. 1-с.3-13.
49. A.c. 1417644 СССР. Устройство для параллельного деления чисел. / А.Д. Марковский (СССР).- 10 с.:ил.
50. A.c. 1618165 СССР. Устройство для параллельного деления чисел/ Марковский А.Д., Кошарновский А.Н. (СССР)-5 с.:ил.
51. A.c. 1505262 СССР. Цифровое логарифмическое устройство/А.Д. Марковский (СССР).-8 с.:ил.
52. Марковский А.Д., Пустовойтов О.И. Быстрый машинный алгоритм вычисления натурального логарифма//Научн. тр. /Моск. лесотехн. ин-т.-1987-Вып. 195-е.69-74.
53. Марковский А.Д., Евстигнеева О.В. Мультипликативные алгоритмы вычисления экспоненты в системе с фиксированной запятой.// Научн. тр. /Моск. лесотехн. ин-т.-1988-Вып.205-е.78-89.
54. A.c. 1381497 СССР. Устройство для извлечения квадратного корня/ Кошарновский А.Н., Марковский А.Д., Пустовойтов О.И. и др. (СССР). 10 е.: ил.
55. Марковский А.Д., Меликов Г.Г. Мультипликативный метод вычисления тригонометрических функций.//Сб. научн. тр. / МЛТИ -1987-Вып.№ 195- с.57-65.
56. Гаврилов Ю.В., Пучко А.Н. Арифметические устройства быстродействующих ЭВМ.-М.: Сов. Радио-1970-280 с.
57. Евстигнеев В.Г. Недвоичная машинная арифметика и специализированные процессоры /Под. ред. И.Я. Акушского.-М.: МИФИ СЕРВИС-1992-266 с.
58. Кошарновский А.Н., Маркин A.B., Евстигнеев В.Г. и др. Методы ускорения выполнения арифметических операций на современных ЭВМ//Научно-технический сборник Сер.8, вып.2(38), 1983.152
59. Кошарновский А.Н., Толстых М.М. Анализ исследований методом машинной обработки оптической информации в реальном масштабе времени: Аналитический обзор./М., 1984., № 3964. 2 с.
60. ПРОГРАММЫ ВЫЧИСЛЕНИЯ НЕКОТОРЫХ ЭЛЕМЕНТАРНЫХ
61. ФУНКЦИЙ на цифровых сигнальных процессорах серии ADSP2100 фирмы Analog Device
62. П1.1. Вычисление квадратного корня1. MODULE Squareroot; {1. Square Root Y = sqrt(x)
63. Calling Parameters MR1 = MSW of x MRO = LSW of x M3 = 1 L3 = 01. Return Values
64. SR1 = y in 8.8 UNSIGNED format1. Altered Registers
65. AXO,AYO,AY1,AR,MYO,MY1,MXO,MF,MR,SE,SR,I31. Computation Time75 cycles (maximum)
66. CONST base=H#0D49, sqrt2=H#5A82; .VAR/DM sqrtcoeff5.;
67. IT sqrtcoeff : H#5D1D, H#A9ED, H#46D6, H#DDAA, H#072D; .ENTRY sqrt;sqrt: l3=Asqrtcoeff; {Pointer to coeff. buffer}
68. SE=EXP MR1 (HI); {Check for redundant bits}1. SE=EXP MRO (LO);
69. AX0=SE, SR=NORM MR1 (HI); {Remove redundant bits}1. SR=SR OR NORM MRO (LO);1. MY0=SR1, AR=PASS SR1;1. EQ RTS;1. MR=0;
70. MR1=base; {Load constant value}
71. MF=AR*MY0 (RND), MX0=DM(I3,M3); {MF = x**2} MR=MR+MX0*MY0 (SS), MX0=DM(I3,M3); {MR = base + C1*x} CNTR=4;1. DO approx UNTIL CE;
72. MR=MR+MX0*MF (SS), MX0=DM(I3,M3); approx:MF=AR*MF (RND); AY0=15;
73. MY0=MR1, AR=AX0+AY0; {SE + 15 = 0?}
74. NE JUMP scale; {No, compute sqrt(s)}
75. SR=ASHIFT MR1 BY-6 (HI); RTS; scale: MR=0;
76. AR=AR AND AYO; {Remove sign bit}1. MY1=AR;
77. MF=AR*MY1 (RND), MX1=DM((3,M3); {MF = x**2} MR=MX1*MY1 (SS), MX1=DM(I3,M3); {MR = C1*x} CNTR=3;1. DO approx UNTIL CE;
78. MR=MR+MX1*MF (SS); approx: MF=AR*MF (RND), MX1=DM(I3,M3); MR=MR+MX1*MF (SS); SR=ASHIFT MR1 BY 3 (HI);
79. SR=SR OR LSHIFT MRO BY 3 (LO); {Convert to 1.15 format} AR=PASS SR1;
80. LT AR=PASS AYO; {Saturate if needed}1. AF=PASS AXO'
81. LT AR=-AR; ' {Negate output if needed}1. RTS' .ENDMOD;
82. П1.3. Вычисление логарифма1. MODULE Logarithms;1.garithm Approximations y=log10(x) y=ln(x)1. Calling Parameters
83. MR1 = Integer Portion of x in 16.0 twos complement MRO = Fractional Portion of x in 0.16 unsigned M3 = 1 L3 = 01. Return Values
84. SR1 = Y (4.12 format for log; 5.11 format for In)1. Altered Registers
85. AX0,AY0,AR,MY1 ,MX1 ,MF,MR,SE,SR,l31. Computation Time33 cycles (maximum)
86. CONST log2=H#2688,ln2=H#2C5D;1. VAR/DM lncoeffs5.;1. VAR/DM logcoeffs5.;
87. IT In coeffs : H#7FE3, H#C149, H#2491, H#EEF8, H#0404;
88. EQ JUMP noinv; {If input < 1, no need to invert}
89. SE=EXP MR1 (HI); {Invert input}1. SR=NORM MR1 (HI);1. SR=SR OR NORM MRO (LO);1. AX0=SR1;1. SI=H#0001;1. SR=NORM SI (HI);1. AY1=SR1;1. AY0=SR0;1. DIVS AY1 ,AX0;
90. DIVQ AXO; DIVQ AXO; DIVQ AXO; DIVQ AXO; DIVQ AXO; DIVQ AXO; DIVQ AXO; DIVQ AXO; DIVQ AXO; DIVQ AXO; DIVQ AXO; DIVQ AXO; DIVQ AXO; DIVQ AXO; DIVQ AXO; AR=AY0; noinv: MY0=AR;
91. MF=AR*MY0 (RND), MY1=DM(I3,M3); MR=AR*MY1 (SS), MX1=DM(13,M3); CNTR=3;1. DO approx UNTIL CE;
92. MR=MR+MX1*MF (SS), MX1=DM(I3,M3); approx: MF=AR*MF (RND); MR=MR+MX1*MF (SS); AR=MR1; AY0=H#4000; AF=PASS AY1; IF NE AR=AY0-MR1; AF=PASS AX1; IF LT AR=-AR; RTS; .ENDMOD;
93. АЛГОРИТМЫ ПЕРЕВОДА ДВОИЧНОГО КОДА В МУЛЬТИПЛИКАТИВНЫЙ И ПРИМЕРЫ ИХ РАБОТЫ
94. Соответствующее ему число х = -—1 VI + 2 ,
95. Шо:- <Зо {Знаки одинаковые}т^01 1 < 1 <п-1 {Обнуление мантиссы мультипликативного кода} § := 0 . с! 1 с12. с!п.1 { g := | ¿/1 модуль й)
96. Для к от 1 до п-1 делать цикл2"к {Сложить g со значением g, сдвинутым на кразрядов вправо } Если f < 1 то {А если / >=/, то g не изменяется§ := Г и к-тый разряд мультипликативного кода
97. С+Ог= 0.1111001 <1, следовательно т2.:=1 и 0:= в+вг к= 3 .1111001 Ог= .00011110+0г= 1.0001000 >1, следовательно гп 3.:=0 и в не меняется к= 4 .1111001 вг= .00001110+0г= 1.0000000 >1, следовательно ш 4. :=0 и й не меняется к= 5 .1111001 Сг= .0000011
98. С+Сг= 0.1111100 <1, следовательно ш5.:=1 и С:=С+Сг к= 6 .1111100 вг= .00000010+Сг= 0.1111101 <1, следовательно т 6.:=1 и 0:= О+йг к= 7 .1111101 йг= .0000000
99. С+Ог= 0.1111101 <1, следовательно ш 7.:=1 . Конец.1. Таким образом:х =0.1000001 =0.5078 т=0.1100111 = 0.5053 Погрешность 0.0025 < 0.0156х = .1000011к= 1 .10000111. Сг= .0100001
100. С+Ог= 0.1100100 <1, следовательно т 1.:=1 и С:= в+йгк= 2 .1100100вг= .0011001
101. С+Сг= 0.1111101 <1, следовательно т2.:=1 ив" в+Ог к= 3 .1111101 вг= .0001111
102. С+Ог= 1.0001100 >1, следовательно гп 3.:=0 и й не меняется к= 4 .1111101 Ог= .0000111
103. С+Ог= 1.0000100 >1, следовательно гп 4.:=0 и б не меняется к= 5 .1111101 Сг= .00000110+Сг= 1.0000000 >1, следовательно ш 5.:=0 и в не меняется к= 6 .1111101 Сг= .0000001
104. С+Ог= 0.1111110 <1, следовательно ш 6.:= 1 и 0:= в+вг к= 7 .1111110 Ог= .0000000
105. С+Сг= 0.1111110 <1, следовательно ш 7.:=1 . Конец.1. Таким образом:х =0.1000011 = 0.5234 т=0.1100011 =0.5211 Погрешность 0.0024 < 0.0156п=16. Формат 1.15 (Знак +15 разрядов мантиссы)
106. Погрешность перевода не более 2"13 = 0.00012207 (2"14 =0.0000610352) х = .100000000000000 ;к= 1 G = .100000000000000 1. Gr= .010000000000000
107. G+Gr= 0.110000000000000 <1, следовательно m 1.:= =1 иО:= С+вгк= 2 G = .110000000000000 1. Gr= .001100000000000
108. G+Gr= 0.111100000000000 <1, следовательно m 2.:= =1 иС:= О+Сгк= о G = .111100000000000 1. Gr= .000111100000000
109. G+Gr= 1.000011100000000 >1, следовательно m 3.: =0 и С не меняетсяк= 4 G = .111100000000000 1. Gr= .000011110000000
110. G+Gr= 0.1111111 10000000 <1, следовательно m 4.:= Ч иО:=С+Сгк= 5 G = .111111110000000 1. Gr= .000001111111100
111. G+Gr= 1.000001101111100 >1, следовательно m 5.:= =0 и О не меняетсяк= 6 G = .111111110000000 1. Gr= .000000111111110
112. G+Gr= 1.000000101111110 >1, следовательно m 6.:= =0 и О не меняетсяк= 7 G = .111111110000000 1. Gr= .000000011111111
113. G+Gr= 1.000000001111111 >1, следовательно m 7.: =0 и С не меняетсяк= 8 G = .111111110000000 1. Gr= .00000000111111!
114. G+Gr= 0.111111111111111 <1, следовательно m 8.:= = 1 и 0:= й+Сгк= 9 G = .111111111111111 1. Gr= .000000000111111
115. G+Gr= 1.0000000001 111 10 >1, следовательно m 9.: =0 и О не меняетсяк= 10 G = .111111111111111 1. Gr= .000000000011111
116. G+Gr= 1.000000000011110 >1, следовательно m10. :=0 и О не меняетсяк= 11 G = .111111111111111 1. Gr= .0000000000011 11
117. G+Gr= 1.000000000001110 >1, следовательно ml 1.: =0 и й не меняетсяк= 12 G = .111111111111111 1. Gr= .000000000000111
118. G+Gr= 1.000000000000110 >1, следовательно m12.: =0 и й не меняетсяк= 13 G = .111111111111111 1. Gr= .000000000000011
119. G+Gr= 1.000000000000010 >1, следовательно m13.: =0 и й не меняетсяк= 14 G = .111111111111111 1. Gr= .000000000000001
120. G+Gr= 1.000000000000000 >1, следовательно m14.: =0 и О не меняетсяк= 15 G = .111111111111111 1. Gr= .000000000000000
121. G+Gr= 0.111111111111111 <1, следовательно m15.:=l . Конец.1. Таким образом:х =0.100000000000000 = 0.5000000000 т=0.110100010000001 = 0.4999923710
122. Погрешность 0.0000076290 < 0.0000610352х = . 110000000000000 к= 1 G = .1100000000000001. Gr= .011000000000000
123. G+Gr= 1.001000000000000 >1, следовательно m 1.:=0 и G не меняется к= 2 G = .1100000000000001. Gr= .001100000000000
124. G+Gr= 0.111100000000000 <1, следовательно m 2.:= =1 и в- С+йгк= 3 G = .111100000000000 1. Gr= .000111100000000
125. G+Gr= 1.000011100000000 >1, следовательно m 3.:: =0 и в не меняетсяк= 4 G = .111100000000000 1. Gr= .000011110000000
126. G+Gr= 0.111111110000000 <1, следовательно m 4.:= =1 и С:= О+йгк= 5 G = .111111110000000 1. Gr= .000001111111100
127. G+Gr= 1.000001101111100 >1, следовательно m 5.:= :0 и й не меняетсяк= 6 G = .111111110000000 1. Gr= .000000111111110
128. G+Gr= 1.000000101111110 >1, следовательно m 6.:= =0 и С не меняетсяк= 7 G = .111111110000000 1. Gr= .000000011111111
129. G+Gr= 1.000000001111111 >1, следовательно m 7.:= :0 и О не меняетсяк= 8 G = .111111110000000 1. Gr= .000000001111111
130. G+Gr= 0.111111111111111 <1, следовательно m 8.:: =1 и С+Сгк= 9 G = .111111111111111 1. Gr= .000000000111111
131. G+Gr= 1.000000000111110 >1, следовательно m 9.:: =0 и О не меняетсяк= 10 G = .111111111111111 1. Gr= .000000000011111
132. G+Gr= 1.000000000011110 >1, следовательно m10.:: =0 и О не меняетсяк= 11 G = .111111111111111 1. Gr= .000000000001111
133. G+Gr= 1.000000000001110 >1, следовательно ml 1 .: :=0 и О не меняетсяк= 12 G = .111111111111111 1. Gr= .000000000000111
134. G+Gr 1.000000000000110 >1, следовательно m12.:: =0 и 0 не меняетсяк= 13 G = .111111111111111 1. Gr= .000000000000011
135. G+Gr= 1.000000000000010 >1, следовательно m13.:: =0 и в не меняетсяк= 14 G = .111111111111111 1. Gr= .000000000000001
136. G+Gr= 1.000000000000000 >1, следовательно m14. :=0 ийне меняетсяк= 15 G = .111111111111111 1. Gr= .000000000000000
137. G+Gr= 0.111111111111111 <1, следовательно m15. :=1 . Конец.1. Таким образом:х =0.110000000000000 = 0.7500000000 m=0.0101 ООО 10000001 = 0.7499885564
138. Погрешность 0.0000114436 < 0.0000610352х = . 111000000000000к= 1 G = .111000000000000 1. Gr= .011100000000000
139. G+Gr= 1.010100000000000 >1, следовательно m 1.:= =0 и G не меняетсяк= 2 G = .111000000000000 1. Gr= .001110000000000
140. G+Gr= 1.000110000000000 >1, следовательно m 2.:: =0 и G не меняетсяк= 3 G = .111000000000000 1. Gr= .000111000000000
141. G+Gr= 0.111111000000000 <1, следовательно m 3.:= = 1 и G:= G+Grк= 4 G = .111111000000000 1. Gr= .000011111100000
142. G+Gr= 1.000010111100000 >1, следовательно m 4.:= =0 и G не меняетсяк= 5 G = .111111000000000 1. Gr= .000001111110000
143. G+Gr= 1.000000111110000 >1, следовательно m 5.:= :0 и О не меняетсяк= 6 G = .111111000000000 1. Gr= .000000111111000
144. G+Gr= 0.111111111111000 <1, следовательно m 6.:= :1 иС:=С+Огк= 7 G = .111111111111000 1. Gr= .000000011111111
145. G+Gr= 1.000000011110111 >1, следовательно m 7.:= :0 и С не меняетсяк= 8 G = .111111111111000 1. Gr= .000000001111111
146. G+Gr= 1.000000001110111 >1, следовательно m 8.:= :0 и О не меняетсяк= 9 G = .111111111111000 1. Gr= .000000000111111
147. G+Gr= 1.000000000110111 >1, следовательно m 9.:= =0 и О не меняетсяк= 10 G = .111111111111000 1. Gr= .000000000011111
148. G+Gr= 1.000000000010111 >1, следовательно m10.: =0 и О не меняетсяк= 11 G = .111111111111000 1. Gr= .000000000001111
149. G+Gr= 1.000000000000111 >1, следовательно ml 1.: :=0 и О не меняетсяк= 12 G = .111111111111000 1. Gr= .000000000000111
150. G+Gr= 0.111111111111111 <1, следовательно m12.:: =1 и С:= О+Огк= 13 G = .111111111111111 1. Gr= .000000000000011
151. G+Gr= 1.000000000000010 >1, следовательно m13.: ;=0 и О не меняетсяк= 14 G = .111111111111111 1. Gr= .000000000000001
152. G+Gr= 1.000000000000000 >1, следовательно m14. :=0 и С не меняетсяк= 15 G = .111111111111111 1. Gr= .000000000000000
153. G+Gr= 0.111111111111111 <1, следовательно m15.:: =1 . Конец.1. Таким образом:х =0.111000000000000 = 0.8750000000 m=0.001001000001001 = 0.8749733501
154. Погрешность 0.0000266499 < 0.0000610352х = . 100000000000001к= 1 G = .1000000000000011. Gr= .010000000000000
155. G+Gr= 0.110000000000001 <1, следовательно гп 1.:=1 и С:= С+йгк= 2 G = .1100000000000011. Gr= .001100000000000
156. G+Gr= 0.111100000000001 <1, следовательно т 2.:=1 и 0:= О+Огк= j G = .1111000000000011. Gr= .000111100000000
157. G+Gr= 1.000011100000001 >1, следовательно ш 3.:=0 и О не меняетсяк= 4 G = .1111000000000011. Gr= .000011110000000
158. G+Gr= 0.111111110000001 <1, следовательно т 4.:=1 и 0:= й+Огк= 5 G = .1111111100000011. Gr= .000001111111100
159. G+Gr= 1.000001101111101 >1, следовательно т 5.:=0 и й не меняетсяк= 6 G = .1111111100000011. Gr= .000000111111110
160. G+Gr= 1.000000101111111 >1, следовательно ш 6.:=0 и С не меняетсяк= 7 G = .1111111100000011. Gr= .000000011111111
161. G+Gr= 1.000000010000000 >1, следовательно m 7.:=0 и G не меняетсяк= 8 G = .1111111100000011. Gr= .000000001111111 •
162. G+Gr= 1.000000000000000 >1, следовательно m 8.:=0 и G не меняетсяк= 9 G = .1111111100000011. Gr= .000000000111111
163. G+Gr= 0.111111111000000 <1, следовательно m 9.:=1 и G:= G+Grк= 10 G = .1111111110000001. Gr= .000000000011111
164. G+Gr= 0.111111111011111 <1, следовательно m10.:=l и G:= G+Grк= 11 G = .1111111110111111. Gr= .000000000001111
165. G+Gr= 0.111111111101110 <1, следовательно ml 1.:=1 и G:= G+Grк= 12 G = .1111111111011101. Gr= .000000000000111
166. G+Gr= 0.111111111110101 <1, следовательно m12.:=l и G:= G+Grк= 13 G = .1111111111101011. Gr= .000000000000011
167. G+Gr= 0.111111111111000 <1, следовательно m13.:=l и G:= G+Grк= 14 G = .1111111111110001. Gr= .000000000000001
168. G+Gr= 0.111111111111001 <1, следовательно m14.:=l и G:= G+Grк= 15 G = .1111111111110011. Gr= .000000000000000
169. G+Gr= 0.111111111111001 <1, следовательно m15.:=l . Конец.1. Таким образом:х =0.100000000000001 = 0.5000305176 m=0.110100001111111 = 0.5000203539
170. Погрешность 0.0000101636 < 0.0000610352х = . 100000000000011k= 1 G = .100000000000011 1. Gr= .010000000000001
171. G+Gr= 0.110000000000100 <1, следовательно т 1.:= Л и G:= G+Grk= 2 G = .110000000000100 1. Gr= .001100000000001
172. G+Gr= 0.111100000000101 <1, следовательно ш 2.:= и G:= G+Grk= j G = .111100000000101 1. Gr= .000111100000000
173. G+Gr= 1.000011100000101 >1, следовательно гп 3.:: =0 и G не меняетсяk= 4 G = .111100000000101 1. Gr= .000011110000000
174. G+Gr= 0.111111110000101 <1, следовательно ш 4.:= =1 и G:= G+Grk= 5 G = .111111110000101 1. Gr= .000001111111100
175. G+Gr= 1.000001110000001 >1, следовательно ш 5.:: =0 и G не меняетсяk= 6 G = .111111110000101 1. Gr= .000000111111110
176. G+Gr= 1.000000110000011 >1, следовательно т 6.:: =0 и G не меняетсяk= 7 G = .111111110000101 1. Gr= .000000011111111
177. G+Gr= 1.000000010000100 >1, следовательно гп 1\: =0 и G не меняетсяk= 8 G = .111111110000101 1. Gr= .000000001111111
178. G+Gr= 1.000000000000100 >1, следовательно т 8.:= =0 и G не меняетсяk= 9 G = .111111110000101 1. Gr= .000000000111111
179. G+Gr= 0.111111111000100 <1, следовательно т 9.:: =1 и G:= G+Grk= 10 G = .111111111000100 1651. Gr= .000000000011111
180. G+Gr= 0.111111111100011 <1, следовательно m10.:=l и G:= G+Gr k= 11 G= .111111111100011 Gr= .000000000001111
181. G+Gr= 0.111111111110010 <1, следовательно mll.:=l и G:= G+Gr k= 12 G= .111111111110010 Gr= .000000000000111
182. G+Gr= 0.111111111111001 <1, следовательно ш12.:=1 и G:= G+Gr k= 13 G= .111111111111001 Gr= .000000000000011
183. G+Gr= 0.111111111111100 <1, следовательно m13.:=l и G:= G+Gr k= 14 G= .111111111111100 Gr= .000000000000001
184. G+Gr= 0.111111111111101 <1, следовательно m14.:=l и G:= G+Gr k= 15 G = .111111111111101 Gr= .000000000000000
185. G+Gr= 0.111111111111101 <1, следовательно m15.:=l . Конец.1. Таким образом:x =0.100000000000011 0.5000915527 m=0.110100001111111 = 0.5000203539
186. Погрешность 0.0000711988 < 0.00012207
187. Соответствующее ему число х
188. Конец если Повторять цикл до тех пор, пока к < п-1.1. Пример работы Алгоритма 2
189. Погрешность перевода не более 2"13 = 0.00012207 (2"14 =0.0000610352)х = .100000000000000
190. Шаг= 1 G = .100000000000000 к= 21. Gr= .001000000000000
191. G+Gr= 0.101000000000000 было: т 2.=0 стало: ш[ 2]:=1
192. Шаг= 2 G = .101000000000000 к= 21. Gr= .001010000000000
193. G+Gr= 0.110010000000000 было: т2.='. 1 стало: ш[ 2]:=2
194. И1аг= 3 G = .110010000000000 к= 31. Gr= .000110010000000
195. G+Gr= 0.111000010000000 было: т 3.=0 стало: гп[ 3]:=1
196. Шаг= 4 G = .111000010000000 к= 41. Gr= .000011100001000
197. G+Gr= 0.111011110001000 было: ш4.=0 стало: т[ 4]:=1
198. Шаг= 5 G = .111011110001000 к= 41. Gr= .000011101111000
199. G+Gr= 0.111111100000000 было: т4.=1 стало: т[ 4]:=2
200. Шаг= 6 G = .111111100000000 к= 81. Gr= .000000001111111
201. G+Gr= 0.111111101111111 было: т 8.=0 стало: ш[ 8]:=1
202. Шаг= 7 G = .111111101111111 к= 81. Gr= .000000001111111
203. G+Gr= 0.111111111111110 было: т8.=: 1 стало: т[ 8]:=2
204. Шаг= 8 G = .111111111111110 к= 15. к>= п-1. Конец.1. Таким образом:х =0.100000000000000 = 0.5000000000 ш=0.021200020000000 = 0.5000152591
205. Погрешность 0.0000152591 < 0.0000610352х = .110000000000000
206. Шаг= 1 G = Gr= .110000000000000 .000110000000000 к= 3
207. G+Gr= 0.110110000000000 было: т 3.=0 стало: т[ 3]:=1
208. Шаг= 2 G = Gr= .110110000000000 .000110110000000 к= 3
209. G+Gr= 0.111100110000000 было: т3.=1 стало: ш[ 3]:=2
210. Шаг= 3 G = Gr= .111100110000000 .000001111001100 к= 5
211. G+Gr= 0.1 111 10101001100 было: т 5.=0 стало: т[ 5]:=1
212. Шаг= 4 G = Gr= .111110101001100 .000000111110101 к= 6
213. G+Gr= 0.111111101000001 было: т 6.=0 стало: т[ 6]:=1
214. Шаг= 5 G = Gr= .111111101000001 .000000001111111 к= 8
215. G+Gr= 0.111111111000000 было: т 8.=0 стало: гп[ 8]:=1
216. Шаг= 6 G = Gr= .111111111000000 .000000000011111 к=10
217. G-Gr= 0.11111 П 11011111 было: ш10.=0 стало: т[10]:=1
218. Шаг= 7 G = Gr= .111111111011111 .000000000011111 к=10
219. G+Gr= 0.111111111111110 было : т10.=1 стало: гп[10]:=
220. Шаг= 8 G = .111111111111110 к=15. к>= п-1. Конец.1. Таким образом:х =0.110000000000000 = 0.7500000000 т=0.002011010200000 = 0.7499920077
221. Погрешность 0.0000079923 < 0.0000610352х =.1111111000000001. Шаг= 11. Шаг= 2111111100000000 к= 800000000111 111
222. С+Ог= 0.11111110111 111 было: ш 8.=011111110111 111 к= 800000000111 111
223. С+Ог= 0.11111111111 110 было. гп 8.=111111111111 110 к=15. к >= п-1стало: ш 8.:=11. Шаг= 3 Таким образом:х =0.111111100000000 = 0.9921875000 т=0.000000020000000 = 0.9922330391
224. Погрешность 0.0000112512 < 0.0000610352х1. Шаг= 11. Шаг= 21. Шаг= 31. Шаг= 41. Шаг= 51. Шаг= 61. Шаг= 71. Шаг= 81. Шаг= 91000000000000010 = .100000000000001 к= 20010000000000000+Сг= 0.101000000000001 было:о = .101000000000001 к=21. Сг= .001010000000000
225. С+Ог= 0.110010000000001 было:й = .110010000000001 к= 31. Сг= .000110010000000
226. С+Сг= 0.111000010000001 было:111000010000001 к= 41. Сг= .0000111000010000+бг= 0.111011110001001 было:в = .111011110001001 к= 4000011101111000
227. С+Ог= 0.111111100000001 было:111111100000001 к= 8000000001111111
228. С+Ог= 0.11111 1110000000 было:в = .111111110000000 к= 9000000000111111
229. С+Ог= 0.111111110111111 было:б = .111111110111111 к= 91. Сг= .000000000111111
230. С+Ог= 0.111111111111110 было:111111111111110. к=15. к1. Таким образом:х =0.100000000000001 = 0.5000305176 m=0.021200012000000 = 0.5000133592
231. Погрешность 0.0000171584 < 0.0000610352х = . 1000000000000111. Шаг= 11. Шаг= 21. Шаг= 31. Шаг= 41. Шаг= 51. Шаг= 61. Шаг= 71. Шаг= 81. Шаг= 91. Шаг=101. Шаг=11
232. G = Gr= G+Gr= G = Gr= G+Gr= G = Gr= G+Gr= G = Gr= G+Gr= G = Gr= G+Gr= G = Gr= G+Gr= G = Gr= G+Gr= G = Gr= G+Gr= G = Gr= G+Gr= G = Gr= G+Gr= G =0
Обратите внимание, представленные выше научные тексты размещены для ознакомления и получены посредством распознавания оригинальных текстов диссертаций (OCR). В связи с чем, в них могут содержаться ошибки, связанные с несовершенством алгоритмов распознавания. В PDF файлах диссертаций и авторефератов, которые мы доставляем, подобных ошибок нет.