Cетка в трехмерном пространстве

Задана функция двух переменных Cетка в трехмерном пространстве - student2.ru . Требуется построить поверхность с выделенными рёбрами по узлам области Cетка в трехмерном пространстве - student2.ru , где Cетка в трехмерном пространстве - student2.ru . Строим разбиение области, узлы Cетка в трехмерном пространстве - student2.ru - определяет два двумерных массива X и Y. Тогда сетчатую поверхность можно построить командой:

mesh(X, Y, Z, C)

Команда mesh(X, Y, Z, C) выводит на экран сетчатую поверхность для значений массива Z, где Cетка в трехмерном пространстве - student2.ru,определенных на множестве значений массивов X и Y. Цвета узлов поверхности задаются массивом C. Цвета ребер определяются свойством EdgeColor объекта surface. Можно задать одинаковый цвет для всех ребер, определив его в виде вектора [r, g, b] интенсивности трех цветов - красного, зеленого, синего. Если определить спецификацию none, то ребра не будут прорисовываться. Если определить спецификацию flat, то цвет ребер ячейки определяется цветом того узла, который был первым при обходе этой ячейки. Поскольку одни и те же ребра обходятся несколько раз, то цвета будут замещаться. Если определить спецификацию interp, то будет реализована линейная интерполяция цвета между вершинами ребра.

Применение функции shading после обращения к функции mesh изменяет спецификации свойств EdgeColor и FaceColor согласно следующей таблице.

Свойство Применяемая функция
mesh shading flat shading interp
EdgeColor flat flat interp
FaceColor Цвет фона Цвет фона Цвет фона

Команда mesh(x, y, Z, C) выполняет ту же функцию, но вместо двумерных массивов X, Y использует их одномерные проекции, так что если length(x) = n, а length(y) = m, то [m, n] = size(Z). В этом случае узлы сетчатой поверхности определяются тройками {x(j), y(i), Z(i, j)}, где вектор x определяет столбцы массива Z, а y - строки.

Команда mesh(Z, C) использует сетку, которая определяется одномерными массивами x = 1:n и y = 1:m, где m*n – размеры матрицы Z.

Команды mesh(X, Y, Z), mesh(x, y, Z), mesh(Z) используют в качестве массива цвета C = Z, то есть цвет в этом случае пропорционален высоте поверхности.

Группа команд meshc(...) в дополнение к трехмерным поверхностям строит проекцию линий постоянного уровня.

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

Функция h = mesh(...) возвращает дескриптор h для графического объекта surface.

Пример 5.11.

Для функции Cетка в трехмерном пространстве - student2.ruпостроить трехмерную поверхность с проекциями линий постоянного уровня.

>> [X,Y]=meshgrid([-2:0.1:2]);
>> Z = X . * exp(- X .^ 2 - Y .^ 2);
>> meshc(X, Y, Z)

Cетка в трехмерном пространстве - student2.ru

Рис.9. Результат примера 5.11

5.11. Затененная сетчатая поверхность

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

Команда surf(X, Y, Z, C) выводит на экран сетчатую поверхность для значений массива Z, определенных на множестве значений массивов X и Y. Цвет ячейки определяется массивом C. Цвет ребер - черный, определяется свойством EdgeColor, специфицированным как [0,0,0]. Можно задать одинаковый цвет для всех ребер, определив его в виде вектора [r,g,b] интенсивности трех цветов - красного, зеленого, синего. Если определить спецификацию none, то ребра не будут прорисовываться.

Применение функции shading после обращения к функции surf изменяет спецификации свойств EdgeColor и FaceColor графического объекта surface согласно следующей таблице.

Свойство Применяемая функция
surf shading flat shading interp
EdgeColor [0,0,0] none none
FaceColor flat flat interp

Команда surf(x, y, Z, C) выполняет ту же функцию, но вместо двумерных массивов X, Y использует их одномерные проекции, так что если length(x) = n, а length(y) = m, то [m, n] = size(Z). В этом случае узлы сетчатой поверхности определяются тройками {x(j), y(i), Z(i, j)}, где вектор x определяет столбцы массива Z, а y - строки. Команда surf(Z,C) использует сетку, которая определяется одномерными массивами x = 1:n и y =1:m. Команды surf(X, Y, Z), surf(x, y, Z), surf(Z) используют в качестве массива цвета C = Z, то есть цвет в этом случае пропорционален высоте поверхности. Группа команд surfc(...) в дополнение к трехмерным затененным поверхностям строит проекцию линий постоянного уровня. Функция h = surf(...) возвращает дескриптор h для графического объекта surface.

Пример 5.12.Построить трехмерную затененную поверхность функции Cетка в трехмерном пространстве - student2.ruсо шкалой затененности.

>> [X,Y]=meshgrid([-2:0.1:2]);
>> Z = X . * exp(- X ^ 2 - Y ^ 2);
>> surf(X, Y, Z)
>> colormap(gray)
>> shading interp
>> colorbar

Cетка в трехмерном пространстве - student2.ru

Рис.10. Затененная поверхность функции Cетка в трехмерном пространстве - student2.ru

Пример 5.13. Рассмотрим пример сферы, которая раскрашена в соответствии с матрицей Адамара (Hadamard), часто используемой в теории кодирования сигналов и составленной только из двух чисел 1 и -1.

>> k=5;n=2^k-1;
>> [X,Y,Z]=sphere(n);
>> C=hadamard(2^k);
>> surf(X,Y,Z,C);
>> colormap([111,2,32,32,3])
>> colorbar

Cетка в трехмерном пространстве - student2.ru

Рис.11. Результат примера 5.13

В силу того, что поверхность двумерна для задания поверхности можно использовать два независимых параметра i и j, которые изменяются непрерывно, например, в прямоугольнике 1 ≤ i ≤ m, 1≤j ≤ n. Тогда поверхность будет определяться тремя функциями x(i, j), y(i, j), z(i, j). Когда i и j целые числа, они задают прямоугольную сетку с целочисленными значениями для узлов. Функции x(i, j), y(i, j), z(i, j) определяют двумерные массивы X, Y, Z размера m х n. Четвертая функция - цвет ячеек поверхности c(i, j) задает четвертую матрицу C.

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

Cетка в трехмерном пространстве - student2.ru

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

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

Рассмотрим, как в этом случае действует функция закраски shading. Если задано значение shading interp, то цвет ячейки определяется как билинейная функция местных координат. Если задано значение shading faceted (принято по умолчанию) или shading flat, то цвет ячейки постоянен и определяется цветом верхней левой вершины, как показано на следующей схеме:

Cетка в трехмерном пространстве - student2.ru

Наши рекомендации