Научная статья на тему 'Построение фрактальных объектов при помощи библиотеки mpich2'

Построение фрактальных объектов при помощи библиотеки mpich2 Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
219
37
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
ТЕОРИЯ ФРАКТАЛОВ / ПАРАЛЛЕЛЬНОЕ ПРОГРАММИРОВАНИЕ / MPI / MPICH2 / FRACTAL THEORY / PARALLEL PROGRAMMING

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Танхасаев Аюр Васильевич

В первой рассматриваются фракталы и методы конструирования фрактальных объектов. Описаны виды фракталов и алгоритмы реализации; во второй освещены проблемы параллельного программирования и программный пакет MPICH2. Дан пример построения фрактала кривая Коха с применением методов параллельного программирования.

i Надоели баннеры? Вы всегда можете отключить рекламу.
iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

CONSTRUCTION OF FRACTAL OBJECTS BY MEANS OF LIBRARY MPICH2

In the first part it is told about fractal objects and methods of their construction. Kinds of fractals and algorithms for their modeling are described. In the second part it is told about problems of parallel programming and the software for their realization. The example of construction of a fractal Kokh''s curve by means of methods of parallel programming is considered.

Текст научной работы на тему «Построение фрактальных объектов при помощи библиотеки mpich2»

2. СИСТЕМНЫЙ АНАЛИЗ И ИНФОРМАЦИОННЫЕ ТЕХНОЛОГИИ

© А.В. Танхасаев

ПОСТРОЕНИЕ ФРАКТАЛЬНЫХ ОБЪЕКТОВ ПРИ ПОМОЩИ БИБЛИОТЕКИ MPICH2

Статья состоит из двух частей:

В первой рассматриваются фракталы и методы конструирования фрактальных объектов. Описаны виды фракталов и алгоритмы реализации; во второй освещены проблемы параллельного программирования и программный пакет MPICH2. Дан пример построения фрактала кривая Коха с применением методов параллельного программирования.

Ключевые слова: теория фракталов, параллельное программирование, MPI, MPICH2.

A.V. Tankhasaev

CONSTRUCTION OF FRACTAL OBJECTS BY MEANS OF LIBRARY MPICH2

In the first part it is told about fractal objects and methods of their construction. Kinds of fractals and algorithms for their modeling are described. In the second part it is told about problems of parallel programming and the software for their realization. The example of construction of a fractal - Kokh's curve by means of methods of parallel programming is considered. Keywords: fractal theory, parallel programming, MPI, MPICH2.

Понятия фрактал и фрактальная геометрия, появившиеся в конце 70-х гг., с середины 80-х прочно вошли в обиход математиков и программистов. Слово «фрактал» образовано от латинского fractus, в переводе означает: состоящий из фрагментов. Оно было предложено Бенуа Мандельбротом в 1975 г. для обозначения нерегулярных, но самоподобных структур, которыми он занимался. Рождение фрактальной геометрии принято связывать с выходом в 1977 г. книги Мандельброта The Fractal Geometry of Nature'

Виды фракталов

Геометрические. В двухмерном случае их получают с помощью некоторой ломаной (или поверхности в трехмерном случае), называемой генератором. За один шаг алгоритма каждый из отрезков, составляющих

Танхасаев А.В. Построение фрактальных объектов при помощи библиотеки МР1СН2

ломаную, заменяется на ломаную-генератор, в соответствующем масштабе. В результате бесконечного повторения этой процедуры и получается геометрический фрактал.

Л

Рис. 2

Алгебраические. Получают их с помощью нелинейных процессов в п-мерных пространствах. Наиболее изучены двухмерные процессы. Интерпретируя нелинейный итерационный процесс, как дискретную динамическую систему, можно пользоваться терминологией теории этих систем: фазовый портрет, установившийся процесс, аттрактор и т.д.

Известно, что нелинейные динамические системы обладают несколькими устойчивыми состояниями. То состояние, в котором оказалась динамическая система после некоторого числа итераций, зависит от ее на-

ВЕСТНИК БУРЯТСКОГО ГОСУДАРСТВЕННОГО УНИВЕРСИТЕТА

2012/1

чального состояния. Поэтому каждое устойчивое состояние (или, как говорят, - аттрактор) обладает некоторой областью начальных состояний, из которых система обязательно попадет в рассматриваемые конечные состояния. Таким образом фазовое пространство системы разбивается на области притяжения аттракторов. Если фазовым является двухмерное пространство, то окрашивая области притяжения различными цветами, можно получить цветовой фазовый портрет этой системы (итерационного процесса).

Рис. 3 Рис. 4

Стохастические. Получаются в том случае, если в итерационном процессе случайным образом менять какие-либо его параметры. При этом получаются объекты очень похожие на природные: несимметричные деревья, изрезанные береговые линии и т.д. Двумерные стохастические фракталы используются при моделировании рельефа местности и поверхности моря.

Рис. 5 Рис. 6

Танхасаев А.В. Построение фрактальных объектов при помощи библиотеки MPICH2

Методы построения фрактальных объектов.

L-systems. Понятие L-систем ввел Аристрид Линденмайер, в основном, для изучения формальных языков. В дальнейшем выяснилось, что с помощью них можно строить самоподобные фракталы. Алгоритм, реализующий L-системы в графическом виде, получил название turtle-графика (по-английски turtle - черепаха). Подробнее о L-системах можно посмотреть в книге: P.Prusinkiewicz & J. Hanan, Lindenmayer Systems, Fractals, and Plants, Lecture Notes in Biomathematics, N79, Springer-Verlag, New-York, 1989.

«Черепаховый» алгоритм представляет собой интерпретатор кодового слова, являющегося результатом выполнения L-системы, которое анализируется слева направо и может содержать следующие символы:

F - указывает, что «черепаха» должна сделать один шаг вперед с прорисовкой;

b - шаг вперед без прорисовки; «+» - увеличить угол; «-» - уменьшить угол; «[« - открыть ветвь; «]» - закрыть ветвь. Пример исходных данных для фрактала кривая Коха: Аксиома: F ;

Правило: F ® F - F + + F - F;

Угол: — .

3

Системы итерирующих функций(IFS). Метод «Систем Итерируемых Функций» (Iterated Functions System - IFS) появился в середине 80-х гг. как простое средство получения фрактальных структур.Н^ представляет собой систему функций из некоторого фиксированного класса функций, отображающих одно многомерное множество на другое. Наиболее простая IFS состоит из аффинных преобразований плоскости: X ' = A * X + B * Y + C Y ' = D * X + E * Y + F

Пример исходных данных для фрактала кривая Коха: Koch{

0.3333 0.0000 0.0000 0.3333 0.0000 0.0000 0.3333 0.0000 0.0000 0.3333 0.6666 0.0000 0.1667 -0.2887 0.2887 0.1667 0.3333 0.0000 -0.1667 0.2887 0.2887 0.1667 0.6666 0.0000}

Опыт построения фрактальных объектов. Для визуализации фрактальных объектов и подсчета фрактальной размерности была разработана программа Планиметр-стереометр. В ней были реализованы методы: IFS, L-systems, координатный и построение с помощью turtle графики. Изначально код был адаптирован для систем с последовательной обработкой данных.

ВЕСТНИК БУРЯТСКОГО ГОСУДАРСТВЕННОГО УНИВЕРСИТЕТА

2012/1

Инициатор

Построение ломаная 1.1

Построение ломаная 2

Схема 1

Инициатор

Построение ломаная 1

1.1 1.2

Построение ломаная 2

2.1

2.2

Схема 2

Организация параллельности вычислений, когда в один и тот же момент выполняется одновременно несколько операций обработки данных, осуществляется, в основном, за счет введения избыточности функциональных устройств (многопроцессорности) [1]. В этом случае можно достичь ускорения процесса решения вычислительной задачи, если осуществить разделение применяемого алгоритма на информационно независимые части и организовать выполнение каждой части вычислений на разных процессорах. Подобный подход позволяет выполнять необходимые вычисления с меньшими затратами времени, и возможность получения максимально-возможного ускорения ограничивается только числом имеющихся процессоров и количеством «независимых» частей в выполняемых вычислениях.

Параллельная модель программирования:

1) параллелизм данных;

2) параллелизм задач.

Подход, основанный на параллелизме данных, характеризуется тем, что:

• одна операция применяется сразу к нескольким элементам массива данных. Различные фрагменты такого массива обрабатываются на век-

Танхасаев А.В. Построение фрактальных объектов при помощи библиотеки MPICH2

торном процессоре или на разных процессорах (ядрах) параллельной вычислительной системы;

• обработкой данных управляет одна программа;

• пространство имен является глобальным;

• параллельные операции над элементами массива выполняются одновременно на всех доступных данной программе процессорах.

Подход, основанный на параллелизме задач, характеризуется тем, что:

• вычислительная задача разбивается на несколько относительно самостоятельных подзадач. Каждая подзадача выполняется на своем процессоре;

• для каждой подзадачи пишется своя собственная программа на обычном языке программирования (С++, Fortran и т.д.);

• подзадачи должны обмениваться результатами своей работы, получать исходные данные. Практически такой обмен осуществляется вызовом процедур специализированной библиотеки. Программист при этом может контролировать распределение данных между различными процессорами и различными подзадачами, а также обмен данными.

Программная реализация

MPICH2 - это быстродействующая и широко портируемая реализация стандарта MPI (реализованы оба стандарта MPI-1 и MPI-2). Цели создания MPICH2 следующие:

1. Предоставить реализацию MPI, которая эффективно поддерживает различные вычислительные и коммуникационные платформы, включая общедоступные кластеры (настольные системы, системы с общей памятью, многоядерные архитектуры), высокоскоростные сети (Ethernet 10 ГБит/с, InfiniBand, Myrinet, Quadrics) и эксклюзивные вычислительные системы (Blue Gene, Cray, SiCortex).

2. Сделать возможными передовые исследования технологии MPI с помощью легко расширяемой модульной структуры для создания производных реализаций.

При построении фрактала - кривая Коха был использован подход, основанный на параллелизме данных. Процедура формирования генератора фрактального объекта требует 3 параметра (координата начала, угол наклона «черепашки», масштаб), а алгоритм построения генератора остается прежним.

ВЕСТНИК БУРЯТСКОГО ГОСУДАРСТВЕННОГО УНИВЕРСИТЕТА

2012/1

1 итерация

Рис. 7. 1 процесс 2 итерация

Рис. 8. Порождены 4 параллельных потока

3 итерация

Рис. 9. Порождены 16 параллельных потоков

Реализация данного алгоритма проводилась с компьютерами на базе процессоров Intel Celeron E3300(2 ядра) и Intel Core 2 Quad(4 ядра). Повышение скорости алгоритма на базе 2-х ядерного процессора составила 1,87 раза относительно однопоточного приложения, а на базе 4-х ядерного процессора - 3,68 раза.

Литература

1. Немнюгин С., Стесик О. Параллельное программирование для многопроцессорных вычислительных систем. - СПб.: БХВ-Петербург, 2002.

2. Гергель В.П. Теория и практика параллельных вычислений. Интернет -университет информационных технологий - ИНТУИТ. ру, БИНОМ. Лаборатория знаний, 2007.

Хандаров Ф.В., Дондоков З.Б.-Д. Прогнозирование налога на доходы физических лиц с использованием искусственных нейронных сетей

3. Озеров С. Параллельное программирование. [Электронный ресурс] -2005. - Режим доступа к журн.: http://www.computerra.ru/242551/, свободный.

4. Пайтген Х.-О., Рихтер П.Х. Красота фракталов. - M.: Мир, 1989.

5. Мандельброт Б. Фрактальная геометрия природы. - М.: «Институт компьютерных исследований», 2002.

6. Кроновер Р. Фракталы и хаос в динамических системах. М.: Постмаркет, 2000. 352 с.

Танхасаев Аюр Васильевич - г. Улан-Удэ, Бурятский государственный университет, martin@bsu.ru, 68-40-47.

Tankhasaev Ayur Vasilievich - Ulan-Ude, Buryat State University, martin@bsu.ru, 68-40-47.

УДК 004+336.221 © Ф.В. Хандаров, З.Б.-Д. Дондоков

ПРОГНОЗИРОВАНИЕ НАЛОГА НА ДОХОДЫ ФИЗИЧЕСКИХ ЛИЦ С ИСПОЛЬЗОВАНИЕМ ИСКУССТВЕННЫХ НЕЙРОННЫХ СЕТЕЙ*

В статье излагается методика прогнозирования налога на доходы физических

лиц с использованием аппарата искусственных нейронных сетей. Приводятся

полученные результаты.

Ключевые слова: временные ряды, налоговое прогнозирование, отбор признаков.

F.V. Handarov, Z.B-D. Dondokov

PERSONAL INCOME TAX FORECASTING USING ARTIFICIAL NEURAL NETWORKS

The paper deals with methods of personal income tax forecasting using artificial

neural networks. The results are described.

Keywords: time series, tax forecasting, feature selection.

Введение

Одной из важных проблем в региональном экономическом планировании является прогнозирование налоговых поступлений; в частности, основного вида прямых налогов - налога на доходы физических лиц. Данный вид налога является третьим по величине отчислений в бюджет и отличается следующими важными особенностями:

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

• объектом обложения данным налогом служит именно доход, реально полученный налогоплательщиком;

• его плательщиками является практически все трудоспособное население страны;

* Работа выполнена при финансовой поддержке РГНФ. Проект №10-02-62206а/Т.

i Надоели баннеры? Вы всегда можете отключить рекламу.