50303

Построение плоских фигур

Лекция

Математика и математический анализ

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

Русский

2014-01-20

428 KB

2 чел.

Глава 1. Построение плоских фигур.

1.1 Экранные координаты.

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

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

Допустим, наш рисунок занимает на плоскости  прямоугольный участок, в пределах которого координаты изменяются в пределах от  до ; и от  до . Мы хотим изобразить этот рисунок на участке экрана ограниченного координатами  и , см. рис. 1.

Чтобы рисунок не искажался, связь между физическими и экранными координатами должна быть линейной, то есть выражаться формулами

.     (1)                                                     

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

,                                       (2)

из которых элементарно находим

;     .       (3)

Аналогичные выражения можно получить и для параметров преобразования вертикальных координат:

;     .       (3a)

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

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

,                   (4)

где  - обозначает операцию целочисленного округления, а параметры преобразований определяются по формулам (3)-(3a).

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

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

 1.2 Построение графиков функций.

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

1) имеет ли функция в заданном интервале особенности, не обращается ли она в бесконечнось, при всех ли значения аргумента она определена;

2) пределы изменения  - область  , что необходимо для оценки коэффициентов преобразований.

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

- оформить процедуру преобразования переменных к экранным координатам;

- задать функциональную зависимость, описывающую данную кривую;

- построить оси координат, при необходимости их оцифровать;

- переместить графический курсор в начальную точку с координатами ;

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

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

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

 Шаг аргумента  следует выбирать таким, чтобы длина отрезка на экране составляла 2-3 пиксела, при большем шаге может быть заметна изломанность линии, уменьшение шага не приводит к улучшению качества изображения, а только затягивает время построения.

Длину отрезка можно оценить по формуле  , где - производная функции.

Пример . Построить график функции  при изменении  от -2 до 2.

В этих пределах изменения   функция изменяется от 0 до 4 и является непрерывной. Примем масштабные множители  равными 50 (при этом рисунок разместится в пределах квадрата со стороной 200 пикселов). Параметры сдвигов  можно выбрать так чтобы изображение поместилось в пределах экрана (например, можно положить их равными координатам центра экрана). Шаг изменения аргумента  примем равным 0,1 (что соответствует изменению горизонтальной координаты на 5 пикселов).

 На рисунке 2 показан результат построения. Там же приведенo изображениe полученнoе при шаге   при «точечном»  построении графика. Сравните !

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

Пример. Построить семейство функций  в интервале  для параметра , изменяющегося от -5 до 5 с шагом 1.

 Простейший анализ функции показывает, что

а) в заданном интервале функция не обращается в бесконечность, достигает максимального значения  в точке  при ;

б) при функция имеет минимум в точке , при этом ; наибольшая глубина минимума при , тогда .

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

На рис.3 показано построенное семейство. Обратите внимание, что для всех кривых, кроме кривой последней, соответствующей , условием окончания послужило ограничение .

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

Пример. Построить семейство функций , где  на интервале .

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

1 В языке Pascal удобно вести построение с помощью оператора LineTo, предварительно установив начальное положение курсора с помощью оператора MoveTo.


 

А также другие работы, которые могут Вас заинтересовать

48697. Изготовление детали «Упор» 1.03 MB
  Прокат в металлургии – это продукция, получаемая на прокатных станках путём прокатки. Прокатывается металл, полученный на предыдущей стадии обработки металла – литьё. Обычно его называют «прокат металла» или «металлопрокат».
48698. Практическое использование возможностей MS WORD и EXCEL 724.5 KB
  Изучение операционной системы Windows, компонентов MS Word и Excel и получение практических навыков работы с современными информационными технологиями. Получение представления о формировании табличной базы данных и о возможностях при работе с ней на примере базы данных в MS Excel.
48699. Следящая система управления зеркалом телескопа 12.3 MB
  Задачей данной курсовой работы является введение в основы проектирования системы автоматического регулирования. На основе следящей системы работают многие системы управления например телескопа радиолокационной антенны зенитного орудия и т. минВ Коэффициент усиления ЭМУ КЭМУ = 7 Коэффициент передачи сельсинов Кс = 076 В град Коэффициент передачи редуктора Кр = 0075 Добротность системы определяется численными значениями оценок: Максимальная скорость слежения Umx = 9 град с Максимальная...
48700. Цифровой аудио сигма-дельта модулятор по 0,35 мкм технологии 713 KB
  При частоте дискретизации равной 4 МГц и коэффициентом передискретизации равным 80 реализация модулятора по технологии 08 мкм. Берем В пФ пФ МГц Найдем крутизну входных транзисторов Мр1 и Мр2: С другой стороны: Берем длину канала L=1 мкм мкм Рассчитаем ток: мА Все выше приведенные значения характерны и для транзисторов Мр3 Мр4 в виду равенства токов. Найдем параметры транзисторов Мn1 Mn2 Мn3 и Mn4: мА Выразим отношение W L: Берем длину канала L=1 мкм мкм Находим крутизны транзисторов: мА В Найдем ток крутизну и ширину...
48702. Гломестный канал (УМК) наземного фазового моноимпульсного радиолокатора (РЛ) дальнего обнаружения объектов с ЭПР 1.16 MB
  Расчёт параметров сигнала. Параметры РЛ: дальность действия от соответствующей длительности импульса зондирующего сигнала до где длительность прямой видимости при высоте цели сектор обзора по углу места при разрешающей способности по углу. При расстоянии до цели погрешность измерения угла места не должна превышать заданного значения при коэффициенте шума приемника равном 3 и потерях энергии сигнала по высокой частоте и при обработке. 2 Определить параметры антенны; зондирующего сигнала; трактов формирования...
48703. Расчет изменения частоты вращения вала 1.32 MB
  Опорами ротора служат подшипники скольжения 8 с жидкой принудительной смазкой (под давлением) от маслоустановки агрегатов. Остаточное осевое усилие ротора воспринимают два упорных подшипника 9. Рабочее колесо литое, одностороннего входа. Направляющий аппарат – литой.
48704. Влияние формы контура области питания скважины. Возможность использования формулы радиального притока в случае нерадиального движения жидкости к скважине 891.5 KB
  Представим себе, что в однородный горизонтальный пласт весьма больших (теоретически неограниченных) размеров и постоянной мощности проведены гидродинамически совершенные равнодебитные нагнетательная и эксплуатационная скважины одинакового радиуса R.
48705. Анализ технических возможностей способов сварки плавлением барабана изготовленного из стали 10 216 KB
  Введение Сварка широко применяется в основных отраслях производства так как резко сокращает сроки выполнения работ и трудоемкость производственных процессов. Сварка позволяет уменьшить затраты на единицу продукции сократить длительность производственного цикла улучшить качество изделий. Для данного изделия возможны следующие способы сварки плавлением: ручная дуговая сварка; сварка в защитных газах плавящимся электродом; –плазменная сварка; лазерная сварка; электроннолучевая сварка; газовая сварка. ручная дуговая сварка покрытым...