Научная статья на тему 'Структура данных для представления геометрической модели трехмерного объекта'

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

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

Текст научной работы на тему «Структура данных для представления геометрической модели трехмерного объекта»

СТРУКТУРА ДАННЫХ ДЛЯ ПРЕДСТАВЛЕНИЯ ГЕОМЕТРИЧЕСКОЙ МОДЕЛИ ТРЕХМЕРНОГО ОБЪЕКТА

Д.В. Курённов, к.т.н.; А.С. Паршин, к.т.н. (Институт машиноведения УрО РАН, г. Екатеринбург, dmitriy-v-k@yandex.ru)

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

Ключевые слова: структура данных, геометрическое моделирование, обобщенный цилиндр, кривые и поверхности Безье.

При разработке современных САПР для различных отраслей промышленности удобно использовать общее универсальное геометрическое ядро - пакет геометрического моделирования. Его функции должны обеспечить создание геометрических моделей трехмерных объектов заданной сложности, выполнение широкого спектра операций с ними, представление результатов работы в различных формах. К необходимым условиям, обеспечивающим успешное и широкое практическое применение пакета, можно отнести высокую точность вычислений, быстроту выполнения алгоритмов, надежность и стабильность в работе, а также простоту и удобство в использовании. Успешная реализация большинства перечисленных функций и требований зависит от выбранной формы представления геометрической информации в системе - структуры данных, которая изначально должна строиться на их основе и с их максимальным учетом.

Требования к структуре

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

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

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

3. Для синтеза сложных объектов следует предварительно получить простые примитивы. Обычно к ним относят простые аналитические те-

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

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

Общая концепция

Объект является основой структуры и предназначен для моделирования реального геометрического объекта или его части. Можно выделить следующие главные компоненты объекта.

Единая поверхность. Описывает поверхность реального моделируемого объекта, является наиболее важным (но не единственным) свойством любого объекта.

Тип объекта. Все многообразие существующих объектов можно разделить на отдельные типы. Это даст возможность пользователю системы строить желаемый объект не путем описания единой поверхности, очень сложной и трудоемкой для ручного описания, а путем указания на желаемый тип и его параметры - другой необходимой компоненты объекта. Целесообразно использовать иерархию типов объектов, где более «верхний» базовый объект сможет представлять все, что может более «нижний» в иерархии объект, а тот, в свою очередь, сможет представлять только некоторый подкласс геометрии «верхнего» объек-

та. Преимуществом иерархии является наследование объектами-потомками всех свойств-параметров их базовых объектов с добавлением к ним своих, новых, что делает ее логически упорядоченной и легко расширяемой впоследствии новыми объектами.

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

Описание поверхности объекта

Существует необходимость описывать поверхность любого достаточно сложного объекта с возможно большей точностью и, главное, в виде единой универсальной структуры. Здесь можно выделить две основные задачи - геометрию и топологию.

Геометрия: найти минимальные элементы, из которых будут составляться вся поверхность, их вид, математическое описание.

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

Рассмотрим решение этих задач в разрабатываемой версии системы.

Элемент поверхности

В виде минимальных элементов, задающих участки поверхности, логично использовать рациональные параметрические бикубические сплайны - порции следующего вида: 0 2 -2 0"

P=Р(ц^)^и^^х

1 -4 -2 2 10

2 0 0

р р00 Р01 р р 02 Р р03 ■ 0 1 -2 0"

Ро Р11 р12 Р13 2 -4 2 1

р р 20 Р21 р р22 Р23 -2 2 0 0

Р р30 Р31 р32 Р р33 _ 1 0 0 0

3

V

2

X V

V

_ 1 _

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

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

Каждая порция имеет, естественно, не более четырех сторон, по которым она просто соединяется с четырьмя смежными ей порциями. Это самый большой недостаток данного подхода, поскольку сильно сужает класс описываемых поверхностей, в принципе ограничивая его одним лишь обобщенным цилиндром. Например, невозможно задать поверхность, получаемую при почти любом пересечении объектов (рис. 1).

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

Кривая на порции

Возьмем некоторую порцию поверхности P и кривую G, точно лежащую на ней (рис. 2). Кривая состоит из множества точек поверхности P, каждая из которых имеет параметрические координаты ц, v. Возьмем также плоскость в декартовой системе координат и отложим на ней точки, декартовы координаты которых совпадают с параметрическими координатами точек кривой G.

Через эти точки проведем некоторую кривую Ь и допустим, что ее можно представить в виде рационального кубического сплайна Ь(0 с характеристической ломаной Ь0Ь1Ь2Ь3, где точки Ь0, Ь1, Ь2, Ь3 будут задаваться однородными координатами X, У, Н.

4 4

шох, ШОУ,

Тогда ж(1)=^-, у(1)=-.

1=0

,=0

Если теперь координаты на плоскости х и у заменить на и и V (параметрические координаты на поверхности) и задать точки Ь0, Ьь Ь2, Ь3 однородными координатами и, V, Н, то можно аналогично получить текущие параметрические координаты точки кривой:

4 4

и(1)=^-, V«=-.

Е&ЮН, Е&(1)Н,

1=0 1=0

Тогда кривая О будет отображением кривой Ь на поверхность Р: О(1)=P(u(t),v(t)).

Таким образом, определен способ задания кривых - сплайнов достаточно широкого класса,

заведомо точно принадлежащих какой-либо порции, через задание вершин их характеристической ломаной в параметрических координатах данной порции.

Секция поверхности

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

Литература

1. Норенков И.П., Маничев В.Б. Основы теории и проектирования САПР: учеб. для вузов. М.: Высш. шк., 1990. 335 с.

2. Препарата Ф., Шеймос М. Вычислительная геометрия: введение. М.: Мир, 1989.

3. Сухих Б.И., Вайсбурд Р.А. Вычислительная геометрия. Основные объекты и преобразования: учеб. пособ. Свердловск: УПИ, 1989. 92 с.

КЛАССИФИКАЦИЯ ЭЛЕМЕНТОВ ИНФОРМАЦИОННОЙ СИСТЕМЫ

ОРГАНИЗАЦИЙ СВЯЗИ

Е.В. Горюнов, к.э.н. (ЗАО «СиБОСС», г. Геленджик, e.goryunov@mail.ru)

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

Ключевые слова: классификация, информационная система, элемент, связь, сеть, телекоммуникации.

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

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

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